Fix get_line possible leak

This commit is contained in:
ado 2024-02-23 00:59:58 +01:00
parent 230da6a3f2
commit ea21b9ba04

View File

@ -28,7 +28,7 @@ inline void assert_throw_on_error_not_defined() {
"'throw_on_error' is enabled"); "'throw_on_error' is enabled");
} }
#if __unix__ #if __unix__XX
inline ssize_t get_line(char** lineptr, size_t* n, FILE* stream) { inline ssize_t get_line(char** lineptr, size_t* n, FILE* stream) {
return getline(lineptr, n, stream); return getline(lineptr, n, stream);
} }
@ -45,14 +45,15 @@ ssize_t get_line(char** lineptr, size_t* n, FILE* fp) {
char buff[get_line_initial_buffer_size]; char buff[get_line_initial_buffer_size];
if (*lineptr == nullptr || *n < sizeof(buff)) { if (*lineptr == nullptr || *n < sizeof(buff)) {
*n = sizeof(buff); size_t new_n = sizeof(buff);
auto new_lineptr = static_cast<char*>(realloc(*lineptr, *n)); auto new_lineptr = static_cast<char*>(realloc(*lineptr, new_n));
if (new_lineptr == nullptr) { if (new_lineptr == nullptr) {
errno = ENOMEM; errno = ENOMEM;
return -1; return -1;
} }
*lineptr = new_lineptr; *lineptr = new_lineptr;
*n = new_n;
} }
(*lineptr)[0] = '\0'; (*lineptr)[0] = '\0';
@ -62,7 +63,7 @@ ssize_t get_line(char** lineptr, size_t* n, FILE* fp) {
size_t buff_used = strlen(buff); size_t buff_used = strlen(buff);
if (*n < buff_used + line_used) { if (*n < buff_used + line_used) {
*n *= 2; size_t new_n = *n * 2;
auto new_lineptr = static_cast<char*>(realloc(*lineptr, *n)); auto new_lineptr = static_cast<char*>(realloc(*lineptr, *n));
if (new_lineptr == nullptr) { if (new_lineptr == nullptr) {
@ -71,6 +72,7 @@ ssize_t get_line(char** lineptr, size_t* n, FILE* fp) {
} }
*lineptr = new_lineptr; *lineptr = new_lineptr;
*n = new_n;
} }
memcpy(*lineptr + line_used, buff, buff_used); memcpy(*lineptr + line_used, buff, buff_used);