aboutsummaryrefslogtreecommitdiff
path: root/libbb/copyfd.c
diff options
context:
space:
mode:
authorlandley <landley@69ca8d6d-28ef-0310-b511-8ec308f3f277>2005-11-12 11:04:11 +0000
committerlandley <landley@69ca8d6d-28ef-0310-b511-8ec308f3f277>2005-11-12 11:04:11 +0000
commit62dbc2aa2ed6168e4ecb4c4cd4b448c830ea54f6 (patch)
tree5f3087f3dbcc849b1ed7f881217d08c625fba1c4 /libbb/copyfd.c
parentec89652278dca2fc7920a151126f877cb4228a7e (diff)
downloadbusybox-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.c9
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;