diff options
author | Paul Eggert <eggert@cs.ucla.edu> | 2010-12-23 00:07:35 -0800 |
---|---|---|
committer | Paul Eggert <eggert@cs.ucla.edu> | 2010-12-23 00:07:59 -0800 |
commit | bc4e77927c6610d856bec90a60da931e33d3abbb (patch) | |
tree | b2f2c77b8e60149b1aa897d2ef7b11a69e91def5 | |
parent | 1d0a1203777bf8478822e6dfb64cd49368a4d588 (diff) | |
download | coreutils-bc4e77927c6610d856bec90a60da931e33d3abbb.tar.xz |
csplit: diagnose file counter wraparound
* src/csplit.c (create_output_file): Detect overflow when the
file counter wraps around, and exit with a diagnostic. Formerly
the code silently wrapped around and wrote to the wrong file,
losing output data.
-rw-r--r-- | src/csplit.c | 24 |
1 files changed, 16 insertions, 8 deletions
diff --git a/src/csplit.c b/src/csplit.c index 07c5c8c57..9629750c9 100644 --- a/src/csplit.c +++ b/src/csplit.c @@ -917,19 +917,27 @@ make_filename (unsigned int num) static void create_output_file (void) { - sigset_t oldset; bool fopen_ok; int fopen_errno; output_filename = make_filename (files_created); - /* Create the output file in a critical section, to avoid races. */ - sigprocmask (SIG_BLOCK, &caught_signals, &oldset); - output_stream = fopen (output_filename, "w"); - fopen_ok = (output_stream != NULL); - fopen_errno = errno; - files_created += fopen_ok; - sigprocmask (SIG_SETMASK, &oldset, NULL); + if (files_created == UINT_MAX) + { + fopen_ok = false; + fopen_errno = EOVERFLOW; + } + else + { + /* Create the output file in a critical section, to avoid races. */ + sigset_t oldset; + sigprocmask (SIG_BLOCK, &caught_signals, &oldset); + output_stream = fopen (output_filename, "w"); + fopen_ok = (output_stream != NULL); + fopen_errno = errno; + files_created += fopen_ok; + sigprocmask (SIG_SETMASK, &oldset, NULL); + } if (! fopen_ok) { |