import re
import sys
+import moe
key_pattern = re.compile("^[A-Za-z0-9_-]+$")
ref_pattern = re.compile("^[A-Za-z0-9_-]+")
-class MoeConfigInvalid(Exception):
+class MoeConfigInvalid(moe.MoeError):
pass
-class MoeConfigEvalErr(Exception):
+class MoeConfigEvalError(moe.MoeError):
pass
class MoeConfig:
k = k[:-1]
if not self.vars.has_key(k):
self.vars[k] = [("a","")];
+ else:
+ self.vars[k] += [("s"," ")]
else:
self.vars[k] = []
if not key_pattern.match(k):
"""Stack of configuration files."""
def __init__(self, base=None):
- ## FIXME: Do we need to duplicate the config files themselves?
if base:
self.stk = base.stk[:]
else:
self.stk = []
self.in_progress = {}
- self.reset_cache()
-
- def reset_cache(self):
- self.cache = {}
def push(self, cfg):
self.stk.append(cfg)
- self.reset_cache()
def __getitem__(self, k):
- if self.cache.has_key(k):
- return self.cache[k]
if self.in_progress.has_key(k):
- raise MoeConfigEvalErr, "Definition of $%s is recursive" % k;
+ raise MoeConfigEvalError, "Definition of $%s is recursive" % k;
self.in_progress[k] = 1;
v = self.do_get(k, len(self.stk)-1)
del self.in_progress[k]
- ## FIXME: This is disabled, because the immutability invariant is broken!
- # self.cache[k] = v
return v
def do_get(self, k, pos):
cfg = self.stk[pos]
if cfg.vars.has_key(k):
new = cfg.vars[k]
- if new[0][0] == "a":
+ if len(new) > 0 and new[0][0] == "a":
v = self.do_get(k, pos-1)
+ if v != "" and not v.endswith(" "):
+ v += " "
else:
v = ""
for op,arg in new:
else:
newstk.append(cfg)
self.stk = newstk
- self.reset_cache()
def parse_overrides(argv):
cfg = None