From: Zac Medico Date: Wed, 2 Aug 2006 03:01:41 +0000 (-0000) Subject: Remove duplicate profile.env values from the environment so that they don't override... X-Git-Tag: v2.1.1~115 X-Git-Url: http://git.tremily.us/?a=commitdiff_plain;h=bcd106c2f2505345ed6e07c4a70390a084fa934b;p=portage.git Remove duplicate profile.env values from the environment so that they don't override updated profile.env values later (profile.env is reloaded in each call to self.regenerate). See bug #51370. svn path=/main/trunk/; revision=4083 --- diff --git a/pym/portage.py b/pym/portage.py index 5dae56416..dc4ea15df 100644 --- a/pym/portage.py +++ b/pym/portage.py @@ -1019,6 +1019,24 @@ class config: pass del blacklisted, cfg + env_d = getconfig( + os.path.join(config_root, "etc", "profile.env")) + # env_d will be None if profile.env doesn't exist. + if env_d: + self.configdict["env.d"].update(env_d) + # Remove duplicate values so they don't override updated + # profile.env values later (profile.env is reloaded in each + # call to self.regenerate). + for cfg in (self.configdict["backupenv"], + self.configdict["env"]): + for k, v in env_d.iteritems(): + try: + if cfg[k] == v: + del cfg[k] + except KeyError: + pass + del cfg, k, v + self["PORTAGE_CONFIGROOT"] = config_root self.backup_changes("PORTAGE_CONFIGROOT") self["ROOT"] = target_root