Commit d7c33b00 authored by Xavier Thompson's avatar Xavier Thompson

Improve declaration analysis of cypclass methods

parent 9e935e2e
...@@ -2505,6 +2505,7 @@ class CFuncDefNode(FuncDefNode): ...@@ -2505,6 +2505,7 @@ class CFuncDefNode(FuncDefNode):
# is_const_method whether this is a const method # is_const_method whether this is a const method
# is_static_method whether this is a static method # is_static_method whether this is a static method
# is_c_class_method whether this is a cclass method # is_c_class_method whether this is a cclass method
# is_cyp_class_method whether this is a cypclass method
child_attrs = ["base_type", "declarator", "body", "decorators", "py_func_stat"] child_attrs = ["base_type", "declarator", "body", "decorators", "py_func_stat"]
outer_attrs = ["decorators", "py_func_stat"] outer_attrs = ["decorators", "py_func_stat"]
...@@ -2531,6 +2532,7 @@ class CFuncDefNode(FuncDefNode): ...@@ -2531,6 +2532,7 @@ class CFuncDefNode(FuncDefNode):
def analyse_declarations(self, env): def analyse_declarations(self, env):
self.is_c_class_method = env.is_c_class_scope self.is_c_class_method = env.is_c_class_scope
self.is_cyp_class_method = env.is_cpp_class_scope and env.parent_type.is_cyp_class
if self.directive_locals is None: if self.directive_locals is None:
self.directive_locals = {} self.directive_locals = {}
self.directive_locals.update(env.directives.get('locals', {})) self.directive_locals.update(env.directives.get('locals', {}))
...@@ -2572,8 +2574,7 @@ class CFuncDefNode(FuncDefNode): ...@@ -2572,8 +2574,7 @@ class CFuncDefNode(FuncDefNode):
# It is reinserted here, as __new__ MUST be static in a cypclass, # It is reinserted here, as __new__ MUST be static in a cypclass,
# so there is no self arg (the first arg is actually the allocator). # so there is no self arg (the first arg is actually the allocator).
if env.is_cpp_class_scope and env.parent_type.is_cyp_class\ if self.is_cyp_class_method and name in ("__new__", "__alloc__") and not self.is_static_method:
and name in ("__new__", "__alloc__") and not self.is_static_method:
self.is_static_method = 1 self.is_static_method = 1
if declarator.skipped_self: if declarator.skipped_self:
_name, _type, _pos, _arg = declarator.skipped_self _name, _type, _pos, _arg = declarator.skipped_self
...@@ -2649,8 +2650,7 @@ class CFuncDefNode(FuncDefNode): ...@@ -2649,8 +2650,7 @@ class CFuncDefNode(FuncDefNode):
# An error will be produced in the cdef function # An error will be produced in the cdef function
self.overridable = False self.overridable = False
if env.is_cpp_class_scope and env.parent_type.is_cyp_class\ if self.is_cyp_class_method and not declarator.skipped_self and not self.is_static_method:
and not declarator.skipped_self and not self.is_static_method:
# It means we have a cypclass method without the self argument # It means we have a cypclass method without the self argument
# => shout # => shout
error(self.pos, "Cypclass methods must have a self argument") error(self.pos, "Cypclass methods must have a self argument")
...@@ -2669,6 +2669,7 @@ class CFuncDefNode(FuncDefNode): ...@@ -2669,6 +2669,7 @@ class CFuncDefNode(FuncDefNode):
self_locking_state.is_rlocked = self.is_const_method self_locking_state.is_rlocked = self.is_const_method
self_locking_state.is_wlocked = not self.is_const_method self_locking_state.is_wlocked = not self.is_const_method
def declare_cpdef_wrapper(self, env): def declare_cpdef_wrapper(self, env):
if self.overridable: if self.overridable:
if self.is_static_method: if self.is_static_method:
......
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