#
-# Thierry Parmentelat - INRIA Sophia Antipolis
+# Thierry Parmentelat <thierry.parmentelat@inria.fr>
+# Copyright (C) 2010 INRIA
+#
#
# mapper class
#
@staticmethod
def node_name (node):
- return node['node_fields']['hostname']
+ return node['name']
+
+ def node_names (self):
+ result=[]
+ for plc in self.plcs:
+ for site in plc['sites']:
+ for node in site['nodes']:
+ result.append(node['name'])
+ return result
def apply_first_map (self, type, name, obj, maplist):
for (map_pattern,rename_dict) in maplist:
if utils.match (name,map_pattern):
- utils.header("TestMapper/%s : applying rules '%s' on %s"%(type,map_pattern,name))
+ if self.options.verbose:
+ utils.header("TestMapper/%s : applying rules '%s' on %s"%(type,map_pattern,name))
for (k,v) in rename_dict.iteritems():
# apply : separator
path=k.split(':')
for step in path[:-1]:
if not o.has_key(step):
o[step]={}
- utils.header ("WARNING : created step %s in path %s on %s %s"%(
- step,path,type,name))
+ if self.options.verbose:
+ utils.header ("WARNING : created step %s in path %s on %s %s"%(
+ step,path,type,name))
o=o[step]
# last step is the one for side-effect
step=path[-1]
- if not o.has_key(step):
- utils.header ("WARNING : inserting key %s for path %s on %s %s"%(
- step,path,type,name))
+ if self.options.verbose:
+ if not o.has_key(step):
+ utils.header ("WARNING : inserting key %s for path %s on %s %s"%(
+ step,path,type,name))
# apply formatting if '%s' found in the value
if v.find('%s')>=0:
v=v%obj[k]
- print("TestMapper, rewriting %s: %s into %s"%(name,k,v))
+ if self.options.verbose:
+ print("TestMapper, rewriting %s: %s into %s"%(name,k,v))
o[step]=v
# only apply first rule
return
- def node_names (self):
- result=[]
- for plc in self.plcs:
- for site in plc['sites']:
- for node in site['nodes']:
- result.append(node['node_fields']['hostname'])
- return result
-
def map (self,mapper):
- try:
- plc_maps = mapper['plc']
- except:
- plc_maps = []
- try:
- node_maps = mapper['node']
- except:
- node_maps = []
+ plc_maps = mapper.get('plc',[])
+ node_maps = mapper.get('node',[])
for plc in self.plcs:
name=TestMapper.plc_name(plc)