Commit 9ea6a398 authored by Robert Bradshaw's avatar Robert Bradshaw

Use assignments, not (buggy) control flow, for arg incref decision.

parent 42c6c6f5
...@@ -1135,7 +1135,7 @@ class FuncDefNode(StatNode, BlockNode): ...@@ -1135,7 +1135,7 @@ class FuncDefNode(StatNode, BlockNode):
# If an argument is assigned to in the body, we must # If an argument is assigned to in the body, we must
# incref it to properly keep track of refcounts. # incref it to properly keep track of refcounts.
for entry in lenv.arg_entries: for entry in lenv.arg_entries:
if entry.type.is_pyobject and lenv.control_flow.get_state((entry.name, 'source')) != 'arg': if entry.type.is_pyobject and entry.assignments:
code.put_var_incref(entry) code.put_var_incref(entry)
# ----- Initialise local variables # ----- Initialise local variables
for entry in lenv.var_entries: for entry in lenv.var_entries:
...@@ -1238,11 +1238,10 @@ class FuncDefNode(StatNode, BlockNode): ...@@ -1238,11 +1238,10 @@ class FuncDefNode(StatNode, BlockNode):
# Decref any increfed args # Decref any increfed args
for entry in lenv.arg_entries: for entry in lenv.arg_entries:
if entry.type.is_pyobject: if entry.type.is_pyobject:
src = lenv.control_flow.get_state((entry.name, 'source')) if entry.in_closure and not entry.assignments:
if entry.in_closure and src == 'arg':
code.put_var_incref(entry) code.put_var_incref(entry)
code.put_var_giveref(entry) code.put_var_giveref(entry)
elif not entry.in_closure and src != 'arg': elif not entry.in_closure and entry.assignments:
code.put_var_decref(entry) code.put_var_decref(entry)
if self.needs_closure: if self.needs_closure:
code.put_decref(Naming.cur_scope_cname, lenv.scope_class.type) code.put_decref(Naming.cur_scope_cname, lenv.scope_class.type)
......
def f(dict d): def f(dict d, x=4):
""" """
>>> f({1:1, 2:2}) >>> f({1:1, 2:2})
[1, 2] [1, 2]
......
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