Commit f70465bd authored by Mark Florisson's avatar Mark Florisson

Fix a little bug for break/continue in parallel sections

parent 8e05843a
...@@ -23,6 +23,9 @@ object_expr = TypedExprNode(py_object_type) ...@@ -23,6 +23,9 @@ object_expr = TypedExprNode(py_object_type)
class MarkAssignments(CythonTransform): class MarkAssignments(CythonTransform):
# tells us whether we're in a normal loop
in_loop = False
def __init__(self, context): def __init__(self, context):
super(CythonTransform, self).__init__() super(CythonTransform, self).__init__()
self.context = context self.context = context
...@@ -115,7 +118,8 @@ class MarkAssignments(CythonTransform): ...@@ -115,7 +118,8 @@ class MarkAssignments(CythonTransform):
node.pos, node.pos,
base = sequence, base = sequence,
index = ExprNodes.IntNode(node.pos, value = '0'))) index = ExprNodes.IntNode(node.pos, value = '0')))
self.visitchildren(node)
self._visit_loop_node_children(node)
return node return node
def visit_ForFromStatNode(self, node): def visit_ForFromStatNode(self, node):
...@@ -126,7 +130,11 @@ class MarkAssignments(CythonTransform): ...@@ -126,7 +130,11 @@ class MarkAssignments(CythonTransform):
'+', '+',
node.bound1, node.bound1,
node.step)) node.step))
self.visitchildren(node) self._visit_loop_node_children(node)
return node
def visit_WhileStatNode(self, node):
self._visit_loop_node_children(node)
return node return node
def visit_ExceptClauseNode(self, node): def visit_ExceptClauseNode(self, node):
...@@ -195,20 +203,22 @@ class MarkAssignments(CythonTransform): ...@@ -195,20 +203,22 @@ class MarkAssignments(CythonTransform):
return node return node
def visit_BreakStatNode(self, node): def visit_BreakStatNode(self, node):
parnode = self.parallel_block_stack[-1] if self.parallel_block_stack:
parnode.break_label_used = True parnode = self.parallel_block_stack[-1]
parnode.break_label_used = True
if not parnode.is_prange and parnode.parent: if not parnode.is_prange and parnode.parent:
parnode.parent.break_label_used = True parnode.parent.break_label_used = True
return node return node
def visit_ContinueStatNode(self, node): def visit_ContinueStatNode(self, node):
parnode = self.parallel_block_stack[-1] if self.parallel_block_stack:
parnode.continue_label_used = True parnode = self.parallel_block_stack[-1]
parnode.continue_label_used = True
if not parnode.is_prange and parnode.parent: if not parnode.is_prange and parnode.parent:
parnode.parent.continue_label_used = True parnode.parent.continue_label_used = True
return node return node
...@@ -225,6 +235,26 @@ class MarkAssignments(CythonTransform): ...@@ -225,6 +235,26 @@ class MarkAssignments(CythonTransform):
return node return node
def _visit_loop_node_children(self, node):
"""
Used for the children of "loop nodes", like ForInStatNode, so subnodes
can establish whether break and continue belong to a parallel node
or something else.
"""
child_attrs = node.child_attrs
node.child_attrs = [attr for attr in child_attrs if attr != 'else_clause']
was_in_loop = self.in_loop
self.in_loop = True
self.visitchildren(node)
self.in_loop = was_in_loop
node.child_attrs = child_attrs
if node.else_clause:
node.else_clause = self.visit(node.else_clause)
class MarkOverflowingArithmetic(CythonTransform): class MarkOverflowingArithmetic(CythonTransform):
......
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