t = time(NULL);
if (last_io && io_timeout && (t-last_io)>io_timeout) {
- fprintf(FERROR,"read timeout after %d second - exiting\n",
+ rprintf(FERROR,"read timeout after %d second - exiting\n",
(int)(t-last_io));
exit_cleanup(1);
}
}
-int read_int(int f)
+int32 read_int(int f)
{
int ret;
char b[4];
if ((ret=readfd(f,b,4)) != 4) {
if (verbose > 1)
- fprintf(FERROR,"(%d) Error reading %d bytes : %s\n",
+ rprintf(FERROR,"(%d) Error reading %d bytes : %s\n",
getpid(),4,ret==-1?strerror(errno):"EOF");
exit_cleanup(1);
}
char b[8];
ret = read_int(f);
- if (ret != -1) return ret;
+ if ((int32)ret != (int32)0xffffffff) return ret;
-#ifndef HAVE_LONGLONG
- fprintf(FERROR,"Integer overflow - attempted 64 bit offset\n");
+#ifdef NO_INT64
+ rprintf(FERROR,"Integer overflow - attempted 64 bit offset\n");
exit_cleanup(1);
#else
if (remote_version >= 16) {
if ((ret=readfd(f,b,8)) != 8) {
if (verbose > 1)
- fprintf(FERROR,"(%d) Error reading %d bytes : %s\n",
+ rprintf(FERROR,"(%d) Error reading %d bytes : %s\n",
getpid(),8,ret==-1?strerror(errno):"EOF");
exit_cleanup(1);
}
int ret;
if ((ret=readfd(f,buf,len)) != len) {
if (verbose > 1)
- fprintf(FERROR,"(%d) Error reading %d bytes : %s\n",
+ rprintf(FERROR,"(%d) Error reading %d bytes : %s\n",
getpid(),len,ret==-1?strerror(errno):"EOF");
exit_cleanup(1);
}
int sparse_end(int f)
{
if (last_sparse) {
- lseek(f,-1,SEEK_CUR);
+ do_lseek(f,-1,SEEK_CUR);
return (write(f,&last_byte,1) == 1 ? 0 : -1);
}
last_sparse = 0;
last_sparse=1;
if (l1 > 0)
- lseek(f,l1,SEEK_CUR);
+ do_lseek(f,l1,SEEK_CUR);
if (l1 == len)
return len;
}
if (l2 > 0)
- lseek(f,l2,SEEK_CUR);
+ do_lseek(f,l2,SEEK_CUR);
return len;
}
systems it seems (eg. IRIX) */
u_sleep(1000);
#if 0
- fprintf(FERROR,"write exception\n");
+ rprintf(FERROR,"write exception\n");
exit_cleanup(1);
#endif
}
&w_fds,NULL,&tv);
if (count == -1 && errno != EINTR) {
if (verbose > 1)
- fprintf(FERROR,"select error: %s\n", strerror(errno));
+ rprintf(FERROR,"select error: %s\n", strerror(errno));
exit_cleanup(1);
}
-void write_int(int f,int x)
+void write_int(int f,int32 x)
{
int ret;
char b[4];
SIVAL(b,0,x);
if ((ret=writefd(f,b,4)) != 4) {
- fprintf(FERROR,"write_int failed : %s\n",
+ rprintf(FERROR,"write_int failed : %s\n",
ret==-1?strerror(errno):"EOF");
exit_cleanup(1);
}
SIVAL(b,4,((x>>32)&0xFFFFFFFF));
if ((ret=writefd(f,b,8)) != 8) {
- fprintf(FERROR,"write_longint failed : %s\n",
+ rprintf(FERROR,"write_longint failed : %s\n",
ret==-1?strerror(errno):"EOF");
exit_cleanup(1);
}
{
int ret;
if ((ret=writefd(f,buf,len)) != len) {
- fprintf(FERROR,"write_buf failed : %s\n",
+ rprintf(FERROR,"write_buf failed : %s\n",
ret==-1?strerror(errno):"EOF");
exit_cleanup(1);
}