Commit f5e79aa7 authored by Xavier Thompson's avatar Xavier Thompson

Avoid locking when accessing a static method from an object instance

parent a0f2c2af
...@@ -7594,7 +7594,14 @@ class AttributeNode(ExprNode): ...@@ -7594,7 +7594,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