summary |
shortlog |
log |
commit | commitdiff |
tree
raw |
patch |
inline | side by side (from parent 1:
e96706d)
svn path=/trunk/packages/invirt-base/; revision=2920
+invirt-base (0.0.29) unstable; urgency=low
+
+ * Added a safestructs for doing config without raising.
+
+ -- Greg Brockman <gdb@mit.edu> Tue, 19 Jan 2010 23:49:19 -0500
+
invirt-base (0.0.28) unstable; urgency=low
* Completely remove the invirt.authz Python package - it will be
invirt-base (0.0.28) unstable; urgency=low
* Completely remove the invirt.authz Python package - it will be
class struct(dict):
'A simple namespace object.'
class struct(dict):
'A simple namespace object.'
- def __init__(self, d = {}, __prefix = None, **kwargs):
+ def __init__(self, d = {}, __prefix = None, __default=None, **kwargs):
super(struct, self).__init__(d)
self.__prefix = __prefix
super(struct, self).__init__(d)
self.__prefix = __prefix
+ self.__default = __default
self.update(kwargs)
def __getattr__(self, key):
try:
return self[key]
except KeyError:
self.update(kwargs)
def __getattr__(self, key):
try:
return self[key]
except KeyError:
- # XX ideally these would point a frame higher on the stack.
- prefix = self.__prefix
- if prefix is not None:
- raise InvirtConfigError('missing configuration variable %s%s'
- % (prefix, key))
+ if self.__default is None:
+ # XX ideally these would point a frame higher on the stack.
+ prefix = self.__prefix
+ if prefix is not None:
+ raise InvirtConfigError('missing configuration variable '
+ '%s%s' % (prefix, key))
+ else:
+ raise AttributeError("anonymous struct has no member '%s'"
+ % (key,))
- raise AttributeError("anonymous struct has no member '%s'"
- % (key,))
+ return struct({}, '', self.__default)
-def dicts2struct(x, prefix = None):
+def dicts2struct(x, prefix = None, default = None):
"""
Given a tree of lists/dicts, perform a deep traversal to transform all the
dicts to structs.
"""
Given a tree of lists/dicts, perform a deep traversal to transform all the
dicts to structs.
else:
def newprefix(k): return prefix
if type(x) == dict:
else:
def newprefix(k): return prefix
if type(x) == dict:
- return struct(((k, dicts2struct(v, newprefix(k)))
+ return struct(((k, dicts2struct(v, newprefix(k), default))
for k,v in x.iteritems()),
for k,v in x.iteritems()),
- return [dicts2struct(v, newprefix(i)) for i, v in enumerate(x)]
+ return [dicts2struct(v, newprefix(i), default)
+ for i, v in enumerate(x)]
- return struct({}, prefix)
+ return struct({}, prefix, default)
dicts = load()
structs = dicts2struct(dicts, '')
dicts = load()
structs = dicts2struct(dicts, '')
+safestructs = dicts2struct(dicts, '', '')