Commit aa75b693 authored by Stefan Behnel's avatar Stefan Behnel

prevent duplicated calls to analyse_default_values() for cpdef functions

parent 253ed803
...@@ -961,10 +961,9 @@ class FuncDefNode(StatNode, BlockNode): ...@@ -961,10 +961,9 @@ class FuncDefNode(StatNode, BlockNode):
for arg in self.args: for arg in self.args:
if arg.default: if arg.default:
if arg.is_generic: if arg.is_generic:
if not hasattr(arg, 'default_entry'): arg.default.analyse_types(env)
arg.default.analyse_types(env) arg.default = arg.default.coerce_to(arg.type, genv)
arg.default = arg.default.coerce_to(arg.type, genv) arg.default.allocate_temps(genv)
arg.default.allocate_temps(genv)
else: else:
error(arg.pos, error(arg.pos,
"This argument cannot have a default value") "This argument cannot have a default value")
...@@ -1352,9 +1351,11 @@ class CFuncDefNode(FuncDefNode): ...@@ -1352,9 +1351,11 @@ class CFuncDefNode(FuncDefNode):
error(self.pos, "Function declared nogil has Python locals or temporaries") error(self.pos, "Function declared nogil has Python locals or temporaries")
def analyse_expressions(self, env): def analyse_expressions(self, env):
self.analyse_default_values(env)
if self.py_func is not None: if self.py_func is not None:
# this will also analyse the default values
self.py_func.analyse_expressions(env) self.py_func.analyse_expressions(env)
else:
self.analyse_default_values(env)
def generate_function_header(self, code, with_pymethdef, with_opt_args = 1, with_dispatch = 1, cname = None): def generate_function_header(self, code, with_pymethdef, with_opt_args = 1, with_dispatch = 1, cname = None):
arg_decls = [] arg_decls = []
......
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