Commit a45cf25c authored by gsamain's avatar gsamain Committed by Xavier Thompson

Do lock analysis on statement nodes other than basic assignments (while, for, ...)

parent dd4be420
...@@ -6151,7 +6151,9 @@ class InPlaceAssignmentNode(AssignmentNode): ...@@ -6151,7 +6151,9 @@ class InPlaceAssignmentNode(AssignmentNode):
def analyse_types(self, env): def analyse_types(self, env):
self.rhs = self.rhs.analyse_types(env) self.rhs = self.rhs.analyse_types(env)
self.rhs.ensure_rhs_locked(env)
self.lhs = self.lhs.analyse_target_types(env) self.lhs = self.lhs.analyse_target_types(env)
self.rhs.ensure_lhs_locked(env)
# When assigning to a fully indexed buffer or memoryview, coerce the rhs # When assigning to a fully indexed buffer or memoryview, coerce the rhs
if self.lhs.is_memview_index or self.lhs.is_buffer_access: if self.lhs.is_memview_index or self.lhs.is_buffer_access:
...@@ -6214,6 +6216,7 @@ class PrintStatNode(StatNode): ...@@ -6214,6 +6216,7 @@ class PrintStatNode(StatNode):
stream = self.stream.analyse_expressions(env) stream = self.stream.analyse_expressions(env)
self.stream = stream.coerce_to_pyobject(env) self.stream = stream.coerce_to_pyobject(env)
arg_tuple = self.arg_tuple.analyse_expressions(env) arg_tuple = self.arg_tuple.analyse_expressions(env)
arg_tuple.ensure_rhs_locked(env)
self.arg_tuple = arg_tuple.coerce_to_pyobject(env) self.arg_tuple = arg_tuple.coerce_to_pyobject(env)
env.use_utility_code(printing_utility_code) env.use_utility_code(printing_utility_code)
if len(self.arg_tuple.args) == 1 and self.append_newline: if len(self.arg_tuple.args) == 1 and self.append_newline:
...@@ -6323,6 +6326,7 @@ class DelStatNode(StatNode): ...@@ -6323,6 +6326,7 @@ class DelStatNode(StatNode):
def analyse_expressions(self, env): def analyse_expressions(self, env):
for i, arg in enumerate(self.args): for i, arg in enumerate(self.args):
arg = self.args[i] = arg.analyse_target_expression(env, None) arg = self.args[i] = arg.analyse_target_expression(env, None)
arg.ensure_lhs_locked(env)
if arg.type.is_pyobject or (arg.is_name and arg.type.is_memoryviewslice): if arg.type.is_pyobject or (arg.is_name and arg.type.is_memoryviewslice):
if arg.is_name and arg.entry.is_cglobal: if arg.is_name and arg.entry.is_cglobal:
error(arg.pos, "Deletion of global C variable") error(arg.pos, "Deletion of global C variable")
...@@ -6450,6 +6454,7 @@ class ReturnStatNode(StatNode): ...@@ -6450,6 +6454,7 @@ class ReturnStatNode(StatNode):
if self.in_async_gen: if self.in_async_gen:
error(self.pos, "Return with value in async generator") error(self.pos, "Return with value in async generator")
self.value = self.value.analyse_types(env) self.value = self.value.analyse_types(env)
self.value.ensure_rhs_locked(env)
if return_type.is_void or return_type.is_returncode: if return_type.is_void or return_type.is_returncode:
error(self.value.pos, "Return with value in void function") error(self.value.pos, "Return with value in void function")
else: else:
...@@ -6794,6 +6799,7 @@ class IfClauseNode(Node): ...@@ -6794,6 +6799,7 @@ class IfClauseNode(Node):
def analyse_expressions(self, env): def analyse_expressions(self, env):
self.condition = self.condition.analyse_temp_boolean_expression(env) self.condition = self.condition.analyse_temp_boolean_expression(env)
self.condition.ensure_rhs_locked(env)
self.body = self.body.analyse_expressions(env) self.body = self.body.analyse_expressions(env)
return self return self
...@@ -6923,6 +6929,7 @@ class WhileStatNode(LoopNode, StatNode): ...@@ -6923,6 +6929,7 @@ class WhileStatNode(LoopNode, StatNode):
def analyse_expressions(self, env): def analyse_expressions(self, env):
if self.condition: if self.condition:
self.condition = self.condition.analyse_temp_boolean_expression(env) self.condition = self.condition.analyse_temp_boolean_expression(env)
self.condition.ensure_rhs_locked(env)
self.body = self.body.analyse_expressions(env) self.body = self.body.analyse_expressions(env)
if self.else_clause: if self.else_clause:
self.else_clause = self.else_clause.analyse_expressions(env) self.else_clause = self.else_clause.analyse_expressions(env)
...@@ -7154,7 +7161,9 @@ class _ForInStatNode(LoopNode, StatNode): ...@@ -7154,7 +7161,9 @@ class _ForInStatNode(LoopNode, StatNode):
def analyse_expressions(self, env): def analyse_expressions(self, env):
self.target = self.target.analyse_target_types(env) self.target = self.target.analyse_target_types(env)
self.target.ensure_lhs_locked(env)
self.iterator = self.iterator.analyse_expressions(env) self.iterator = self.iterator.analyse_expressions(env)
self.iterator.ensure_rhs_locked(env)
self._create_item_node() # must rewrap self.item after analysis self._create_item_node() # must rewrap self.item after analysis
self.item = self.item.analyse_expressions(env) self.item = self.item.analyse_expressions(env)
if (not self.is_async and if (not self.is_async and
...@@ -7296,13 +7305,17 @@ class ForFromStatNode(LoopNode, StatNode): ...@@ -7296,13 +7305,17 @@ class ForFromStatNode(LoopNode, StatNode):
def analyse_expressions(self, env): def analyse_expressions(self, env):
from . import ExprNodes from . import ExprNodes
self.target = self.target.analyse_target_types(env) self.target = self.target.analyse_target_types(env)
self.target.ensure_lhs_locked(env)
self.bound1 = self.bound1.analyse_types(env) self.bound1 = self.bound1.analyse_types(env)
self.bound1.ensure_rhs_locked(env)
self.bound2 = self.bound2.analyse_types(env) self.bound2 = self.bound2.analyse_types(env)
self.bound2.ensure_rhs_locked(env)
if self.step is not None: if self.step is not None:
if isinstance(self.step, ExprNodes.UnaryMinusNode): if isinstance(self.step, ExprNodes.UnaryMinusNode):
warning(self.step.pos, "Probable infinite loop in for-from-by statement. " warning(self.step.pos, "Probable infinite loop in for-from-by statement. "
"Consider switching the directions of the relations.", 2) "Consider switching the directions of the relations.", 2)
self.step = self.step.analyse_types(env) self.step = self.step.analyse_types(env)
self.step.ensure_rhs_locked(env)
self.set_up_loop(env) self.set_up_loop(env)
target_type = self.target.type target_type = self.target.type
......
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