get ACCEPT_KEYWORDS from the env in gvisible() to properly handle negated values...
authorZac Medico <zmedico@gentoo.org>
Sun, 24 Jun 2007 18:33:46 +0000 (18:33 -0000)
committerZac Medico <zmedico@gentoo.org>
Sun, 24 Jun 2007 18:33:46 +0000 (18:33 -0000)
svn path=/main/branches/2.1.2/; revision=6998

pym/portage.py

index 9a5ec82f707c5f24400ec549ab8f4104f4578884..d517fa37c2912c42a1628a090e56c0bf74e97bc8 100644 (file)
@@ -6350,6 +6350,13 @@ class portdbapi(dbapi):
                accept_keywords = self.mysettings["ACCEPT_KEYWORDS"].split()
                pkgdict = self.mysettings.pkeywordsdict
                aux_keys = ["KEYWORDS", "EAPI", "SLOT"]
+
+               # Hack: Need to check the env directly here as otherwise stacking 
+               # doesn't work properly as negative values are lost in the config
+               # object (bug #139600)
+               egroups = self.mysettings.configdict["backupenv"].get(
+                       "ACCEPT_KEYWORDS", "").split()
+
                for mycpv in mylist:
                        try:
                                keys, eapi, slot = self.aux_get(mycpv, aux_keys)
@@ -6371,6 +6378,7 @@ class portdbapi(dbapi):
                                matches = match_to_list(cpv_slot, pkgdict[cp].keys())
                                for atom in matches:
                                        pgroups.extend(pkgdict[cp][atom])
+                               pgroups.extend(egroups)
                                if matches:
                                        inc_pgroups = []
                                        for x in pgroups: