From: Marius Mauch Date: Sun, 28 Sep 2008 17:27:44 +0000 (-0000) Subject: Add operator logic to sets.conf X-Git-Tag: v2.2_rc12~68 X-Git-Url: http://git.tremily.us/?a=commitdiff_plain;h=2f9c5ff0157ec37b2009256b333191c360f57867;p=portage.git Add operator logic to sets.conf svn path=/main/trunk/; revision=11584 --- diff --git a/pym/portage/sets/__init__.py b/pym/portage/sets/__init__.py index 022e31897..28fcf58a5 100644 --- a/pym/portage/sets/__init__.py +++ b/pym/portage/sets/__init__.py @@ -123,14 +123,38 @@ class SetConfig(SafeConfigParser): def getSetAtoms(self, setname, ignorelist=None): myset = self.getSets()[setname] myatoms = myset.getAtoms() + + extend = set() + remove = set() + intersect = set() + if ignorelist is None: ignorelist = set() + if not setname in ignorelist: + if self.has_option(myset.creator, "extend"): + extend.update(self.get(myset.creator, "extend").split()) + if self.has_option(myset.creator, "remove"): + remove.update(self.get(myset.creator, "remove").split()) + if self.has_option(myset.creator, "intersect"): + intersect.update(self.get(myset.creator, "intersect").split()) + ignorelist.add(setname) for n in myset.getNonAtoms(): - if n[0] == SETPREFIX and n[1:] in self.psets: - if n[1:] not in ignorelist: - myatoms.update(self.getSetAtoms(n[1:], - ignorelist=ignorelist)) + if n.startswith(SETPREFIX) and n[len(SETPREFIX):] in self.psets: + extend.add(n[len(SETPREFIX):]) + + for s in ignorelist: + extend.discard(s) + remove.discard(s) + intersect.discard(s) + + for s in extend: + myatoms.update(self.getSetAtoms(s, ignorelist=ignorelist)) + for s in remove: + myatoms.difference_update(self.getSetAtoms(s, ignorelist=None)) + for s in intersect: + myatoms.intersection_update(self.getSetAtoms(s, ignorelist=None)) + return myatoms def load_default_config(settings, trees):