X-Git-Url: https://mattmccutchen.net/rsync/rsync.git/blobdiff_plain/06ce139fcc8c843fdfe7d030cba0e1215287d181..6aaf8d8c1041b524d985bf09b9a3f5e371cf8ac2:/io.c diff --git a/io.c b/io.c index 9c4ac19d..1d406490 100644 --- a/io.c +++ b/io.c @@ -19,11 +19,22 @@ Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA. */ -/* - socket and pipe IO utilities used in rsync +/** + * + * @file io.c + * + * Socket and pipe IO utilities used in rsync. + * + * rsync provides its own multiplexing system, which is used to send + * stderr and stdout over a single socket. We need this because + * stdout normally carries the binary data stream, and stderr all our + * error messages. + * + * For historical reasons this is off during the start of the + * connection, but it's switched on quite early using + * io_start_multiplex_out() and io_start_multiplex_in(). + **/ - tridge, June 1996 - */ #include "rsync.h" /* if no timeout is specified then use a 60 second select timeout */ @@ -377,7 +388,8 @@ unsigned char read_byte(int f) return c; } -/* write len bytes to fd */ +/* Write len bytes to fd. This underlies the multiplexing system, + * which is always called by application code. */ static void writefd_unbuffered(int fd,char *buf,size_t len) { size_t total = 0; @@ -442,8 +454,11 @@ static void writefd_unbuffered(int fd,char *buf,size_t len) } if (ret <= 0) { - rprintf(FERROR, - "error writing %d unbuffered bytes" + /* Don't try to write errors back + * across the stream */ + io_multiplexing_close(); + rprintf(FERROR, RSYNC_NAME + ": error writing %d unbuffered bytes" " - exiting: %s\n", len, strerror(errno)); exit_cleanup(RERR_STREAMIO); @@ -527,8 +542,7 @@ void io_flush(void) } -/* XXX: fd is ignored, which seems a little strange. */ -void io_end_buffering(int fd) +void io_end_buffering(void) { io_flush(); if (!io_multiplexing_out) { @@ -549,7 +563,7 @@ static void writefd(int fd,char *buf,size_t len) } while (len) { - int n = MIN(len, IO_BUFFER_SIZE-io_buffer_count); + int n = MIN((int) len, IO_BUFFER_SIZE-io_buffer_count); if (n > 0) { memcpy(io_buffer+io_buffer_count, buf, n); buf += n;