diff options
author | Nikita Popov <nikic@php.net> | 2016-02-12 17:58:12 +0100 |
---|---|---|
committer | Nikita Popov <nikic@php.net> | 2016-02-12 17:58:12 +0100 |
commit | d1b777bd992525ced913a033bd7fff9490614f52 (patch) | |
tree | 395480a3ff7ffd1c30e019fae67a344d5b59ea92 | |
parent | 44ed1cb5c053c290c607c2ec5249c6241c979d5a (diff) | |
parent | ccc06e252bdf4c54cb2c96dbcab9a2aeb933181c (diff) | |
download | php-git-d1b777bd992525ced913a033bd7fff9490614f52.tar.gz |
Merge branch 'PHP-7.0'
-rw-r--r-- | Zend/tests/generators/yield_from_by_reference.phpt | 12 | ||||
-rw-r--r-- | Zend/zend_compile.c | 5 |
2 files changed, 17 insertions, 0 deletions
diff --git a/Zend/tests/generators/yield_from_by_reference.phpt b/Zend/tests/generators/yield_from_by_reference.phpt new file mode 100644 index 0000000000..8412a32af5 --- /dev/null +++ b/Zend/tests/generators/yield_from_by_reference.phpt @@ -0,0 +1,12 @@ +--TEST-- +Yield from by reference is not supported +--FILE-- +<?php + +function &gen() { + yield from []; +} + +?> +--EXPECTF-- +Fatal error: Cannot use "yield from" inside a by-reference generator in %s on line %d diff --git a/Zend/zend_compile.c b/Zend/zend_compile.c index 2cb9ed08b4..83d042d6e7 100644 --- a/Zend/zend_compile.c +++ b/Zend/zend_compile.c @@ -6616,6 +6616,11 @@ void zend_compile_yield_from(znode *result, zend_ast *ast) /* {{{ */ zend_mark_function_as_generator(); + if (CG(active_op_array)->fn_flags & ZEND_ACC_RETURN_REFERENCE) { + zend_error_noreturn(E_COMPILE_ERROR, + "Cannot use \"yield from\" inside a by-reference generator"); + } + zend_compile_expr(&expr_node, expr_ast); zend_emit_op_tmp(result, ZEND_YIELD_FROM, &expr_node, NULL); } |