+
+ /* this is the client */
+
+ if (!am_sender && verbose) {
+ /* note that if (!verbose && do_stats) then these values will
+ be taken from the receiver side's copy. The total size
+ is identical but the bytes read and written are slightly
+ different. It's done this way to avoid modifying the
+ protocol to support --stats without -v. */
+ stats.total_written = read_longint(f);
+ stats.total_read = read_longint(f);
+ stats.total_size = read_longint(f);
+
+ /* when the total_read was set above just now it would not
+ have included the last two longints, but the last
+ read_longint would have compensated for one of them.
+ Compensate for the other one too by adding 8. */
+ stats.total_read += sizeof(int64);
+ }
+
+ if (do_stats) {
+ rprintf(FINFO,"\nNumber of files: %d\n", stats.num_files);
+ rprintf(FINFO,"Number of files transferred: %d\n",
+ stats.num_transferred_files);
+ rprintf(FINFO,"Total file size: %.0f bytes\n",
+ (double)stats.total_size);
+ rprintf(FINFO,"Total transferred file size: %.0f bytes\n",
+ (double)stats.total_transferred_size);
+ rprintf(FINFO,"Literal data: %.0f bytes\n",
+ (double)stats.literal_data);
+ rprintf(FINFO,"Matched data: %.0f bytes\n",
+ (double)stats.matched_data);
+ rprintf(FINFO,"File list size: %d\n", stats.flist_size);
+ rprintf(FINFO,"Total bytes written: %.0f\n",
+ (double)stats.total_written);
+ rprintf(FINFO,"Total bytes read: %.0f\n\n",
+ (double)stats.total_read);