Commit 92685f5b authored by Stefan Behnel's avatar Stefan Behnel

streamline iteration termination a bit

parent 9a2a051c
...@@ -2369,8 +2369,10 @@ class IteratorNode(ExprNode): ...@@ -2369,8 +2369,10 @@ class IteratorNode(ExprNode):
self.iter_func_ptr, self.iter_func_ptr,
self.py_result())) self.py_result()))
code.putln("if (unlikely(!%s)) {" % result_name) code.putln("if (unlikely(!%s)) {" % result_name)
code.putln("if (PyErr_Occurred()) {") code.putln("PyObject* exc_type = PyErr_Occurred();")
code.putln("if (likely(PyErr_ExceptionMatches(PyExc_StopIteration))) PyErr_Clear();") code.putln("if (exc_type) {")
code.putln("if (likely(exc_type == PyExc_StopIteration ||"
" PyErr_GivenExceptionMatches(exc_type, PyExc_StopIteration))) PyErr_Clear();")
code.putln("else %s" % code.error_goto(self.pos)) code.putln("else %s" % code.error_goto(self.pos))
code.putln("}") code.putln("}")
code.putln("break;") code.putln("break;")
...@@ -7714,15 +7716,15 @@ class YieldFromExprNode(YieldExprNode): ...@@ -7714,15 +7716,15 @@ class YieldFromExprNode(YieldExprNode):
# either error or sub-generator has normally terminated: return value => node result # either error or sub-generator has normally terminated: return value => node result
if self.result_is_used: if self.result_is_used:
# YieldExprNode has allocated the result temp for us # YieldExprNode has allocated the result temp for us
code.putln("if (__Pyx_PyGen_FetchStopIterationValue(&%s) < 0) %s" % ( code.putln("if (unlikely(__Pyx_PyGen_FetchStopIterationValue(&%s) < 0)) %s" % (
self.result(), self.result(),
code.error_goto(self.pos))) code.error_goto(self.pos)))
else: else:
code.putln("PyObject* exc_type = PyErr_Occurred();") code.putln("PyObject* exc_type = PyErr_Occurred();")
code.putln("if (exc_type) {") code.putln("if (exc_type) {")
code.putln("if (!PyErr_GivenExceptionMatches(exc_type, PyExc_StopIteration)) %s" % code.putln("if (likely(exc_type == PyExc_StopIteration ||"
code.error_goto(self.pos)) " PyErr_GivenExceptionMatches(exc_type, PyExc_StopIteration))) PyErr_Clear();")
code.putln("PyErr_Clear();") code.putln("else %s" % code.error_goto(self.pos))
code.putln("}") code.putln("}")
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