diff options
author | Pádraig Brady <P@draigBrady.com> | 2010-10-07 13:12:36 +0100 |
---|---|---|
committer | Pádraig Brady <P@draigBrady.com> | 2010-10-07 20:08:16 +0100 |
commit | 758916b49e69836fcbd1e861e19edfced44e28ea (patch) | |
tree | f1f3f1b4117e9efb4ea1f27bb1e9a0b5e4453579 /src | |
parent | 6483f0e1bd4ae5b5b300512c96cc3028d643a58c (diff) | |
download | coreutils-758916b49e69836fcbd1e861e19edfced44e28ea.tar.xz |
split: fix reporting of read errors
The bug was introduced with commit 23f6d41f, 19-02-2003.
* src/split.c (bytes_split, lines_split, line_bytes_split):
Correctly check the return from full_read().
* tests/misc/split-fail: Ensure split fails when
it can't read its input.
* NEWS: Mention the fix.
Diffstat (limited to 'src')
-rw-r--r-- | src/split.c | 11 |
1 files changed, 5 insertions, 6 deletions
diff --git a/src/split.c b/src/split.c index 5be720795..61ae265d8 100644 --- a/src/split.c +++ b/src/split.c @@ -33,7 +33,6 @@ #include "full-read.h" #include "full-write.h" #include "quote.h" -#include "safe-read.h" #include "xfreopen.h" #include "xstrtol.h" @@ -229,7 +228,7 @@ bytes_split (uintmax_t n_bytes, char *buf, size_t bufsize) do { n_read = full_read (STDIN_FILENO, buf, bufsize); - if (n_read == SAFE_READ_ERROR) + if (n_read < bufsize && errno) error (EXIT_FAILURE, errno, "%s", infile); bp_out = buf; to_read = n_read; @@ -273,7 +272,7 @@ lines_split (uintmax_t n_lines, char *buf, size_t bufsize) do { n_read = full_read (STDIN_FILENO, buf, bufsize); - if (n_read == SAFE_READ_ERROR) + if (n_read < bufsize && errno) error (EXIT_FAILURE, errno, "%s", infile); bp = bp_out = buf; eob = bp + n_read; @@ -314,7 +313,6 @@ lines_split (uintmax_t n_lines, char *buf, size_t bufsize) static void line_bytes_split (size_t n_bytes) { - size_t n_read; char *bp; bool eof = false; size_t n_buffered = 0; @@ -324,8 +322,9 @@ line_bytes_split (size_t n_bytes) { /* Fill up the full buffer size from the input file. */ - n_read = full_read (STDIN_FILENO, buf + n_buffered, n_bytes - n_buffered); - if (n_read == SAFE_READ_ERROR) + size_t to_read = n_bytes - n_buffered; + size_t n_read = full_read (STDIN_FILENO, buf + n_buffered, to_read); + if (n_read < to_read && errno) error (EXIT_FAILURE, errno, "%s", infile); n_buffered += n_read; |