Commit 07ef4ef6 authored by Stefan Behnel's avatar Stefan Behnel

mofe GIVEREF() before PyTuple_SET_ITEM() call because that's when we still own...

mofe GIVEREF() before PyTuple_SET_ITEM() call because that's when we still own the reference (pypy needs it that way)
parent dd55f76d
...@@ -5013,17 +5013,17 @@ class PyMethodCallNode(SimpleCallNode): ...@@ -5013,17 +5013,17 @@ class PyMethodCallNode(SimpleCallNode):
if len(args) > 1: if len(args) > 1:
code.putln("if (%s) {" % self_arg) code.putln("if (%s) {" % self_arg)
code.putln("PyTuple_SET_ITEM(%s, 0, %s); __Pyx_GIVEREF(%s); %s = NULL;" % ( code.putln("__Pyx_GIVEREF(%s); PyTuple_SET_ITEM(%s, 0, %s); %s = NULL;" % (
args_tuple, self_arg, self_arg, self_arg)) # stealing owned ref in this case self_arg, args_tuple, self_arg, self_arg)) # stealing owned ref in this case
code.funcstate.release_temp(self_arg) code.funcstate.release_temp(self_arg)
if len(args) > 1: if len(args) > 1:
code.putln("}") code.putln("}")
for i, arg in enumerate(args): for i, arg in enumerate(args):
arg.make_owned_reference(code) arg.make_owned_reference(code)
code.put_giveref(arg.py_result())
code.putln("PyTuple_SET_ITEM(%s, %d+%s, %s);" % ( code.putln("PyTuple_SET_ITEM(%s, %d+%s, %s);" % (
args_tuple, i, arg_offset, arg.py_result())) args_tuple, i, arg_offset, arg.py_result()))
code.put_giveref(arg.py_result())
if len(args) > 1: if len(args) > 1:
code.funcstate.release_temp(arg_offset_cname) code.funcstate.release_temp(arg_offset_cname)
...@@ -6185,12 +6185,12 @@ class SequenceNode(ExprNode): ...@@ -6185,12 +6185,12 @@ class SequenceNode(ExprNode):
arg = self.args[i] arg = self.args[i]
if c_mult or not arg.result_in_temp(): if c_mult or not arg.result_in_temp():
code.put_incref(arg.result(), arg.ctype()) code.put_incref(arg.result(), arg.ctype())
code.put_giveref(arg.py_result())
code.putln("%s(%s, %s, %s);" % ( code.putln("%s(%s, %s, %s);" % (
set_item_func, set_item_func,
target, target,
(offset and i) and ('%s + %s' % (offset, i)) or (offset or i), (offset and i) and ('%s + %s' % (offset, i)) or (offset or i),
arg.py_result())) arg.py_result()))
code.put_giveref(arg.py_result())
if c_mult: if c_mult:
code.putln('}') code.putln('}')
......
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