- fix bug #887, in bb_get_chomped_line_from_file(), the last char was removed
authorBernhard Reutner-Fischer <rep.dot.nop@gmail.com>
Sat, 10 Jun 2006 11:05:12 +0000 (11:05 -0000)
committerBernhard Reutner-Fischer <rep.dot.nop@gmail.com>
Sat, 10 Jun 2006 11:05:12 +0000 (11:05 -0000)
  unconditionally, even if it was not a newline.
  This was apparently broken by r14254
- whitespace while at it.

libbb/get_line_from_file.c

index 44cf448691a37c05b0b238af59bc4a441d41b13b..68837b20d785c7c3dbffae52866228992fcc7d1f 100644 (file)
@@ -18,7 +18,7 @@
  * stored and free'ed  by the caller.  If end is null '\n' isn't considered
  * and of line.  If end isn't null, length of the chunk read is stored in it. */
 
-char *bb_get_chunk_from_file(FILE *file, int *end)
+char *bb_get_chunk_from_file(FILE * file, int *end)
 {
        int ch;
        int idx = 0;
@@ -30,10 +30,12 @@ char *bb_get_chunk_from_file(FILE *file, int *end)
                if (idx > linebufsz - 2) {
                        linebuf = xrealloc(linebuf, linebufsz += 80);
                }
-               linebuf[idx++] = (char)ch;
-               if (!ch || (end && ch == '\n')) break;
+               linebuf[idx++] = (char) ch;
+               if (!ch || (end && ch == '\n'))
+                       break;
        }
-       if (end) *end = idx;
+       if (end)
+               *end = idx;
        if (linebuf) {
                if (ferror(file)) {
                        free(linebuf);
@@ -45,18 +47,21 @@ char *bb_get_chunk_from_file(FILE *file, int *end)
 }
 
 /* Get line, including trailing /n if any */
-char *bb_get_line_from_file(FILE *file)
+char *bb_get_line_from_file(FILE * file)
 {
        int i;
+
        return bb_get_chunk_from_file(file, &i);
 }
 
 /* Get line.  Remove trailing /n */
-char *bb_get_chomped_line_from_file(FILE *file)
+char *bb_get_chomped_line_from_file(FILE * file)
 {
        int i;
-       char *c=bb_get_chunk_from_file(file, &i);
-       if(i) c[--i]=0;
-       
+       char *c = bb_get_chunk_from_file(file, &i);
+
+       if (i && c[--i] == '\n')
+               c[i] = 0;
+
        return c;
 }