summaryrefslogtreecommitdiffstats
path: root/src
diff options
context:
space:
mode:
authorNarayan Desai <desai@mcs.anl.gov>2004-03-01 22:19:11 +0000
committerNarayan Desai <desai@mcs.anl.gov>2004-03-01 22:19:11 +0000
commit7294aed77c25b8b635c5a1271833493412559726 (patch)
tree6e00bcc5e748e9e3230a0b13ce3633ab9525b009 /src
parent576031311e5f8dd1ec3e49078e62e83221a5b8b7 (diff)
downloadbcfg2-7294aed77c25b8b635c5a1271833493412559726.tar.gz
bcfg2-7294aed77c25b8b635c5a1271833493412559726.tar.bz2
bcfg2-7294aed77c25b8b635c5a1271833493412559726.zip
move to using Generator.__provides__ from __build__
2004/01/20 10:40:13-06:00 anl.gov!desai add datastore usage (Logical change 1.18) git-svn-id: https://svn.mcs.anl.gov/repos/bcfg/trunk/bcfg2@67 ce84e21b-d406-0410-9b95-82705330c041
Diffstat (limited to 'src')
-rw-r--r--src/Core.py17
1 files changed, 12 insertions, 5 deletions
diff --git a/src/Core.py b/src/Core.py
index 698dd64a1..72d79a07d 100644
--- a/src/Core.py
+++ b/src/Core.py
@@ -17,12 +17,14 @@ class PublishedValue(object):
self.value=value
class Core(object):
- def __init__(self, generators):
- self.handles = {}
+ def __init__(self, repository, generators):
+ self.datastore = repository
+ self.provides = {'Service':{},'ConfigFile':{},'Packages':{}}
self.pubspace = {}
self.generators = []
for generator in generators:
- self.generators.append(generator(self))
+ g = getattr(__import__(generator),generator)
+ self.generators.append(g(self, self.datastore))
# we need to inventory and setup generators
# Process generator requirements
for g in self.generators:
@@ -30,8 +32,9 @@ class Core(object):
if not self.pubspace.has_key(prq):
raise GeneratorError, (g.name, prq)
g.CompleteSetup()
- for f in g.__build__.keys():
- self.handles[f] = g
+ for etype in g.__provides__.keys():
+ for entry in g.__provides__[etype]:
+ self.provides[etype][entry] = getattr(g,g.__provides__[etype][entry])
def PublishValue(self,owner,key,value):
if not self.pubspace.has_key(key):
@@ -53,3 +56,7 @@ class Core(object):
if self.handles.has_key(filename):
return self.handles[filename].Build(filename,client)
raise KeyError, filename
+
+ def Get(self,type,name,client):
+ f = self.provides[type][name]
+ return f(name,client)