From: Nikita Popov Date: Wed, 2 Sep 2020 08:50:14 +0000 (+0200) Subject: Fix throwing of yield from related exceptions into generator X-Git-Tag: php-7.3.23RC1~12 X-Git-Url: https://granicus.if.org/sourcecode?a=commitdiff_plain;h=2e9e706a8271bbb42ad696c3383912facdd7d45f;p=php Fix throwing of yield from related exceptions into generator Use the general zend_generator_throw_exception() helper for this. Otherwise we don't handle the off-by-one opline correctly (should we maybe just stop doing that?) This is a followup to ad750c3bb6e7b48384c6265eb9d3bcf5b4000652, which fixed a different yield from exception handling problem that happened to show up in the same test case from oss-fuzz #25321. Now both issues should be fixed. --- diff --git a/Zend/tests/generators/yield_from_valid_exception.phpt b/Zend/tests/generators/yield_from_valid_exception.phpt index 3af35f53af..d3e054bfaf 100644 --- a/Zend/tests/generators/yield_from_valid_exception.phpt +++ b/Zend/tests/generators/yield_from_valid_exception.phpt @@ -15,7 +15,8 @@ class FooBar implements Iterator { function gen() { try { - yield from new FooBar; + // the fact that the yield from result is used is relevant. + var_dump(yield from new FooBar); } catch (Exception $e) { echo $e->getMessage(), "\n"; } diff --git a/Zend/zend_generators.c b/Zend/zend_generators.c index bb3260b11b..0ed92f4ca2 100644 --- a/Zend/zend_generators.c +++ b/Zend/zend_generators.c @@ -740,7 +740,7 @@ static int zend_generator_get_next_delegated_value(zend_generator *generator) /* return SUCCESS; exception: - zend_rethrow_exception(generator->execute_data); + zend_generator_throw_exception(generator, NULL); failure: zval_ptr_dtor(&generator->values);