From f658802ff830f2638850e11bcb566cf6f79e447d Mon Sep 17 00:00:00 2001 From: Sebastien Bourdeauducq Date: Sat, 2 Nov 2013 16:03:47 +0100 Subject: [PATCH] replace use of __dict__ with dir()/xdir() --- migen/bank/csrgen.py | 5 ++--- migen/bank/description.py | 5 +++-- migen/bank/eventmanager.py | 3 ++- migen/fhdl/decorators.py | 3 +++ migen/fhdl/namer.py | 2 +- migen/flow/actor.py | 3 ++- migen/genlib/ioo.py | 7 ++++--- migen/pytholite/compiler.py | 4 +++- migen/util/misc.py | 7 +++++++ migen/{graph => util}/treeviz.py | 0 10 files changed, 27 insertions(+), 12 deletions(-) create mode 100644 migen/util/misc.py rename migen/{graph => util}/treeviz.py (100%) diff --git a/migen/bank/csrgen.py b/migen/bank/csrgen.py index 320b3ec0c..9be01cb08 100644 --- a/migen/bank/csrgen.py +++ b/migen/bank/csrgen.py @@ -1,5 +1,4 @@ -from operator import itemgetter - +from migen.util.misc import xdir from migen.fhdl.std import * from migen.bus import csr from migen.bank.description import * @@ -69,7 +68,7 @@ class BankArray(Module): def scan(self, ifargs, ifkwargs): self.banks = [] self.srams = [] - for name, obj in sorted(self.source.__dict__.items(), key=itemgetter(0)): + for name, obj in xdir(self.source, True): if hasattr(obj, "get_csrs"): csrs = obj.get_csrs() else: diff --git a/migen/bank/description.py b/migen/bank/description.py index 5afbfdf1d..8632dd2c1 100644 --- a/migen/bank/description.py +++ b/migen/bank/description.py @@ -1,3 +1,4 @@ +from migen.util.misc import xdir from migen.fhdl.std import * from migen.fhdl.tracer import get_obj_var_name @@ -107,7 +108,7 @@ class AutoCSR: except AttributeError: prefixed = self.__prefixed = set() r = [] - for k, v in self.__dict__.items(): + for k, v in xdir(self, True): if k not in exclude: if isinstance(v, Memory): r.append(v) @@ -127,7 +128,7 @@ class AutoCSR: except AttributeError: prefixed = self.__prefixed = set() r = [] - for k, v in self.__dict__.items(): + for k, v in xdir(self, True): if k not in exclude: if isinstance(v, _CSRBase): r.append(v) diff --git a/migen/bank/eventmanager.py b/migen/bank/eventmanager.py index 9c9aa423a..8cd47a7ee 100644 --- a/migen/bank/eventmanager.py +++ b/migen/bank/eventmanager.py @@ -1,3 +1,4 @@ +from migen.util.misc import xdir from migen.fhdl.std import * from migen.bank.description import * from migen.genlib.misc import optree @@ -46,7 +47,7 @@ class EventManager(Module, AutoCSR): self.irq = Signal() def do_finalize(self): - sources_u = [v for v in self.__dict__.values() if isinstance(v, _EventSource)] + sources_u = [v for k, v in xdir(self, True) if isinstance(v, _EventSource)] sources = sorted(sources_u, key=lambda x: x.huid) n = len(sources) self.status = CSR(n) diff --git a/migen/fhdl/decorators.py b/migen/fhdl/decorators.py index 7c7efe164..03318bc01 100644 --- a/migen/fhdl/decorators.py +++ b/migen/fhdl/decorators.py @@ -20,6 +20,9 @@ class ModuleDecorator: self.transform_fragment(f) return f + def __dir__(self): + return dir(self._md_decorated) + class DecorateModule: def __init__(self, decorator, *dec_args, **dec_kwargs): self.decorator = decorator diff --git a/migen/fhdl/namer.py b/migen/fhdl/namer.py index ba24cf3b3..1cfcf2ea9 100644 --- a/migen/fhdl/namer.py +++ b/migen/fhdl/namer.py @@ -12,7 +12,7 @@ class _Node: self.children = OrderedDict() def _display_tree(filename, tree): - from migen.graph.treeviz import RenderNode + from migen.util.treeviz import RenderNode def _to_render_node(name, node): children = [_to_render_node(k, v) for k, v in node.children.items()] diff --git a/migen/flow/actor.py b/migen/flow/actor.py index a834046ab..279182e7f 100644 --- a/migen/flow/actor.py +++ b/migen/flow/actor.py @@ -1,3 +1,4 @@ +from migen.util.misc import xdir from migen.fhdl.std import * from migen.genlib.misc import optree from migen.genlib.record import * @@ -32,7 +33,7 @@ def get_endpoints(obj, filt=_Endpoint): if hasattr(obj, "get_endpoints") and callable(obj.get_endpoints): return obj.get_endpoints(filt) r = dict() - for k, v in obj.__dict__.items(): + for k, v in xdir(obj, True): if isinstance(v, filt): r[k] = v return r diff --git a/migen/genlib/ioo.py b/migen/genlib/ioo.py index 66d411b07..0280b43d4 100644 --- a/migen/genlib/ioo.py +++ b/migen/genlib/ioo.py @@ -1,3 +1,4 @@ +from migen.util.misc import xdir from migen.fhdl.std import * from migen.flow.actor import * from migen.flow.actor import _Endpoint @@ -10,13 +11,13 @@ class UnifiedIOObject(Module): def do_finalize(self): if self.get_dataflow(): self.busy = Signal() - self.specials += set(v for v in self.__dict__.values() if isinstance(v, Memory)) + self.specials += set(v for k, v in xdir(self, True) if isinstance(v, Memory)) def get_dataflow(self): - return dict((k, v) for k, v in self.__dict__.items() if isinstance(v, _Endpoint)) + return dict((k, v) for k, v in xdir(self, True) if isinstance(v, _Endpoint)) def get_buses(self): - return dict((k, v) for k, v in self.__dict__.items() if isinstance(v, (wishbone.Interface, Memory))) + return dict((k, v) for k, v in xdir(self, True) if isinstance(v, (wishbone.Interface, Memory))) (_WAIT_COMPLETE, _WAIT_POLL) = range(2) diff --git a/migen/pytholite/compiler.py b/migen/pytholite/compiler.py index bfe1f8278..20d7db021 100644 --- a/migen/pytholite/compiler.py +++ b/migen/pytholite/compiler.py @@ -2,6 +2,7 @@ import inspect import ast from collections import OrderedDict +from migen.util.misc import xdir from migen.fhdl.structure import * from migen.fhdl.visit import TransformModule from migen.fhdl.specials import Memory @@ -293,7 +294,8 @@ class Pytholite(UnifiedIOObject): if self.get_dataflow(): self.busy.reset = 1 self.memory_ports = dict() - for mem in self.__dict__.values(): + for key in xdir(self): + mem = getattr(self, key) if isinstance(mem, Memory): port = mem.get_port(write_capable=True, we_granularity=8) self.specials += port diff --git a/migen/util/misc.py b/migen/util/misc.py new file mode 100644 index 000000000..0a35ea681 --- /dev/null +++ b/migen/util/misc.py @@ -0,0 +1,7 @@ +def xdir(obj, return_values=False): + for attr in dir(obj): + if attr[:2] != "__" and attr[-2:] != "__": + if return_values: + yield attr, getattr(obj, attr) + else: + yield attr diff --git a/migen/graph/treeviz.py b/migen/util/treeviz.py similarity index 100% rename from migen/graph/treeviz.py rename to migen/util/treeviz.py