Config: Add support for a Self.all proxy object

This commit is contained in:
Ali Saidi 2011-07-10 12:56:08 -05:00
parent 83f91db2cc
commit 9751a1d3e7
3 changed files with 30 additions and 1 deletions

View file

@ -746,6 +746,21 @@ class SimObject(object):
found_obj = match_obj
return found_obj, found_obj != None
def find_all(self, ptype):
all = {}
# search children
for child in self._children.itervalues():
if isinstance(child, ptype) and not isproxy(child) and \
not isNullPointer(child):
all[child] = True
# search param space
for pname,pdesc in self._params.iteritems():
if issubclass(pdesc.ptype, ptype):
match_obj = self._values[pname]
if not isproxy(match_obj) and not isNullPointer(match_obj):
all[match_obj] = True
return all.keys(), True
def unproxy(self, base):
return self

View file

@ -184,7 +184,10 @@ class VectorParamValue(list):
return [ v.getValue() for v in self ]
def unproxy(self, base):
return [v.unproxy(base) for v in self]
if len(self) == 1 and isinstance(self[0], AllProxy):
return self[0].unproxy(base)
else:
return [v.unproxy(base) for v in self]
class SimObjectVector(VectorParamValue):
# support clone operation

View file

@ -184,6 +184,13 @@ class AnyProxy(BaseProxy):
def path(self):
return 'any'
class AllProxy(BaseProxy):
def find(self, obj):
return obj.find_all(self._pdesc.ptype)
def path(self):
return 'all'
def isproxy(obj):
if isinstance(obj, (BaseProxy, params.EthernetAddr)):
return True
@ -201,6 +208,10 @@ class ProxyFactory(object):
def __getattr__(self, attr):
if attr == 'any':
return AnyProxy(self.search_self, self.search_up)
elif attr == 'all':
if self.search_up:
assert("Parant.all is not supported")
return AllProxy(self.search_self, self.search_up)
else:
return AttrProxy(self.search_self, self.search_up, attr)