X-Git-Url: https://mattmccutchen.net/rsync/rsync.git/blobdiff_plain/40e383765a972e4cbfc4d0091f472542e04e453c..c0dba635ba9d2cf29e39b9363cecc277974d62bb:/flist.c diff --git a/flist.c b/flist.c index aef150d8..57d1596f 100644 --- a/flist.c +++ b/flist.c @@ -1608,7 +1608,7 @@ static void send1extra(int f, struct file_struct *file, struct file_list *flist) if (is_dot_dir) { STRUCT_STAT st; - if (link_stat(fbuf, &st, copy_dirlinks) != 0) { + if (link_stat(fbuf, &st, 1) != 0) { io_error |= IOERR_GENERAL; rsyserr(FERROR, errno, "link_stat %s failed", full_fname(fbuf)); @@ -1905,7 +1905,7 @@ struct file_list *send_file_list(int f, int argc, char *argv[]) if (fn != fbuf) memmove(fbuf, fn, len + 1); - if (link_stat(fbuf, &st, copy_dirlinks) != 0) { + if (link_stat(fbuf, &st, copy_dirlinks || is_dot_dir) != 0) { io_error |= IOERR_GENERAL; rsyserr(FERROR, errno, "link_stat %s failed", full_fname(fbuf)); @@ -2392,6 +2392,8 @@ static void clean_flist(struct file_list *flist, int strip_root) else { if (am_sender) file->flags |= FLAG_DUPLICATE; + else /* Make sure we don't lose vital flags. */ + fp->flags |= file->flags & (FLAG_TOP_DIR|FLAG_XFER_DIR); keep = j, drop = i; } } else @@ -2403,11 +2405,6 @@ static void clean_flist(struct file_list *flist, int strip_root) "removing duplicate name %s from file list (%d)\n", f_name(file, fbuf), drop + flist->ndx_start); } - /* Make sure we don't lose track of a user-specified - * top directory. */ - flist->sorted[keep]->flags |= flist->sorted[drop]->flags - & (FLAG_TOP_DIR|FLAG_XFER_DIR); - clear_file(flist->sorted[drop]); }