From 0dd27bdf17a0c21918ebb8fafd1dcdea7531a5e9 Mon Sep 17 00:00:00 2001 From: Paul Eggert Date: Thu, 2 Sep 2004 23:56:42 +0000 Subject: (dummy_closed, CLOSED, dummy_endlist, ENDLIST): Remove; it's not portable C to assume FILE is a complete type. (paste_parallel): Use null instead of ENDLIST, and an explicit boolean instead of CLOSED. --- src/paste.c | 41 ++++++++++++++++++++--------------------- 1 file changed, 20 insertions(+), 21 deletions(-) (limited to 'src') diff --git a/src/paste.c b/src/paste.c index 3ab66dacb..7d0f615b5 100644 --- a/src/paste.c +++ b/src/paste.c @@ -52,14 +52,6 @@ /* Indicates that no delimiter should be added in the current position. */ #define EMPTY_DELIM '\0' -static FILE dummy_closed; -/* Element marking a file that has reached EOF and been closed. */ -#define CLOSED (&dummy_closed) - -static FILE dummy_endlist; -/* Element marking end of list of open files. */ -#define ENDLIST (&dummy_endlist) - /* Name this program was run with. */ char *program_name; @@ -154,13 +146,19 @@ paste_parallel (size_t nfiles, char **fnamptr) round, the string of delimiters must be preserved. delbuf[0] through delbuf[nfiles] store the delimiters for closed files. */ - char *delbuf; - FILE **fileptr; /* Streams open to the files to process. */ - size_t files_open; /* Number of files still open to process. */ - bool opened_stdin = false; /* true if any fopen got fd == STDIN_FILENO */ + char *delbuf = xmalloc (nfiles + 2); + + /* Streams open to the files to process. */ + FILE **fileptr = xnmalloc (nfiles + 1, sizeof *fileptr); + + /* Which of these streams are closed. */ + bool *closed = xcalloc (nfiles, sizeof *closed); + + /* Number of files still open to process. */ + size_t files_open; - delbuf = xmalloc (nfiles + 2); - fileptr = xnmalloc (nfiles + 1, sizeof *fileptr); + /* True if any fopen got fd == STDIN_FILENO. */ + bool opened_stdin = false; /* Attempt to open all files. This could be expanded to an infinite number of files, but at the (considerable) expense of remembering @@ -183,7 +181,7 @@ paste_parallel (size_t nfiles, char **fnamptr) } } - fileptr[files_open] = ENDLIST; + fileptr[files_open] = NULL; if (opened_stdin && have_read_stdin) error (EXIT_FAILURE, 0, _("standard input is closed")); @@ -200,11 +198,11 @@ paste_parallel (size_t nfiles, char **fnamptr) size_t delims_saved = 0; /* Number of delims saved in `delbuf'. */ size_t i; - for (i = 0; fileptr[i] != ENDLIST && files_open; i++) + for (i = 0; fileptr[i] && files_open; i++) { int chr IF_LINT (= 0); /* Input character. */ size_t line_length = 0; /* Number of chars in line. */ - if (fileptr[i] != CLOSED) + if (! closed[i]) { chr = getc (fileptr[i]); if (chr != EOF && delims_saved) @@ -227,7 +225,7 @@ paste_parallel (size_t nfiles, char **fnamptr) { /* EOF, read error, or closed file. If an EOF or error, close the file and mark it in the list. */ - if (fileptr[i] != CLOSED) + if (! closed[i]) { if (ferror (fileptr[i])) { @@ -242,11 +240,11 @@ paste_parallel (size_t nfiles, char **fnamptr) ok = false; } - fileptr[i] = CLOSED; + closed[i] = true; files_open--; } - if (fileptr[i + 1] == ENDLIST) + if (! fileptr[i + 1]) { /* End of this output line. Is this the end of the whole thing? */ @@ -277,7 +275,7 @@ paste_parallel (size_t nfiles, char **fnamptr) somedone = true; /* Except for last file, replace last newline with delim. */ - if (fileptr[i + 1] != ENDLIST) + if (fileptr[i + 1]) { if (chr != '\n' && chr != EOF) putc (chr, stdout); @@ -297,6 +295,7 @@ paste_parallel (size_t nfiles, char **fnamptr) } } free (fileptr); + free (closed); free (delbuf); return ok; } -- cgit v1.2.3-70-g09d2