diff options
| author | Manuel Novoa III <mjn3@codepoet.org> | 2004-05-26 15:21:19 +0000 |
|---|---|---|
| committer | Manuel Novoa III <mjn3@codepoet.org> | 2004-05-26 15:21:19 +0000 |
| commit | d709743b09a456f4550ad0b06dca89dc41a19e60 (patch) | |
| tree | 994819fb891500254f5b5780c384b7cc075c9610 | |
| parent | a6f6a95ba45e094bbee6fd0895925a992e4a29cd (diff) | |
| download | busybox-w32-d709743b09a456f4550ad0b06dca89dc41a19e60.tar.gz busybox-w32-d709743b09a456f4550ad0b06dca89dc41a19e60.tar.bz2 busybox-w32-d709743b09a456f4550ad0b06dca89dc41a19e60.zip | |
If read were to return with an error, bad things would happen. Fix it.
Also, make sure read errors are reflected in the applet exit code.
| -rw-r--r-- | coreutils/tee.c | 8 |
1 files changed, 6 insertions, 2 deletions
diff --git a/coreutils/tee.c b/coreutils/tee.c index 6ec1d6dff..ba2e10f90 100644 --- a/coreutils/tee.c +++ b/coreutils/tee.c | |||
| @@ -38,7 +38,7 @@ int tee_main(int argc, char **argv) | |||
| 38 | int flags; | 38 | int flags; |
| 39 | int retval = EXIT_SUCCESS; | 39 | int retval = EXIT_SUCCESS; |
| 40 | #ifdef CONFIG_FEATURE_TEE_USE_BLOCK_IO | 40 | #ifdef CONFIG_FEATURE_TEE_USE_BLOCK_IO |
| 41 | size_t c; | 41 | ssize_t c; |
| 42 | RESERVE_CONFIG_BUFFER(buf, BUFSIZ); | 42 | RESERVE_CONFIG_BUFFER(buf, BUFSIZ); |
| 43 | #else | 43 | #else |
| 44 | int c; | 44 | int c; |
| @@ -78,12 +78,16 @@ int tee_main(int argc, char **argv) | |||
| 78 | *p = NULL; /* Store the sentinal value. */ | 78 | *p = NULL; /* Store the sentinal value. */ |
| 79 | 79 | ||
| 80 | #ifdef CONFIG_FEATURE_TEE_USE_BLOCK_IO | 80 | #ifdef CONFIG_FEATURE_TEE_USE_BLOCK_IO |
| 81 | while ((c = read(STDIN_FILENO, buf, BUFSIZ)) != 0) { | 81 | while ((c = safe_read(STDIN_FILENO, buf, BUFSIZ)) > 0) { |
| 82 | for (p=files ; *p ; p++) { | 82 | for (p=files ; *p ; p++) { |
| 83 | fwrite(buf, 1, c, *p); | 83 | fwrite(buf, 1, c, *p); |
| 84 | } | 84 | } |
| 85 | } | 85 | } |
| 86 | 86 | ||
| 87 | if (c < 0) { /* Make sure read errors are signaled. */ | ||
| 88 | retval = EXIT_FAILURE; | ||
| 89 | } | ||
| 90 | |||
| 87 | #ifdef CONFIG_FEATURE_CLEAN_UP | 91 | #ifdef CONFIG_FEATURE_CLEAN_UP |
| 88 | RELEASE_CONFIG_BUFFER(buf); | 92 | RELEASE_CONFIG_BUFFER(buf); |
| 89 | #endif | 93 | #endif |
