summaryrefslogtreecommitdiff
path: root/rebuilder.py
diff options
context:
space:
mode:
authorcpopa <devnull@localhost>2013-08-13 13:48:51 +0300
committercpopa <devnull@localhost>2013-08-13 13:48:51 +0300
commit3a1e3fa1636032cdaad5b1debdd15bf115ad2c1a (patch)
tree76cfcefd5e139f620d762f65da7e4b6d1d3276d0 /rebuilder.py
parent9b41481e469b2829cf97a9dd282930a092d5d777 (diff)
downloadastroid-3a1e3fa1636032cdaad5b1debdd15bf115ad2c1a.tar.gz
Change metaclass discovery.
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 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