diff options
author | Paul Eggert <eggert@cs.ucla.edu> | 2005-07-03 06:26:15 +0000 |
---|---|---|
committer | Paul Eggert <eggert@cs.ucla.edu> | 2005-07-03 06:26:15 +0000 |
commit | 9c17ef9a811b78f3b1aa432e3e83e609869238f4 (patch) | |
tree | 89d1bb8fb0291bc9ab56c489379e5ec7a506b5fa | |
parent | 6af6438b0a0ffc4d4b92e81a70d29557cc573309 (diff) | |
download | coreutils-9c17ef9a811b78f3b1aa432e3e83e609869238f4.tar.xz |
Don't include stdio-safer.h; no longer needed.
(writeline): Remove stream arg; we now always output to stdout.
All callers changed.
(check_file): Reuse stdout rather than opening a new stream.
This saves a file descriptor.
-rw-r--r-- | src/uniq.c | 37 |
1 files changed, 12 insertions, 25 deletions
diff --git a/src/uniq.c b/src/uniq.c index e58aa26aa..5f0ea74f9 100644 --- a/src/uniq.c +++ b/src/uniq.c @@ -30,7 +30,6 @@ #include "hard-locale.h" #include "posixver.h" #include "quote.h" -#include "stdio-safer.h" #include "xmemcoll.h" #include "xstrtol.h" #include "memcasecmp.h" @@ -235,14 +234,14 @@ different (char *old, char *new, size_t oldlen, size_t newlen) return oldlen != newlen || memcmp (old, new, oldlen); } -/* Output the line in linebuffer LINE to stream STREAM +/* Output the line in linebuffer LINE to standard output provided that the switches say it should be output. MATCH is true if the line matches the previous line. If requested, print the number of times it occurred, as well; LINECOUNT + 1 is the number of times that the line occurred. */ static void -writeline (struct linebuffer const *line, FILE *stream, +writeline (struct linebuffer const *line, bool match, uintmax_t linecount) { if (! (linecount == 0 ? output_unique @@ -251,9 +250,9 @@ writeline (struct linebuffer const *line, FILE *stream, return; if (countmode == count_occurrences) - fprintf (stream, "%7" PRIuMAX " ", linecount + 1); + printf ("%7" PRIuMAX " ", linecount + 1); - fwrite (line->buffer, sizeof (char), line->length, stream); + fwrite (line->buffer, sizeof (char), line->length, stdout); } /* Process input file INFILE with output to OUTFILE. @@ -262,22 +261,13 @@ writeline (struct linebuffer const *line, FILE *stream, static void check_file (const char *infile, const char *outfile) { - FILE *ostream; struct linebuffer lb1, lb2; struct linebuffer *thisline, *prevline; - bool is_stdin = STREQ (infile, "-"); - bool is_stdout = STREQ (outfile, "-"); - if (!is_stdin && ! freopen (infile, "r", stdin)) + if (! (STREQ (infile, "-") || freopen (infile, "r", stdin))) error (EXIT_FAILURE, errno, "%s", infile); - if (is_stdout) - ostream = stdout; - else - { - ostream = fopen_safer (outfile, "w"); - if (! ostream) - error (EXIT_FAILURE, errno, "%s", outfile); - } + if (! (STREQ (outfile, "-") || freopen (outfile, "w", stdout))) + error (EXIT_FAILURE, errno, "%s", outfile); thisline = &lb1; prevline = &lb2; @@ -309,7 +299,7 @@ check_file (const char *infile, const char *outfile) || different (thisfield, prevfield, thislen, prevlen)) { fwrite (thisline->buffer, sizeof (char), - thisline->length, ostream); + thisline->length, stdout); SWAP_LINES (prevline, thisline); prevfield = thisfield; @@ -364,13 +354,13 @@ check_file (const char *infile, const char *outfile) if ((delimit_groups == DM_PREPEND) || (delimit_groups == DM_SEPARATE && !first_delimiter)) - putc ('\n', ostream); + putchar ('\n'); } } if (!match || output_later_repeated) { - writeline (prevline, ostream, match, match_count); + writeline (prevline, match, match_count); SWAP_LINES (prevline, thisline); prevfield = thisfield; prevlen = thislen; @@ -379,17 +369,14 @@ check_file (const char *infile, const char *outfile) } } - writeline (prevline, ostream, false, match_count); + writeline (prevline, false, match_count); } closefiles: if (ferror (stdin) || fclose (stdin) != 0) error (EXIT_FAILURE, 0, _("error reading %s"), infile); - /* Check for errors and close ostream only if it's not stdout -- - stdout is handled via the atexit-invoked close_stdout function. */ - if (!is_stdout && (ferror (ostream) || fclose (ostream) != 0)) - error (EXIT_FAILURE, 0, _("error writing %s"), outfile); + /* stdout is handled via the atexit-invoked close_stdout function. */ free (lb1.buffer); free (lb2.buffer); |