Commit 0ede0ca5 authored by Vitja Makarov's avatar Vitja Makarov

Transform generator into GeneratorDefNode and GeneratorBodyDefNode

parent 9cf498c8
This diff is collapsed.
...@@ -1354,9 +1354,20 @@ class MarkClosureVisitor(CythonTransform): ...@@ -1354,9 +1354,20 @@ class MarkClosureVisitor(CythonTransform):
if collector.yields: if collector.yields:
if collector.returns and not collector.has_return_value: if collector.returns and not collector.has_return_value:
error(collector.returns[0].pos, "'return' inside generators not yet supported ") error(collector.returns[0].pos, "'return' inside generators not yet supported ")
node.is_generator = True
node.needs_closure = True gbody = Nodes.GeneratorBodyDefNode(pos=node.pos,
node.yields = collector.yields name=node.name,
body=node.body,
yields=collector.yields)
generator = Nodes.GeneratorDefNode(pos=node.pos,
name=node.name,
args=node.args,
star_arg=node.star_arg,
starstar_arg=node.starstar_arg,
doc=node.doc,
decorators=node.decorators,
gbody=gbody)
return generator
return node return node
def visit_CFuncDefNode(self, node): def visit_CFuncDefNode(self, node):
...@@ -1447,6 +1458,9 @@ class CreateClosureClasses(CythonTransform): ...@@ -1447,6 +1458,9 @@ class CreateClosureClasses(CythonTransform):
return from_closure, in_closure return from_closure, in_closure
def create_class_from_scope(self, node, target_module_scope, inner_node=None): def create_class_from_scope(self, node, target_module_scope, inner_node=None):
# skip generator body
if node.is_generator_body:
return
# move local variables into closure # move local variables into closure
if node.is_generator: if node.is_generator:
for entry in node.local_scope.entries.values(): for entry in node.local_scope.entries.values():
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment