* fix a buffer overflow
* correctly return -1 when nothing can be read
* In either case, on a successful call, *buf and *n will be updated to reflect
* the buffer address and allocated size respectively.
*/
* In either case, on a successful call, *buf and *n will be updated to reflect
* the buffer address and allocated size respectively.
*/
-ssize_t xbt_getline(char **buf, size_t * n, FILE * stream)
+ssize_t xbt_getline(char **buf, size_t *n, FILE *stream)
+ ch = getc(stream);
+ if (ferror(stream) || feof(stream))
+ return -1;
+
- *buf = xbt_malloc(512);
- if (feof(stream))
- return (ssize_t) - 1;
-
- for (i = 0; (ch = fgetc(stream)) != EOF; i++) {
-
- if (i >= (*n) + 1)
+ i = 0;
+ do {
+ if (i == *n)
*buf = xbt_realloc(*buf, *n += 512);
*buf = xbt_realloc(*buf, *n += 512);
-
- (*buf)[i] = ch;
-
- if ((*buf)[i] == '\n') {
- i++;
- (*buf)[i] = '\0';
- break;
- }
- }
+ (*buf)[i++] = ch;
+ } while (ch != '\n' && (ch = getc(stream)) != EOF);
if (i == *n)
*buf = xbt_realloc(*buf, *n += 1);
if (i == *n)
*buf = xbt_realloc(*buf, *n += 1);