summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorRichard M. Stallman <rms@gnu.org>2005-06-23 21:29:26 +0000
committerRichard M. Stallman <rms@gnu.org>2005-06-23 21:29:26 +0000
commitd550c42590e3d681eb71ceed8d30291f021d318b (patch)
tree65b5fdb3bf5e40e41335e6685e026e2b5a6d3f79
parent7407e52e20de845f3c52b244df7d5fba01101e9b (diff)
downloademacs-d550c42590e3d681eb71ceed8d30291f021d318b.tar.gz
(Frename_file): Preserve owner and group, if possible.
-rw-r--r--src/fileio.c6
1 files changed, 6 insertions, 0 deletions
diff --git a/src/fileio.c b/src/fileio.c
index 537b7f4d10d..6bdc030bc6c 100644
--- a/src/fileio.c
+++ b/src/fileio.c
@@ -2775,6 +2775,7 @@ This is what happens in interactive use with M-x. */)
{
if (errno == EXDEV)
{
+ struct stat data;
#ifdef S_IFLNK
symlink_target = Ffile_symlink_p (file);
if (! NILP (symlink_target))
@@ -2787,6 +2788,11 @@ This is what happens in interactive use with M-x. */)
so don't have copy-file prompt again. */
NILP (ok_if_already_exists) ? Qnil : Qt,
Qt, Qnil);
+
+ /* Preserve owner and group, if possible (if we are root). */
+ if (stat (SDATA (encoded_file), &data) >= 0)
+ chown (SDATA (encoded_file), data.st_uid, data.st_gid);
+
Fdelete_file (file);
}
else