diff options
author | landley <landley@69ca8d6d-28ef-0310-b511-8ec308f3f277> | 2005-11-12 11:04:11 +0000 |
---|---|---|
committer | landley <landley@69ca8d6d-28ef-0310-b511-8ec308f3f277> | 2005-11-12 11:04:11 +0000 |
commit | 62dbc2aa2ed6168e4ecb4c4cd4b448c830ea54f6 (patch) | |
tree | 5f3087f3dbcc849b1ed7f881217d08c625fba1c4 /libbb/copyfd.c | |
parent | ec89652278dca2fc7920a151126f877cb4228a7e (diff) | |
download | busybox-w32-62dbc2aa2ed6168e4ecb4c4cd4b448c830ea54f6.tar.gz busybox-w32-62dbc2aa2ed6168e4ecb4c4cd4b448c830ea54f6.tar.bz2 busybox-w32-62dbc2aa2ed6168e4ecb4c4cd4b448c830ea54f6.zip |
My last change to this file broke tar x. Sigh. (Trying to make sure we work
on file sizes between 2 and 4 gigs on 32 bit machines. For supporting >4 gigs,
just use a 64 bit machine already...)
git-svn-id: svn://busybox.net/trunk/busybox@12225 69ca8d6d-28ef-0310-b511-8ec308f3f277
Diffstat (limited to 'libbb/copyfd.c')
-rw-r--r-- | libbb/copyfd.c | 9 |
1 files changed, 5 insertions, 4 deletions
diff --git a/libbb/copyfd.c b/libbb/copyfd.c index c1962e3c6..0b850884b 100644 --- a/libbb/copyfd.c +++ b/libbb/copyfd.c | |||
@@ -29,11 +29,13 @@ static ssize_t bb_full_fd_action(int src_fd, int dst_fd, size_t size) | |||
29 | RESERVE_CONFIG_BUFFER(buffer,BUFSIZ); | 29 | RESERVE_CONFIG_BUFFER(buffer,BUFSIZ); |
30 | 30 | ||
31 | if (src_fd < 0) goto out; | 31 | if (src_fd < 0) goto out; |
32 | |||
33 | while (!size || total < size) | 32 | while (!size || total < size) |
34 | { | 33 | { |
35 | ssize_t wrote, xread = (size && size < BUFSIZ) ? size : BUFSIZ; | 34 | ssize_t wrote, xread; |
36 | xread = safe_read(src_fd, buffer, xread); | 35 | |
36 | xread = safe_read(src_fd, buffer, | ||
37 | (!size || size - total > BUFSIZ) ? BUFSIZ : size - total); | ||
38 | |||
37 | if (xread > 0) { | 39 | if (xread > 0) { |
38 | /* A -1 dst_fd means we need to fake it... */ | 40 | /* A -1 dst_fd means we need to fake it... */ |
39 | wrote = (dst_fd < 0) ? xread : bb_full_write(dst_fd, buffer, xread); | 41 | wrote = (dst_fd < 0) ? xread : bb_full_write(dst_fd, buffer, xread); |
@@ -42,7 +44,6 @@ static ssize_t bb_full_fd_action(int src_fd, int dst_fd, size_t size) | |||
42 | break; | 44 | break; |
43 | } | 45 | } |
44 | total += wrote; | 46 | total += wrote; |
45 | size -= wrote; | ||
46 | } else if (xread < 0) { | 47 | } else if (xread < 0) { |
47 | bb_perror_msg(bb_msg_read_error); | 48 | bb_perror_msg(bb_msg_read_error); |
48 | break; | 49 | break; |