X-Git-Url: https://mattmccutchen.net/rsync/rsync.git/blobdiff_plain/2b7e0f33a67ba8f9de069280b1bd5d1f9053d595..97b7bff4d654d9fc679b823d5550ccd9b8a312ad:/flist.c diff --git a/flist.c b/flist.c index 1bc25bc2..8f26f03c 100644 --- a/flist.c +++ b/flist.c @@ -68,6 +68,7 @@ extern struct filter_list_struct filter_list; extern struct filter_list_struct server_filter_list; int io_error; +int checksum_len; dev_t filesystem_dev; /* used to implement -x */ static char empty_sum[MD4_SUM_LENGTH]; @@ -84,6 +85,7 @@ void init_flist(void) /* Figure out how big the file_struct is without trailing padding */ file_struct_len = offsetof(struct file_struct, flags) + sizeof f.flags; + checksum_len = protocol_version < 21 ? 2 : MD4_SUM_LENGTH; } static int show_filelist_p(void) @@ -475,14 +477,13 @@ void send_file_entry(struct file_struct *file, int f, unsigned short base_flags) if (always_checksum && (S_ISREG(mode) || protocol_version < 28)) { char *sum; - int slen = protocol_version < 21 ? 2 : MD4_SUM_LENGTH; if (S_ISREG(mode)) sum = file->u.sum; else { /* Prior to 28, we sent a useless set of nulls. */ sum = empty_sum; } - write_buf(f, sum, slen); + write_buf(f, sum, checksum_len); } strlcpy(lastname, fname, MAXPATHLEN); @@ -698,7 +699,6 @@ static struct file_struct *receive_file_entry(struct file_list *flist, if (always_checksum && (sum_len || protocol_version < 28)) { char *sum; - int slen = protocol_version < 21 ? 2 : MD4_SUM_LENGTH; if (sum_len) { file->u.sum = sum = bp; /*bp += sum_len;*/ @@ -706,7 +706,7 @@ static struct file_struct *receive_file_entry(struct file_list *flist, /* Prior to 28, we get a useless set of nulls. */ sum = empty_sum; } - read_buf(f, sum, slen); + read_buf(f, sum, checksum_len); } if (!preserve_perms) { @@ -820,7 +820,7 @@ struct file_struct *make_file(char *fname, struct file_list *flist, return NULL; } -skip_filters: + skip_filters: if (verbose > 2) { rprintf(FINFO, "[%s] make_file(%s,*,%d)\n", @@ -848,7 +848,8 @@ skip_filters: linkname_len = 0; #endif - sum_len = always_checksum && S_ISREG(st.st_mode) ? MD4_SUM_LENGTH : 0; + sum_len = always_checksum && am_sender && S_ISREG(st.st_mode) + ? MD4_SUM_LENGTH : 0; alloc_len = file_struct_len + dirname_len + basename_len + linkname_len + sum_len; @@ -1313,7 +1314,6 @@ struct file_list *recv_file_list(int f) if (!flist->files) goto oom; - while ((flags = read_byte(f)) != 0) { struct file_struct *file; @@ -1374,7 +1374,7 @@ struct file_list *recv_file_list(int f) return flist; -oom: + oom: out_of_memory("recv_file_list"); return NULL; /* not reached */ }