summaryrefslogtreecommitdiffstats
path: root/src/pdmgen.py
diff options
context:
space:
mode:
authorBrad Bishop <bradleyb@fuzziesquirrel.com>2017-05-23 17:58:12 -0400
committerBrad Bishop <bradleyb@fuzziesquirrel.com>2017-06-04 22:40:30 -0400
commit0e7df1317a055fd0a3e15fb46b1e78b6887ee2c8 (patch)
tree015e03140cb2fecc893f6c7a0236898fd928dac8 /src/pdmgen.py
parent05b0c1eef9de3dcd56fd2eee65db9e228231d3f7 (diff)
downloadphosphor-dbus-monitor-0e7df1317a055fd0a3e15fb46b1e78b6887ee2c8.tar.gz
phosphor-dbus-monitor-0e7df1317a055fd0a3e15fb46b1e78b6887ee2c8.zip
Add path and path group support
Add support for defining groups of object paths. Groups are a list of path/metadata tuples. Metadata can be used to give a path context when required. Change-Id: I355ebf76b40f2ffc8d783e94e888b930cde8ee9c Signed-off-by: Brad Bishop <bradleyb@fuzziesquirrel.com>
Diffstat (limited to 'src/pdmgen.py')
-rwxr-xr-xsrc/pdmgen.py76
1 files changed, 76 insertions, 0 deletions
diff --git a/src/pdmgen.py b/src/pdmgen.py
index 711df52..fcda960 100755
--- a/src/pdmgen.py
+++ b/src/pdmgen.py
@@ -121,6 +121,44 @@ class ConfigEntry(NamedElement):
pass
+class Path(ConfigEntry):
+ '''Path/metadata association.'''
+
+ def __init__(self, *a, **kw):
+ super(Path, self).__init__(**kw)
+
+ def factory(self, objs):
+ '''Create path and metadata elements.'''
+
+ args = {
+ 'class': 'pathname',
+ 'pathname': 'element',
+ 'name': self.name['path']
+ }
+ add_unique(ConfigEntry(
+ configfile=self.configfile, **args), objs)
+
+ args = {
+ 'class': 'meta',
+ 'meta': 'element',
+ 'name': self.name['meta']
+ }
+ add_unique(ConfigEntry(
+ configfile=self.configfile, **args), objs)
+
+ super(Path, self).factory(objs)
+
+ def setup(self, objs):
+ '''Resolve path and metadata names to indicies.'''
+
+ self.path = get_index(
+ objs, 'pathname', self.name['path'])
+ self.meta = get_index(
+ objs, 'meta', self.name['meta'])
+
+ super(Path, self).setup(objs)
+
+
class Group(ConfigEntry):
'''Pop the members keyword for groups.'''
@@ -154,6 +192,29 @@ class ImplicitGroup(Group):
super(ImplicitGroup, self).factory(objs)
+class GroupOfPaths(ImplicitGroup):
+ '''Path group config file directive.'''
+
+ def __init__(self, *a, **kw):
+ super(GroupOfPaths, self).__init__(**kw)
+
+ def setup(self, objs):
+ '''Resolve group members.'''
+
+ def map_member(x):
+ path = get_index(
+ objs, 'pathname', x['path'])
+ meta = get_index(
+ objs, 'meta', x['meta'])
+ return (path, meta)
+
+ self.members = map(
+ map_member,
+ self.members)
+
+ super(GroupOfPaths, self).setup(objs)
+
+
class Everything(Renderer):
'''Parse/render entry point.'''
@@ -163,6 +224,12 @@ class Everything(Renderer):
handler methods.'''
class_map = {
+ 'path': {
+ 'element': Path,
+ },
+ 'pathgroup': {
+ 'path': GroupOfPaths,
+ },
}
if cls not in class_map:
@@ -241,6 +308,11 @@ class Everything(Renderer):
return Everything(**objs)
def __init__(self, *a, **kw):
+ self.pathmeta = kw.pop('path', [])
+ self.paths = kw.pop('pathname', [])
+ self.meta = kw.pop('meta', [])
+ self.pathgroups = kw.pop('pathgroup', [])
+
super(Everything, self).__init__(**kw)
def generate_cpp(self, loader):
@@ -250,6 +322,10 @@ class Everything(Renderer):
self.render(
loader,
args.template,
+ meta=self.meta,
+ paths=self.paths,
+ pathmeta=self.pathmeta,
+ pathgroups=self.pathgroups,
indent=Indent()))
if __name__ == '__main__':
OpenPOWER on IntegriCloud