diff options
Diffstat (limited to 'src')
-rw-r--r-- | src/sort.c | 71 |
1 files changed, 23 insertions, 48 deletions
diff --git a/src/sort.c b/src/sort.c index 53c2d8822..da442f73c 100644 --- a/src/sort.c +++ b/src/sort.c @@ -361,6 +361,17 @@ cleanup (void) unlink (node->name); } +/* Report an error for STRING, clean up, and exit. */ + +static void die PARAMS ((char const *)) ATTRIBUTE_NORETURN; +static void +die (char const *string) +{ + error (0, errno, "%s", string); + cleanup (); + exit (SORT_FAILURE); +} + /* Create a new temporary file, returning its newly allocated name. Store into *PFP a stream open for writing. */ @@ -394,11 +405,7 @@ create_temp_file (FILE **pfp) errno = saved_errno; if (fd < 0 || (*pfp = fdopen (fd, "w")) == NULL) - { - error (0, errno, "%s", file); - cleanup (); - exit (SORT_FAILURE); - } + die (file); return file; } @@ -416,11 +423,7 @@ xfopen (const char *file, const char *how) else { if ((fp = fopen_safer (file, how)) == NULL) - { - error (0, errno, "%s", file); - cleanup (); - exit (SORT_FAILURE); - } + die (file); } return fp; @@ -440,11 +443,7 @@ xfclose (FILE *fp, char const *file) else { if (fclose (fp) != 0) - { - error (0, errno, "%s", file); - cleanup (); - exit (SORT_FAILURE); - } + die (file); } } @@ -452,11 +451,7 @@ static void write_bytes (const char *buf, size_t n_bytes, FILE *fp, const char *output_file) { if (fwrite (buf, 1, n_bytes, fp) != n_bytes) - { - error (0, errno, _("%s: write error"), output_file); - cleanup (); - exit (SORT_FAILURE); - } + die (output_file); } /* Append DIR to the array of temporary directory names. */ @@ -663,11 +658,7 @@ sort_buffer_size (FILE *const *fps, int nfps, : strcmp (files[i], "-") == 0 ? fstat (STDIN_FILENO, &st) : stat (files[i], &st)) != 0) - { - error (0, errno, "%s", files[i]); - cleanup (); - exit (SORT_FAILURE); - } + die (files[i]); file_size = S_ISREG (st.st_mode) ? st.st_size : INPUT_FILE_SIZE_GUESS; @@ -917,11 +908,7 @@ fillbuf (struct buffer *buf, register FILE *fp, char const *file) if (bytes_read != readsize) { if (ferror (fp)) - { - error (0, errno, "%s", file); - cleanup (); - exit (SORT_FAILURE); - } + die (file); if (feof (fp)) { buf->eof = 1; @@ -2450,11 +2437,7 @@ but lacks following character offset")); if ((STREQ (files[i], "-") ? fstat (STDIN_FILENO, &instat) : stat (files[i], &instat)) != 0) - { - error (0, errno, "%s", files[i]); - cleanup (); - exit (SORT_FAILURE); - } + die (files[i]); if (S_ISREG (instat.st_mode) && !SAME_INODE (instat, outstat)) { /* We know the files are distinct. */ @@ -2468,11 +2451,7 @@ but lacks following character offset")); while ((cc = fread (buf, 1, sizeof buf, in_fp)) > 0) write_bytes (buf, cc, out_fp, tmp); if (ferror (in_fp)) - { - error (0, errno, "%s", files[i]); - cleanup (); - exit (SORT_FAILURE); - } + die (files[i]); xfclose (out_fp, tmp); xfclose (in_fp, files[i]); files[i] = tmp; @@ -2492,11 +2471,7 @@ but lacks following character offset")); if (STREQ (files[i], "-")) continue; if (stat (files[i], &sb)) - { - error (0, errno, "%s", files[i]); - cleanup (); - exit (SORT_FAILURE); - } + die (files[i]); } ofp = xfopen (outfile, "w"); @@ -2511,13 +2486,13 @@ but lacks following character offset")); merge (files, nfiles, ofp, outfile); else sort (files, nfiles, ofp, outfile); - cleanup (); if (fclose (ofp) != 0) - error (SORT_FAILURE, errno, _("%s: write error"), outfile); + die (outfile); if (have_read_stdin && fclose (stdin) == EOF) - error (SORT_FAILURE, errno, "-"); + die ("-"); + cleanup (); exit (EXIT_SUCCESS); } |