summaryrefslogtreecommitdiff
path: root/rebuilder.py
diff options
context:
space:
mode:
authorClaudiu Popa <pcmanticore@gmail.com>2013-08-13 13:48:51 +0300
committerClaudiu Popa <pcmanticore@gmail.com>2013-08-13 13:48:51 +0300
commit1100458bb85aadbf49ad5c08ec43f75995bac1f5 (patch)
tree0de68d2bca3200decc03fab3706f7e1f59288925 /rebuilder.py
parent0b9211efae4ca1b29559a81ae82aed6f0a42d262 (diff)
downloadastroid-git-1100458bb85aadbf49ad5c08ec43f75995bac1f5.tar.gz
Change metaclass discovery.
--HG-- branch : metaclass
Diffstat (limited to 'rebuilder.py')
-rw-r--r--rebuilder.py14
1 files changed, 4 insertions, 10 deletions
diff --git a/rebuilder.py b/rebuilder.py
index e3e1fc16..862de858 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