Commit 3bfdb38f authored by Stefan Behnel's avatar Stefan Behnel

avoid "return"-ing from generator without NULL return value but no exception...

avoid "return"-ing from generator without NULL return value but no exception set (fails assertion in debug build)
parent 4af42443
...@@ -5501,13 +5501,11 @@ class ReturnStatNode(StatNode): ...@@ -5501,13 +5501,11 @@ class ReturnStatNode(StatNode):
have_gil=self.in_nogil_context) have_gil=self.in_nogil_context)
elif self.in_generator: elif self.in_generator:
# return value == raise StopIteration(value), but uncatchable # return value == raise StopIteration(value), but uncatchable
code.putln("%s = NULL;" % Naming.retval_cname) code.globalstate.use_utility_code(
if not self.value.is_none: UtilityCode.load_cached("ReturnWithStopIteration", "Generator.c"))
# CPython 3.3+ crashes in yield-from when the StopIteration is not instantiated code.putln("%s = NULL; __Pyx_ReturnWithStopIteration(%s);" % (
code.globalstate.use_utility_code( Naming.retval_cname,
UtilityCode.load_cached("ReturnWithStopIteration", "Generator.c")) self.value.py_result()))
code.putln("__Pyx_ReturnWithStopIteration(%s);" % (
self.value.py_result()))
self.value.generate_disposal_code(code) self.value.generate_disposal_code(code)
else: else:
self.value.make_owned_reference(code) self.value.make_owned_reference(code)
......
...@@ -755,7 +755,8 @@ static int __pyx_Generator_init(void) { ...@@ -755,7 +755,8 @@ static int __pyx_Generator_init(void) {
#if CYTHON_COMPILING_IN_CPYTHON #if CYTHON_COMPILING_IN_CPYTHON
// CPython 3.3+ crashes in yield-from when the StopIteration is not instantiated // CPython 3.3+ crashes in yield-from when the StopIteration is not instantiated
#define __Pyx_ReturnWithStopIteration(value) if (value == Py_None); else __Pyx__ReturnWithStopIteration(value) #define __Pyx_ReturnWithStopIteration(value) \
if (value == Py_None) PyErr_SetNone(PyExc_StopIteration); else __Pyx__ReturnWithStopIteration(value)
static void __Pyx__ReturnWithStopIteration(PyObject* value); /*proto*/ static void __Pyx__ReturnWithStopIteration(PyObject* value); /*proto*/
#else #else
#define __Pyx_ReturnWithStopIteration(value) PyErr_SetObject(PyExc_StopIteration, value) #define __Pyx_ReturnWithStopIteration(value) PyErr_SetObject(PyExc_StopIteration, value)
......
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