aboutsummaryrefslogtreecommitdiffstats
path: root/main.c
diff options
context:
space:
mode:
authorWayne Davison <wayned@samba.org>2005-03-29 11:11:35 +0000
committerWayne Davison <wayned@samba.org>2005-03-29 11:11:35 +0000
commit33c4b445ef295f7abe023b208651d450ab2a5c3b (patch)
treec33bae22df5b0b50f25f2fbae60f320210c26ec9 /main.c
parent53135fe89a7688ff3ef6bb26eb4053de82879036 (diff)
downloadandroid_external_rsync-33c4b445ef295f7abe023b208651d450ab2a5c3b.tar.gz
android_external_rsync-33c4b445ef295f7abe023b208651d450ab2a5c3b.tar.bz2
android_external_rsync-33c4b445ef295f7abe023b208651d450ab2a5c3b.zip
Split report() into handle_stats() and output_report() so that (1)
the report happens after all --delete-after activity has ceased when pulling, and (2) a batch-file created when pushing gets the stats values written out prior to any end-of-run keep-alive packets.
Diffstat (limited to 'main.c')
-rw-r--r--main.c36
1 files changed, 24 insertions, 12 deletions
diff --git a/main.c b/main.c
index 81be989a..91f096af 100644
--- a/main.c
+++ b/main.c
@@ -21,8 +21,6 @@
#include "rsync.h"
-time_t starttime = 0;
-
extern int verbose;
extern int dry_run;
extern int list_only;
@@ -77,6 +75,9 @@ struct pid_status {
int status;
} pid_stat_table[MAXCHILDPROCS];
+static time_t starttime, endtime;
+static int64 total_read, total_written;
+
static void show_malloc_stats(void);
/****************************************************************************
@@ -121,12 +122,13 @@ void wait_process(pid_t pid, int *status)
* the report. All processes might also generate a set of debug stats, if
* the verbose level is high enough (this is the only thing that the
* generator process and the server receiver ever do here). */
-static void report(int f)
+static void handle_stats(int f)
{
+ endtime = time(NULL);
+
/* Cache two stats because the read/write code can change it. */
- int64 total_read = stats.total_read;
- int64 total_written = stats.total_written;
- time_t t = time(NULL);
+ total_read = stats.total_read;
+ total_written = stats.total_written;
if (do_stats && verbose > 1) {
/* These come out from every process */
@@ -207,11 +209,17 @@ static void report(int f)
(double)total_read);
}
+ fflush(stdout);
+ fflush(stderr);
+}
+
+static void output_summary(void)
+{
if (verbose || do_stats) {
rprintf(FINFO,
"\nsent %.0f bytes received %.0f bytes %.2f bytes/sec\n",
(double)total_written, (double)total_read,
- (total_written + total_read)/(0.5 + (t - starttime)));
+ (total_written + total_read)/(0.5 + (endtime - starttime)));
rprintf(FINFO, "total size is %.0f speedup is %.2f\n",
(double)stats.total_size,
(double)stats.total_size / (total_written+total_read));
@@ -509,7 +517,7 @@ static void do_server_sender(int f_in, int f_out, int argc,char *argv[])
send_files(flist,f_out,f_in);
io_flush(FULL_FLUSH);
- report(f_out);
+ handle_stats(f_out);
if (protocol_version >= 24)
read_final_goodbye(f_in, f_out);
io_flush(FULL_FLUSH);
@@ -555,7 +563,7 @@ static int do_recv(int f_in,int f_out,struct file_list *flist,char *local_name)
recv_files(f_in, flist, local_name);
io_flush(FULL_FLUSH);
- report(f_in);
+ handle_stats(f_in);
send_msg(MSG_DONE, "", 0);
io_flush(FULL_FLUSH);
@@ -596,7 +604,7 @@ static int do_recv(int f_in,int f_out,struct file_list *flist,char *local_name)
generate_files(f_out, flist, local_name);
- report(-1);
+ handle_stats(-1);
io_flush(FULL_FLUSH);
if (protocol_version >= 24) {
/* send a final goodbye message */
@@ -767,6 +775,7 @@ int client_run(int f_in, int f_out, pid_t pid, int argc, char *argv[])
io_flush(NORMAL_FLUSH);
send_files(flist,f_out,f_in);
io_flush(FULL_FLUSH);
+ handle_stats(-1);
if (protocol_version >= 24)
read_final_goodbye(f_in, f_out);
if (pid != -1) {
@@ -775,8 +784,8 @@ int client_run(int f_in, int f_out, pid_t pid, int argc, char *argv[])
io_flush(FULL_FLUSH);
wait_process(pid, &status);
}
- report(-1);
io_flush(FULL_FLUSH);
+ output_summary();
exit_cleanup(status);
}
@@ -977,8 +986,11 @@ static RETSIGTYPE sigusr1_handler(UNUSED(int val))
static RETSIGTYPE sigusr2_handler(UNUSED(int val))
{
+ if (!am_server)
+ output_summary();
close_all();
- if (log_got_error) _exit(RERR_PARTIAL);
+ if (log_got_error)
+ _exit(RERR_PARTIAL);
_exit(0);
}