From 0e39b529b6039e95beea3db4fd2897303a59b781 Mon Sep 17 00:00:00 2001 From: Jim Meyering Date: Sun, 23 May 1999 23:23:55 +0000 Subject: (copy_internal): Don't apply the umask in move_mode. Otherwise, `mv' would not preserve the permissions when copying between partitions. Reported by David Godfrey --- src/copy.c | 8 +++++++- 1 file changed, 7 insertions(+), 1 deletion(-) diff --git a/src/copy.c b/src/copy.c index 1a6694ebb..f1242efea 100644 --- a/src/copy.c +++ b/src/copy.c @@ -896,7 +896,13 @@ copy_internal (const char *src_path, const char *dst_path, else if ((x->preserve_chmod_bits || new_dst) && (x->copy_as_regular || S_ISREG (src_type) || S_ISDIR (src_type))) { - if (chmod (dst_path, src_mode & x->umask_kill)) + mode_t dst_mode = src_mode; + + /* Honor the umask for `cp', but not for `mv'. */ + if (!x->move_mode) + dst_mode &= x->umask_kill; + + if (chmod (dst_path, dst_mode)) { error (0, errno, _("preserving permissions for %s"), dst_path); if (x->require_preserve) -- cgit v1.2.3-70-g09d2