From 749eef242b8acf1306912ab8f6c473ca3d221699 Mon Sep 17 00:00:00 2001 From: Narayan Desai Date: Wed, 10 Jan 2007 22:40:15 +0000 Subject: Implement negation for bundles, base, pkgmgr, svcmgr, and rules git-svn-id: https://svn.mcs.anl.gov/repos/bcfg/trunk/bcfg2@2643 ce84e21b-d406-0410-9b95-82705330c041 --- src/lib/Server/Plugin.py | 8 ++++++-- 1 file changed, 6 insertions(+), 2 deletions(-) (limited to 'src/lib/Server/Plugin.py') diff --git a/src/lib/Server/Plugin.py b/src/lib/Server/Plugin.py index 8d944e7f8..2f23f76a5 100644 --- a/src/lib/Server/Plugin.py +++ b/src/lib/Server/Plugin.py @@ -187,8 +187,12 @@ class StructFile(XMLFileBacked): and not isinstance(item, lxml.etree._Comment)] for group in [item for item in worklist if item.tag == 'Group']: # if only python had forceable early-binding - newpred = eval("lambda x:'%s' in x.groups and predicate(x)" % (group.get('name')), - {'predicate':predicate}) + if group.get('negate', 'false') == 'true': + cmd = "lambda x:'%s' not in x.groups and predicate(x)" + else: + cmd = "lambda x:'%s' in x.groups and predicate(x)" + + newpred = eval(cmd % (group.get('name')), {'predicate':predicate}) work[newpred] = group.getchildren() def Match(self, metadata): -- cgit v1.2.3-1-g7c22