Commit ad55c5fa authored by Stefan Behnel's avatar Stefan Behnel

fix node subtree access in last change (use either local variable or attribute, not a mix)

parent f6c6faf6
...@@ -4639,14 +4639,15 @@ class SingleAssignmentNode(AssignmentNode): ...@@ -4639,14 +4639,15 @@ class SingleAssignmentNode(AssignmentNode):
else: else:
dtype = self.lhs.type dtype = self.lhs.type
self.rhs = self.rhs.coerce_to(dtype, env) rhs = self.rhs.coerce_to(dtype, env)
if use_temp or self.rhs.is_attribute or ( if use_temp or rhs.is_attribute or (
not self.rhs.is_name and not self.rhs.is_literal and not rhs.is_name and not rhs.is_literal and
self.rhs.type.is_pyobject): rhs.type.is_pyobject):
# things like (cdef) attribute access are not safe (traverses pointers) # things like (cdef) attribute access are not safe (traverses pointers)
self.rhs = self.rhs.coerce_to_temp(env) rhs = rhs.coerce_to_temp(env)
elif self.rhs.type.is_pyobject: elif rhs.type.is_pyobject:
self.rhs = self.rhs.coerce_to_simple(env) rhs = rhs.coerce_to_simple(env)
self.rhs = rhs
return self return self
def generate_rhs_evaluation_code(self, code): def generate_rhs_evaluation_code(self, code):
...@@ -4686,9 +4687,9 @@ class CascadedAssignmentNode(AssignmentNode): ...@@ -4686,9 +4687,9 @@ class CascadedAssignmentNode(AssignmentNode):
from ExprNodes import CloneNode, ProxyNode from ExprNodes import CloneNode, ProxyNode
rhs = self.rhs.analyse_types(env) rhs = self.rhs.analyse_types(env)
if use_temp or self.rhs.is_attribute or ( if use_temp or rhs.is_attribute or (
not self.rhs.is_name and not self.rhs.is_literal and not rhs.is_name and not rhs.is_literal and
self.rhs.type.is_pyobject): rhs.type.is_pyobject):
rhs = rhs.coerce_to_temp(env) rhs = rhs.coerce_to_temp(env)
else: else:
rhs = rhs.coerce_to_simple(env) rhs = rhs.coerce_to_simple(env)
......
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