a76d6c30a2
Copy from Base:System/rpm based on submit request 18841 from user mlschroe OBS-URL: https://build.opensuse.org/request/show/18841 OBS-URL: https://build.opensuse.org/package/show/openSUSE:Factory/rpm?expand=0&rev=84
29 lines
1.0 KiB
Diff
29 lines
1.0 KiB
Diff
Warn the user if chown/fchown fails.
|
|
|
|
Index: lib/fsm.c
|
|
===================================================================
|
|
--- lib/fsm.c.orig
|
|
+++ lib/fsm.c
|
|
@@ -2093,6 +2093,10 @@ if (!(fsm->mapFlags & CPIO_ALL_HARDLINKS
|
|
break;
|
|
case FSM_CHOWN:
|
|
rc = chown(fsm->path, st->st_uid, st->st_gid);
|
|
+ if (rc < 0 && errno == EPERM) {
|
|
+ rpmlog(RPMLOG_WARNING, "can't chown %s (%s)\n", fsm->path, strerror(errno));
|
|
+ rc = 0;
|
|
+ }
|
|
if (_fsm_debug && (stage & FSM_SYSCALL))
|
|
rpmlog(RPMLOG_DEBUG, " %8s (%s, %d, %d) %s\n", cur,
|
|
fsm->path, (int)st->st_uid, (int)st->st_gid,
|
|
@@ -2102,6 +2106,10 @@ if (!(fsm->mapFlags & CPIO_ALL_HARDLINKS
|
|
case FSM_LCHOWN:
|
|
#if ! CHOWN_FOLLOWS_SYMLINK
|
|
rc = lchown(fsm->path, st->st_uid, st->st_gid);
|
|
+ if (rc < 0 && errno == EPERM) {
|
|
+ rpmlog(RPMLOG_WARNING, "can't lchown %s (%s)\n", fsm->path, strerror(errno));
|
|
+ rc = 0;
|
|
+ }
|
|
if (_fsm_debug && (stage & FSM_SYSCALL))
|
|
rpmlog(RPMLOG_DEBUG, " %8s (%s, %d, %d) %s\n", cur,
|
|
fsm->path, (int)st->st_uid, (int)st->st_gid,
|