X-Git-Url: https://mattmccutchen.net/rsync/rsync.git/blobdiff_plain/58d433ab3cbf7dd3010a0944dc579756dfd89ad7..43a481dc5586a16af249fbae611b36442bed6a8c:/io.c diff --git a/io.c b/io.c index 22e5b3db..b7d27e62 100644 --- a/io.c +++ b/io.c @@ -103,7 +103,8 @@ static int readfd(int fd,char *buffer,int N) read_buffer_p += ret; read_buffer_len -= ret; } else { - ret = read(fd,buffer + total,N - total); + if ((ret = read(fd,buffer + total,N - total)) == -1) + return -1; } if (ret <= 0) @@ -116,10 +117,12 @@ static int readfd(int fd,char *buffer,int N) int read_int(int f) { + int ret; char b[4]; - if (readfd(f,b,4) != 4) { + if ((ret=readfd(f,b,4)) != 4) { if (verbose > 1) - fprintf(stderr,"Error reading %d bytes : %s\n",4,strerror(errno)); + fprintf(stderr,"Error reading %d bytes : %s\n", + 4,ret==-1?strerror(errno):"EOF"); exit(1); } total_read += 4; @@ -128,14 +131,22 @@ int read_int(int f) void read_buf(int f,char *buf,int len) { - if (readfd(f,buf,len) != len) { + int ret; + if ((ret=readfd(f,buf,len)) != len) { if (verbose > 1) - fprintf(stderr,"Error reading %d bytes : %s\n",len,strerror(errno)); + fprintf(stderr,"Error reading %d bytes : %s\n", + len,ret==-1?strerror(errno):"EOF"); exit(1); } total_read += len; } +unsigned char read_byte(int f) +{ + char c; + read_buf(f,&c,1); + return (unsigned char)c; +} int read_write(int fd_in,int fd_out,int size) { @@ -173,8 +184,8 @@ static int writefd(int fd,char *buf,int len) if (ret == 0) return total; - if (ret == -1 && errno != EWOULDBLOCK) - return total?total:-1; + if (ret == -1 && !(errno == EWOULDBLOCK || errno == EAGAIN)) + return -1; if (ret == -1) { read_check(buffer_f_in); @@ -196,10 +207,12 @@ static int writefd(int fd,char *buf,int len) void write_int(int f,int x) { + int ret; char b[4]; SIVAL(b,0,x); - if (writefd(f,b,4) != 4) { - fprintf(stderr,"write_int failed : %s\n",strerror(errno)); + if ((ret=writefd(f,b,4)) != 4) { + fprintf(stderr,"write_int failed : %s\n", + ret==-1?strerror(errno):"EOF"); exit(1); } total_written += 4; @@ -207,14 +220,21 @@ void write_int(int f,int x) void write_buf(int f,char *buf,int len) { - if (writefd(f,buf,len) != len) { - fprintf(stderr,"write_buf failed : %s\n",strerror(errno)); + int ret; + if ((ret=writefd(f,buf,len)) != len) { + fprintf(stderr,"write_buf failed : %s\n", + ret==-1?strerror(errno):"EOF"); exit(1); } total_written += len; } +void write_byte(int f,unsigned char c) +{ + write_buf(f,(char *)&c,1); +} + void write_flush(int f) { }