summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--NEWS3
-rw-r--r--src/chown-core.c36
2 files changed, 27 insertions, 12 deletions
diff --git a/NEWS b/NEWS
index 2a3f8601a..007db10b0 100644
--- a/NEWS
+++ b/NEWS
@@ -16,7 +16,8 @@ GNU coreutils NEWS -*- outline -*-
** Changes in behavior
- chmod -v and -c now output the original mode in the messages.
+ chmod, chown and chgrp now output the original attributes in messages,
+ when -v or -c specified.
** New features
diff --git a/src/chown-core.c b/src/chown-core.c
index e72aa33b1..55f8a2d36 100644
--- a/src/chown-core.c
+++ b/src/chown-core.c
@@ -107,7 +107,7 @@ uid_to_name (uid_t uid)
static char *
user_group_str (char const *user, char const *group)
{
- char *spec;
+ char *spec = NULL;
if (user)
{
@@ -121,7 +121,7 @@ user_group_str (char const *user, char const *group)
spec = xstrdup (user);
}
}
- else
+ else if (group)
{
spec = xstrdup (group);
}
@@ -139,6 +139,7 @@ describe_change (const char *file, enum Change_status changed,
char const *user, char const *group)
{
const char *fmt;
+ char *old_spec;
char *spec;
if (changed == CH_NOT_APPLIED)
@@ -148,32 +149,45 @@ describe_change (const char *file, enum Change_status changed,
return;
}
+ spec = user_group_str (user, group);
+ old_spec = user_group_str (user ? old_user : NULL, group ? old_group : NULL);
+
switch (changed)
{
case CH_SUCCEEDED:
- fmt = (user ? _("changed ownership of %s to %s\n")
- : group ? _("changed group of %s to %s\n")
+ fmt = (user ? _("changed ownership of %s from %s to %s\n")
+ : group ? _("changed group of %s from %s to %s\n")
: _("no change to ownership of %s\n"));
- spec = user_group_str (user, group);
break;
case CH_FAILED:
- fmt = (user ? _("failed to change ownership of %s to %s\n")
- : group ? _("failed to change group of %s to %s\n")
- : _("failed to change ownership of %s\n"));
- spec = user_group_str (user, group);
+ if (old_spec)
+ {
+ fmt = (user ? _("failed to change ownership of %s from %s to %s\n")
+ : group ? _("failed to change group of %s from %s to %s\n")
+ : _("failed to change ownership of %s\n"));
+ }
+ else
+ {
+ fmt = (user ? _("failed to change ownership of %s to %s\n")
+ : group ? _("failed to change group of %s to %s\n")
+ : _("failed to change ownership of %s\n"));
+ free (old_spec);
+ old_spec = spec;
+ spec = NULL;
+ }
break;
case CH_NO_CHANGE_REQUESTED:
fmt = (user ? _("ownership of %s retained as %s\n")
: group ? _("group of %s retained as %s\n")
: _("ownership of %s retained\n"));
- spec = user_group_str (user ? old_user : NULL, group ? old_group : NULL);
break;
default:
abort ();
}
- printf (fmt, quote (file), spec);
+ printf (fmt, quote (file), old_spec, spec);
+ free (old_spec);
free (spec);
}