X-Git-Url: http://erislabs.net/gitweb/?a=blobdiff_plain;f=lib%2Flinebuffer.c;h=3b15d1fb3066511357a4fc83aaba085515b88f9b;hb=a655ee23a7d332ff458d3785df802f69acd6ea4f;hp=7f53aed70bdf57ef169c63438d7e4174fff8b9c5;hpb=87e2683e04a8ef7d18ea8f515e65d8885e5a2355;p=gnulib.git diff --git a/lib/linebuffer.c b/lib/linebuffer.c index 7f53aed70..3b15d1fb3 100644 --- a/lib/linebuffer.c +++ b/lib/linebuffer.c @@ -1,5 +1,5 @@ /* linebuffer.c -- read arbitrarily long lines - Copyright (C) 1986, 1991 Free Software Foundation, Inc. + Copyright (C) 1986, 1991, 1998, 1999 Free Software Foundation, Inc. This program is free software; you can redistribute it and/or modify it under the terms of the GNU General Public License as published by @@ -12,12 +12,17 @@ GNU General Public License for more details. You should have received a copy of the GNU General Public License - along with this program; if not, write to the Free Software - Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA. */ + along with this program; if not, write to the Free Software Foundation, + Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. */ /* Written by Richard Stallman. */ +#ifdef HAVE_CONFIG_H +# include +#endif + #include +#include #include "linebuffer.h" char *xmalloc (); @@ -27,8 +32,7 @@ void free (); /* Initialize linebuffer LINEBUFFER for use. */ void -initbuffer (linebuffer) - struct linebuffer *linebuffer; +initbuffer (struct linebuffer *linebuffer) { linebuffer->length = 0; linebuffer->size = 200; @@ -36,55 +40,52 @@ initbuffer (linebuffer) } /* Read an arbitrarily long line of text from STREAM into LINEBUFFER. - Remove any newline. Does not null terminate. + Keep the newline; append a newline if it's the last line of a file + that ends in a non-newline character. Do not null terminate. Return LINEBUFFER, except at end of file return 0. */ struct linebuffer * -readline (linebuffer, stream) - struct linebuffer *linebuffer; - FILE *stream; +readline (struct linebuffer *linebuffer, FILE *stream) { int c; char *buffer = linebuffer->buffer; char *p = linebuffer->buffer; char *end = buffer + linebuffer->size; /* Sentinel. */ - if (feof (stream)) - { - linebuffer->length = 0; - return 0; - } + if (feof (stream) || ferror (stream)) + return 0; - while (1) + do { c = getc (stream); + if (c == EOF) + { + if (p == buffer) + return 0; + if (p[-1] == '\n') + break; + c = '\n'; + } if (p == end) { linebuffer->size *= 2; buffer = (char *) xrealloc (buffer, linebuffer->size); - p += buffer - linebuffer->buffer; + p = p - linebuffer->buffer + buffer; linebuffer->buffer = buffer; end = buffer + linebuffer->size; } - if (c == EOF || c == '\n') - break; *p++ = c; } + while (c != '\n'); - if (feof (stream) && p == buffer) - { - linebuffer->length = 0; - return 0; - } - linebuffer->length = p - linebuffer->buffer; + linebuffer->length = p - buffer; return linebuffer; } /* Free linebuffer LINEBUFFER and its data, all allocated with malloc. */ void -freebuffer (linebuffer) - struct linebuffer *linebuffer; +freebuffer (struct linebuffer *linebuffer) { free (linebuffer->buffer); free (linebuffer);