def transform(self, node, results):
- meta = self.has_metaclass(node)
+ meta_results = self.has_metaclass(node)
+ if not meta_results: return
+ for meta in meta_results:
target = Leaf(token.NAME, u"__metaclass__")
equal = Leaf(token.EQUAL, u"=", prefix=u" ")
- stmt_node = Node(syms.atom, [target, equal, meta])
+ #meta is the last item in what was returned by has_metaclass(): name
+ stmt_node = Node(syms.atom, [target, equal, name])
def has_metaclass(self, parent):
for node in parent.children:
if node.type == syms.argument:
if kids[0] == Leaf(token.NAME, u"metaclass") and \
kids[1] == Leaf(token.EQUAL, u"=") and \
- #One argument, it's the (metaclass=X) part...
+ #Hack to avoid "class X(=):" with this case.
+ results = [node] + kids
elif node.type == syms.arglist:
#Argument list... loop through it looking for:
#Node(*, [*, Leaf(token.NAME, u"metaclass"), Leaf(token.EQUAL, u"="), Leaf(*, *)]
for child in node.children:
- if type(child) == Node:
+ if type(child) == Leaf:
+ if child.type == token.COMMA:
+ #Store the last comma, which precedes the metaclass
+ elif type(child) == Node:
+ meta = equal = name = None
for arg in child.children:
if arg == Leaf(token.NAME, u"metaclass"):
#We have the (metaclass) part
#Here we go, we have (metaclass=X)
- raise SyntaxError("Argument after metaclass=X")
+ results = (comma, meta, equal, name)