X-Git-Url: https://mattmccutchen.net/rsync/rsync.git/blobdiff_plain/f855a7d01ab8401a307bb02cdcdee546df3e2423..7e0ca8e2f0945b8c1b99c88a0283068a3adb19e4:/generator.c diff --git a/generator.c b/generator.c index bbc328df..9bf0e959 100644 --- a/generator.c +++ b/generator.c @@ -177,6 +177,7 @@ void recv_generator(char *fname,struct file_list *flist,int i,int f_out) char fnamecmpbuf[MAXPATHLEN]; extern char *compare_dest; extern int list_only; + extern int preserve_perms; if (list_only) return; @@ -185,6 +186,15 @@ void recv_generator(char *fname,struct file_list *flist,int i,int f_out) statret = link_stat(fname,&st); + if (statret == 0 && + !preserve_perms && + (S_ISDIR(st.st_mode) == S_ISDIR(file->mode))) { + /* if the file exists already and we aren't perserving + presmissions then act as though the remote end sent + us the file permissions we already have */ + file->mode = (file->mode & _S_IFMT) | (st.st_mode & ~_S_IFMT); + } + if (S_ISDIR(file->mode)) { if (dry_run) return; if (statret == 0 && !S_ISDIR(st.st_mode)) { @@ -340,7 +350,7 @@ void recv_generator(char *fname,struct file_list *flist,int i,int f_out) } /* open the file */ - fd = open(fnamecmp,O_RDONLY); + fd = do_open(fnamecmp, O_RDONLY, 0); if (fd == -1) { rprintf(FERROR,"failed to open %s : %s\n",fnamecmp,strerror(errno));