Commit a4398a4e authored by Stefan Behnel's avatar Stefan Behnel

Use specialised default return handling code for "return None" in generators...

Use specialised default return handling code for "return None" in generators and other functions that return Python objects.
parent baac4e73
...@@ -5879,19 +5879,23 @@ class ReturnStatNode(StatNode): ...@@ -5879,19 +5879,23 @@ class ReturnStatNode(StatNode):
if not self.return_type: if not self.return_type:
# error reported earlier # error reported earlier
return return
value = self.value
if self.return_type.is_pyobject: if self.return_type.is_pyobject:
code.put_xdecref(Naming.retval_cname, code.put_xdecref(Naming.retval_cname, self.return_type)
self.return_type) if value and value.is_none:
# Use specialised default handling for "return None".
value = None
if self.value: if value:
self.value.generate_evaluation_code(code) value.generate_evaluation_code(code)
if self.return_type.is_memoryviewslice: if self.return_type.is_memoryviewslice:
from . import MemoryView from . import MemoryView
MemoryView.put_acquire_memoryviewslice( MemoryView.put_acquire_memoryviewslice(
lhs_cname=Naming.retval_cname, lhs_cname=Naming.retval_cname,
lhs_type=self.return_type, lhs_type=self.return_type,
lhs_pos=self.value.pos, lhs_pos=value.pos,
rhs=self.value, rhs=value,
code=code, code=code,
have_gil=self.in_nogil_context) have_gil=self.in_nogil_context)
elif self.in_generator: elif self.in_generator:
...@@ -5900,15 +5904,15 @@ class ReturnStatNode(StatNode): ...@@ -5900,15 +5904,15 @@ class ReturnStatNode(StatNode):
UtilityCode.load_cached("ReturnWithStopIteration", "Coroutine.c")) UtilityCode.load_cached("ReturnWithStopIteration", "Coroutine.c"))
code.putln("%s = NULL; __Pyx_ReturnWithStopIteration(%s);" % ( code.putln("%s = NULL; __Pyx_ReturnWithStopIteration(%s);" % (
Naming.retval_cname, Naming.retval_cname,
self.value.py_result())) value.py_result()))
self.value.generate_disposal_code(code) value.generate_disposal_code(code)
else: else:
self.value.make_owned_reference(code) value.make_owned_reference(code)
code.putln("%s = %s;" % ( code.putln("%s = %s;" % (
Naming.retval_cname, Naming.retval_cname,
self.value.result_as(self.return_type))) value.result_as(self.return_type)))
self.value.generate_post_assignment_code(code) value.generate_post_assignment_code(code)
self.value.free_temps(code) value.free_temps(code)
else: else:
if self.return_type.is_pyobject: if self.return_type.is_pyobject:
if self.in_generator: if self.in_generator:
......
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