Commit b3a21330 authored by Mark Florisson's avatar Mark Florisson

Fix default arguments

parent 0bc88c6c
...@@ -6240,7 +6240,7 @@ class PyCFunctionNode(ExprNode, ModuleNameMixin): ...@@ -6240,7 +6240,7 @@ class PyCFunctionNode(ExprNode, ModuleNameMixin):
else: else:
arg.default = DefaultLiteralArgNode(arg.pos, arg.default) arg.default = DefaultLiteralArgNode(arg.pos, arg.default)
default_args.append(arg) default_args.append(arg)
if nonliteral_objects or nonliteral_objects: if nonliteral_objects or nonliteral_other:
module_scope = env.global_scope() module_scope = env.global_scope()
cname = module_scope.next_id(Naming.defaults_struct_prefix) cname = module_scope.next_id(Naming.defaults_struct_prefix)
scope = Symtab.StructOrUnionScope(cname) scope = Symtab.StructOrUnionScope(cname)
......
...@@ -679,18 +679,18 @@ class FusedCFuncDefNode(StatListNode): ...@@ -679,18 +679,18 @@ class FusedCFuncDefNode(StatListNode):
else: else:
defaults.append(None) defaults.append(None)
for node in self.stats: for stat in self.stats:
node.analyse_expressions(env) stat.analyse_expressions(env)
if isinstance(node, FuncDefNode): if isinstance(stat, FuncDefNode):
for arg, default in zip(node.args, defaults): for arg, default in zip(stat.args, defaults):
if default is not None: if default is not None:
arg.default = CloneNode(default).coerce_to(arg.type, env) arg.default = CloneNode(default).coerce_to(arg.type, env)
if self.py_func: if self.py_func:
args = [CloneNode(default) for default in defaults if default] args = [CloneNode(default) for default in defaults if default]
defaults_tuple = TupleNode(self.pos, args=args) self.defaults_tuple = TupleNode(self.pos, args=args)
defaults_tuple.analyse_types(env, skip_children=True) self.defaults_tuple.analyse_types(env, skip_children=True)
self.defaults_tuple = ProxyNode(defaults_tuple) self.defaults_tuple = ProxyNode(self.defaults_tuple)
self.code_object = ProxyNode(self.specialized_pycfuncs[0].code_object) self.code_object = ProxyNode(self.specialized_pycfuncs[0].code_object)
fused_func = self.resulting_fused_function.arg fused_func = self.resulting_fused_function.arg
...@@ -698,8 +698,9 @@ class FusedCFuncDefNode(StatListNode): ...@@ -698,8 +698,9 @@ class FusedCFuncDefNode(StatListNode):
fused_func.code_object = CloneNode(self.code_object) fused_func.code_object = CloneNode(self.code_object)
for pycfunc in self.specialized_pycfuncs: for pycfunc in self.specialized_pycfuncs:
pycfunc.defaults_tuple = CloneNode(self.defaults_tuple)
pycfunc.code_object = CloneNode(self.code_object) pycfunc.code_object = CloneNode(self.code_object)
pycfunc.analyse_types(env)
pycfunc.defaults_tuple = CloneNode(self.defaults_tuple)
def synthesize_defnodes(self): def synthesize_defnodes(self):
""" """
......
...@@ -107,3 +107,27 @@ def test_defaults_fused(cython.floating arg1, cython.floating arg2 = counter2()) ...@@ -107,3 +107,27 @@ def test_defaults_fused(cython.floating arg1, cython.floating arg2 = counter2())
(2.0,) (2.0,)
""" """
print arg1, arg2 print arg1, arg2
funcs = []
for i in range(10):
def defaults_fused(cython.floating a, cython.floating b = i):
return a, b
funcs.append(defaults_fused)
def test_dynamic_defaults_fused():
"""
>>> test_dynamic_defaults_fused()
i 0 func result (1.0, 0.0) defaults (0,)
i 1 func result (1.0, 1.0) defaults (1,)
i 2 func result (1.0, 2.0) defaults (2,)
i 3 func result (1.0, 3.0) defaults (3,)
i 4 func result (1.0, 4.0) defaults (4,)
i 5 func result (1.0, 5.0) defaults (5,)
i 6 func result (1.0, 6.0) defaults (6,)
i 7 func result (1.0, 7.0) defaults (7,)
i 8 func result (1.0, 8.0) defaults (8,)
i 9 func result (1.0, 9.0) defaults (9,)
"""
for i, f in enumerate(funcs):
print "i", i, "func result", f(1.0), "defaults", get_defaults(f)
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