int block_size=BLOCK_SIZE;
char *backup_suffix = BACKUP_SUFFIX;
+char *tmpdir = NULL;
static char *rsync_path = RSYNC_NAME;
extern int csum_length;
int am_server = 0;
-static int sender = 0;
+static int sender;
int recurse = 0;
static void usage(FILE *f);
static void report(int f)
{
- int in,out,tsize;
+ off_t in,out,tsize;
time_t t = time(NULL);
if (!verbose) return;
if (am_server && sender) {
- write_int(f,read_total());
- write_int(f,write_total());
- write_int(f,total_size);
+ write_longint(f,read_total());
+ write_longint(f,write_total());
+ write_longint(f,total_size);
write_flush(f);
return;
}
if (sender) {
in = read_total();
out = write_total();
- tsize = (int)total_size;
+ tsize = total_size;
} else {
- in = read_int(f);
- out = read_int(f);
- tsize = read_int(f);
+ in = read_longint(f);
+ out = read_longint(f);
+ tsize = read_longint(f);
}
- printf("wrote %d bytes read %d bytes %g bytes/sec\n",
- out,in,(in+out)/(0.5 + (t-starttime)));
- printf("total size is %d speedup is %g\n",
- tsize,(1.0*tsize)/(in+out));
+#if HAVE_LONGLONG
+ printf("wrote %lld bytes read %lld bytes %g bytes/sec\n",
+ (long long)out,(long long)in,(in+out)/(0.5 + (t-starttime)));
+ printf("total size is %lld speedup is %g\n",
+ (long long)tsize,(1.0*tsize)/(in+out));
+#else
+ printf("wrote %ld bytes read %ld bytes %g bytes/sec\n",
+ (long)out,(long)in,(in+out)/(0.5 + (t-starttime)));
+ printf("total size is %ld speedup is %g\n",
+ (long)tsize,(1.0*tsize)/(in+out));
+#endif
}
if (numeric_ids)
args[ac++] = "--numeric-ids";
+ if (tmpdir) {
+ args[ac++] = "--temp-dir";
+ args[ac++] = tmpdir;
+ }
+
*argc = ac;
}
}
- if ((pid=fork()) == 0) {
+ if ((pid=do_fork()) == 0) {
recv_files(f_in,flist,local_name,recv_pipe[1]);
if (verbose > 2)
- fprintf(FERROR,"receiver read %d\n",read_total());
+ fprintf(FERROR,"receiver read %ld\n",(long)read_total());
exit_cleanup(0);
}
fprintf(f," --delete delete files that don't exist on the sending side\n");
fprintf(f," --numeric-ids don't map uid/gid values by user/group name\n");
fprintf(f,"-I, --ignore-times don't exclude files that match length and time\n");
+ fprintf(f,"-T --temp-dir DIR create temporary files in directory DIR\n");
fprintf(f,"-z, --compress compress file data\n");
fprintf(f," --exclude FILE exclude file FILE\n");
fprintf(f," --exclude-from FILE exclude files listed in FILE\n");
enum {OPT_VERSION,OPT_SUFFIX,OPT_SENDER,OPT_SERVER,OPT_EXCLUDE,
OPT_EXCLUDE_FROM,OPT_DELETE,OPT_NUMERIC_IDS,OPT_RSYNC_PATH};
-static char *short_options = "oblLWHpguDCtcahvrRIxnSe:B:z";
+static char *short_options = "oblLWHpguDCtcahvrRIxnSe:B:T:z";
static struct option long_options[] = {
{"version", 0, 0, OPT_VERSION},
{"rsh", 1, 0, 'e'},
{"suffix", 1, 0, OPT_SUFFIX},
{"block-size", 1, 0, 'B'},
+ {"temp-dir", 1, 0, 'T'},
{"compress", 0, 0, 'z'},
{0,0,0,0}};
struct file_list *flist;
char *local_name = NULL;
-#ifdef SETPGRP_VOID
- setpgrp();
-#else
- setpgrp(0,0);
-#endif
signal(SIGUSR1, sigusr1_handler);
starttime = time(NULL);
/* we set a 0 umask so that correct file permissions can be
carried across */
- orig_umask = umask(0);
+ orig_umask = (int)umask(0);
while ((opt = getopt_long(argc, argv,
short_options, long_options, &option_index))
block_size = atoi(optarg);
break;
+ case 'T':
+ tmpdir = optarg;
+ break;
+
case 'z':
do_compression = 1;
break;