Commit a25fbc15 authored by Xavier Thompson's avatar Xavier Thompson

Avoid locking when accessing a static method from an object instance

parent f079f785
...@@ -7637,7 +7637,14 @@ class AttributeNode(ExprNode): ...@@ -7637,7 +7637,14 @@ class AttributeNode(ExprNode):
gil_message = "Accessing Python attribute" gil_message = "Accessing Python attribute"
def ensure_subexpr_rhs_locked(self, env): def ensure_subexpr_rhs_locked(self, env):
if not self.entry or self.entry.is_cfunction and not self.entry.type.is_const_method: if not self.entry:
self.obj.ensure_lhs_locked(env, is_dereferenced = True)
elif self.entry.is_cfunction:
if self.entry.type.is_static_method:
pass
elif self.entry.type.is_const_method:
self.obj.ensure_rhs_locked(env, is_dereferenced = True)
else:
self.obj.ensure_lhs_locked(env, is_dereferenced = True) self.obj.ensure_lhs_locked(env, is_dereferenced = True)
else: else:
self.obj.ensure_rhs_locked(env, is_dereferenced = True) self.obj.ensure_rhs_locked(env, is_dereferenced = True)
......
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