summaryrefslogtreecommitdiff
path: root/rsync.c
diff options
context:
space:
mode:
authorWayne Davison <wayned@samba.org>2007-11-24 10:50:45 -0800
committerWayne Davison <wayned@samba.org>2007-11-24 10:50:45 -0800
commite107b6b122812d88d531f3826e1a510abe916006 (patch)
tree501799c3301ccce2368e81bffbfc9d68f0984088 /rsync.c
parent5223b786ca62d7b7ffbbd6764083d4d71f6301b9 (diff)
downloadrsync-e107b6b122812d88d531f3826e1a510abe916006.tar.gz
Fixed a problem with --fake-super not getting the fully tweaked new_mode
value. Also fixed the removal of rsync-internal xattr values on the destination files when we aren't copying rsync-internal xattr values.
Diffstat (limited to 'rsync.c')
-rw-r--r--rsync.c8
1 files changed, 4 insertions, 4 deletions
diff --git a/rsync.c b/rsync.c
index c5bcbb5a..ca122561 100644
--- a/rsync.c
+++ b/rsync.c
@@ -371,6 +371,9 @@ int set_file_attrs(const char *fname, struct file_struct *file, stat_x *sxp,
new_mode |= S_ISGID;
}
+ if (daemon_chmod_modes && !S_ISLNK(new_mode))
+ new_mode = tweak_mode(new_mode, daemon_chmod_modes);
+
#ifdef SUPPORT_ACLS
if (preserve_acls && !S_ISLNK(file->mode) && !ACL_READY(*sxp))
get_acl(fname, sxp);
@@ -380,7 +383,7 @@ int set_file_attrs(const char *fname, struct file_struct *file, stat_x *sxp,
if (preserve_xattrs && fnamecmp)
set_xattr(fname, file, fnamecmp, sxp);
if (am_root < 0)
- set_stat_xattr(fname, file);
+ set_stat_xattr(fname, file, new_mode);
#endif
if (!preserve_times || (S_ISDIR(sxp->st.st_mode) && preserve_times == 1))
@@ -440,9 +443,6 @@ int set_file_attrs(const char *fname, struct file_struct *file, stat_x *sxp,
updated = 1;
}
- if (daemon_chmod_modes && !S_ISLNK(new_mode))
- new_mode = tweak_mode(new_mode, daemon_chmod_modes);
-
#ifdef SUPPORT_ACLS
/* It's OK to call set_acl() now, even for a dir, as the generator
* will enable owner-writability using chmod, if necessary.