1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58
|
--TEST--
GH-16514: Nested generator in zend_test observer
--EXTENSIONS--
zend_test
--INI--
zend_test.observer.enabled=1
zend_test.observer.show_output=1
zend_test.observer.show_init_backtrace=1
--FILE--
<?php
class Foo {
public function __destruct() {
debug_print_backtrace();
}
}
function bar() {
yield from foo();
}
function foo() {
$foo = new Foo();
yield;
}
$gen = bar();
foreach ($gen as $dummy);
?>
--EXPECTF--
<!-- init '%sgh16514.php' -->
<!--
{main} %sgh16514.php
-->
<!-- init bar() -->
<!--
bar()
{main} %sgh16514.php
-->
<!-- init foo() -->
<!--
foo()
bar()
{main} %sgh16514.php
-->
<!-- init Foo::__destruct() -->
<!--
Foo::__destruct()
bar()
{main} %sgh16514.php
-->
<!-- init debug_print_backtrace() -->
<!--
debug_print_backtrace()
Foo::__destruct()
bar()
{main} %sgh16514.php
-->
#0 %s(%d): Foo->__destruct()
#1 %s(%d): bar()
|