summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorBob Weinand <bobwei9@hotmail.com>2015-07-24 20:30:32 +0200
committerBob Weinand <bobwei9@hotmail.com>2015-07-24 20:31:18 +0200
commit2eb845d0fa21a8ee0bce4c53ac9f1a5743a56aac (patch)
tree8f962fb7f05b9ce023adae0e1bbe63015050520b
parent352bf686ce8da93d7a8852eb275da2dccbdbca62 (diff)
downloadphp-git-2eb845d0fa21a8ee0bce4c53ac9f1a5743a56aac.tar.gz
Fix bug using not set temporary with typed generator returns
-rw-r--r--Zend/tests/generators/generator_return_return_type.phpt17
-rw-r--r--Zend/zend_opcode.c6
2 files changed, 22 insertions, 1 deletions
diff --git a/Zend/tests/generators/generator_return_return_type.phpt b/Zend/tests/generators/generator_return_return_type.phpt
new file mode 100644
index 0000000000..804542285f
--- /dev/null
+++ b/Zend/tests/generators/generator_return_return_type.phpt
@@ -0,0 +1,17 @@
+--TEST--
+Generators must return a valid variable with return type specified
+--FILE--
+<?php
+
+$gen = (function (): Generator {
+ return true;
+ yield;
+})();
+
+var_dump($gen->valid());
+var_dump($gen->getReturn());
+
+?>
+--EXPECT--
+bool(false)
+bool(true)
diff --git a/Zend/zend_opcode.c b/Zend/zend_opcode.c
index ba952a4867..c42f3807e4 100644
--- a/Zend/zend_opcode.c
+++ b/Zend/zend_opcode.c
@@ -583,7 +583,7 @@ static void zend_resolve_finally_call(zend_op_array *op_array, uint32_t op_num,
fast_call_var = op_array->opcodes[op_array->try_catch_array[i].finally_end].op1.var;
/* generate a FAST_CALL to finally block */
- start_op = get_next_op_number(op_array);
+ start_op = get_next_op_number(op_array);
opline = get_next_op(op_array);
opline->opcode = ZEND_FAST_CALL;
@@ -807,6 +807,10 @@ ZEND_API int pass_two(zend_op_array *op_array)
break;
case ZEND_VERIFY_RETURN_TYPE:
if (op_array->fn_flags & ZEND_ACC_GENERATOR) {
+ if (opline->op1_type != IS_UNUSED) {
+ (opline + 1)->op1 = opline->op1;
+ (opline + 1)->op1_type = opline->op1_type;
+ }
MAKE_NOP(opline);
}
break;