From 53f6c0a332acd00a7da06fe30f560357d3cf6f72 Mon Sep 17 00:00:00 2001 From: Zac Medico Date: Tue, 17 Mar 2009 19:13:22 +0000 Subject: [PATCH] Do not create hardlinks when merging CONFIG_PROTECTed files since config files shouldn't be hardlinked to eachother (for example, shadow installs several identical config files inside /etc/pam.d/). Thanks to Caleb Cushing for reporting. (trunk r13115) svn path=/main/branches/2.1.6/; revision=13122 --- pym/portage/dbapi/vartree.py | 22 +++++++++++++++------- 1 file changed, 15 insertions(+), 7 deletions(-) diff --git a/pym/portage/dbapi/vartree.py b/pym/portage/dbapi/vartree.py index 399aa2791..f106e5f56 100644 --- a/pym/portage/dbapi/vartree.py +++ b/pym/portage/dbapi/vartree.py @@ -2706,6 +2706,7 @@ class dblink(object): moveme = 1 zing = "!!!" mymtime = None + protected = self.isprotected(mydest) if mydmode != None: # destination file exists if stat.S_ISDIR(mydmode): @@ -2719,7 +2720,7 @@ class dblink(object): # or by a symlink to an existing regular file; # now, config file management may come into play. # we only need to tweak mydest if cfg file management is in play. - if self.isprotected(mydest): + if protected: # we have a protection path; enable config file management. destmd5 = perform_md5(mydest, calc_prelink=1) if mymd5 == destmd5: @@ -2756,21 +2757,28 @@ class dblink(object): # extract a tarball of the resulting hardlinks due to # 'Invalid cross-device link' errors (depends on layout of # mount points). Also, don't hardlink zero-byte files since - # it doesn't save any space. + # it doesn't save any space, and don't hardlink + # CONFIG_PROTECTed files since config files shouldn't be + # hardlinked to eachother (for example, shadow installs + # several identical config files inside /etc/pam.d/). parent_dir = os.path.dirname(myrealdest) hardlink_key = (parent_dir, mymd5, mystat.st_size, mystat.st_mode, mystat.st_uid, mystat.st_gid) - hardlink_candidates = self._md5_merge_map.get(hardlink_key) - if hardlink_candidates is None: - hardlink_candidates = [] - if mystat.st_size != 0: + + hardlink_candidates = None + if not protected and mystat.st_size != 0: + hardlink_candidates = self._md5_merge_map.get(hardlink_key) + if hardlink_candidates is None: + hardlink_candidates = [] self._md5_merge_map[hardlink_key] = hardlink_candidates + mymtime = movefile(mysrc, mydest, newmtime=thismtime, sstat=mystat, mysettings=self.settings, hardlink_candidates=hardlink_candidates) if mymtime is None: return 1 - hardlink_candidates.append(mydest) + if hardlink_candidates is not None: + hardlink_candidates.append(mydest) zing = ">>>" if mymtime != None: -- 2.26.2