From ddc642bf85f84ecc8c2fa74472870f313ab94912 Mon Sep 17 00:00:00 2001 From: Zac Medico Date: Thu, 12 Mar 2009 03:48:10 +0000 Subject: When translating portage uid/gid to root uid/gid after src_install on FreeBSD, temporarily remove all file flags inside $D in order to avoid EPERM errors. Thanks to Timothy Redaelli for reporting. svn path=/main/trunk/; revision=13068 --- pym/portage/__init__.py | 17 +++++++++++++++++ 1 file changed, 17 insertions(+) diff --git a/pym/portage/__init__.py b/pym/portage/__init__.py index 1dc81cf59..8c2137f2c 100644 --- a/pym/portage/__init__.py +++ b/pym/portage/__init__.py @@ -4884,6 +4884,17 @@ def _post_src_install_uid_fix(mysettings): """ inst_uid = int(mysettings["PORTAGE_INST_UID"]) inst_gid = int(mysettings["PORTAGE_INST_GID"]) + + if bsd_chflags: + # Temporarily remove all of the flags in order to avoid EPERM errors. + os.system("mtree -c -p %s -k flags > %s" % \ + (_shell_quote(mysettings["D"]), + _shell_quote(os.path.join(mysettings["T"], "bsdflags.mtree")))) + os.system("chflags -R noschg,nouchg,nosappnd,nouappnd %s" % \ + (_shell_quote(mysettings["D"]),)) + os.system("chflags -R nosunlnk,nouunlnk %s 2>/dev/null" % \ + (_shell_quote(mysettings["D"]),)) + for parent, dirs, files in os.walk(mysettings["D"]): for fname in chain(dirs, files): fpath = os.path.join(parent, fname) @@ -4901,6 +4912,12 @@ def _post_src_install_uid_fix(mysettings): mode=mystat.st_mode, stat_cached=mystat, follow_links=False) + if bsd_chflags: + # Restore all of the flags saved above. + os.system("mtree -e -p %s -U -k flags < %s > /dev/null" % \ + (_shell_quote(mysettings["D"]), + _shell_quote(os.path.join(mysettings["T"], "bsdflags.mtree")))) + def _post_pkg_preinst_cmd(mysettings): """ Post phase logic and tasks that have been factored out of -- cgit v1.2.3-1-g7c22