diff options
author | cpopa <devnull@localhost> | 2013-08-13 13:48:51 +0300 |
---|---|---|
committer | cpopa <devnull@localhost> | 2013-08-13 13:48:51 +0300 |
commit | 3a1e3fa1636032cdaad5b1debdd15bf115ad2c1a (patch) | |
tree | 76cfcefd5e139f620d762f65da7e4b6d1d3276d0 /rebuilder.py | |
parent | 9b41481e469b2829cf97a9dd282930a092d5d777 (diff) | |
download | astroid-3a1e3fa1636032cdaad5b1debdd15bf115ad2c1a.tar.gz |
Change metaclass discovery.
Diffstat (limited to 'rebuilder.py')
-rw-r--r-- | rebuilder.py | 14 |
1 files changed, 4 insertions, 10 deletions
diff --git a/rebuilder.py b/rebuilder.py index e3e1fc1..862de85 100644 --- a/rebuilder.py +++ b/rebuilder.py @@ -21,7 +21,7 @@ order to get a single Astroid representation import sys from warnings import warn -from _ast import (Expr as Discard, Str, Name, Attribute, +from _ast import (Expr as Discard, Str, # binary operators Add, Div, FloorDiv, Mod, Mult, Pow, Sub, BitAnd, BitOr, BitXor, LShift, RShift, @@ -99,13 +99,6 @@ def _init_set_doc(node, newnode): except IndexError: pass # ast built from scratch -def _infer_metaclass(node): - if isinstance(node, Name): - return node.id - elif isinstance(node, Attribute): - # TODO: should we retrieve the fully qualified name of the class? - return node.attr - def _lineno_parent(oldnode, newnode, parent): newnode.parent = parent if hasattr(oldnode, 'lineno'): @@ -251,7 +244,8 @@ class TreeRebuilder(object): except (AttributeError, KeyError): continue elif getattr(newnode.targets[0], 'name', None) == '__metaclass__': - self._metaclass[-1] = _infer_metaclass(node.value) or 'type' + # XXX check more... + self._metaclass[-1] = 'type' newnode.set_line_info(newnode.last_child()) return newnode @@ -944,7 +938,7 @@ class TreeRebuilder3k(TreeRebuilder): newnode = super(TreeRebuilder3k, self).visit_class(node, parent) for keyword in node.keywords: if keyword.arg == 'metaclass': - newnode._metaclass = _infer_metaclass(keyword.value) or 'type' + newnode._metaclass = self.visit(keyword, newnode).value break return newnode |