summaryrefslogtreecommitdiff
path: root/Zend/zend_opcode.c
diff options
context:
space:
mode:
authorDmitry Stogov <dmitry@zend.com>2015-01-28 06:56:19 +0300
committerDmitry Stogov <dmitry@zend.com>2015-01-28 06:56:19 +0300
commit638d0cb7531525201e00577d5a77f1da3f84811e (patch)
tree79d288d48c40d0aa720158d43b053145b8c9fe73 /Zend/zend_opcode.c
parent598c935245eca96ce93d1cc112cd8bbd1cf412c9 (diff)
parentc8576c5a46508ce87f7d2eb2442e6a9283b6a1ce (diff)
downloadphp-git-638d0cb7531525201e00577d5a77f1da3f84811e.tar.gz
Merge branch 'typed_returns' of github.com:morrisonlevi/php-src into test
* 'typed_returns' of github.com:morrisonlevi/php-src: Implement return types
Diffstat (limited to 'Zend/zend_opcode.c')
-rw-r--r--Zend/zend_opcode.c25
1 files changed, 19 insertions, 6 deletions
diff --git a/Zend/zend_opcode.c b/Zend/zend_opcode.c
index aa2abb2f6b..a6d041f131 100644
--- a/Zend/zend_opcode.c
+++ b/Zend/zend_opcode.c
@@ -367,18 +367,26 @@ ZEND_API void destroy_op_array(zend_op_array *op_array)
zend_llist_apply_with_argument(&zend_extensions, (llist_apply_with_arg_func_t) zend_extension_op_array_dtor_handler, op_array);
}
if (op_array->arg_info) {
- uint32_t num_args = op_array->num_args;
+ int32_t num_args = op_array->num_args;
+ zend_arg_info *arg_info = op_array->arg_info;
+ int32_t i;
+ if (op_array->fn_flags & ZEND_ACC_HAS_RETURN_TYPE) {
+ arg_info--;
+ num_args++;
+ }
if (op_array->fn_flags & ZEND_ACC_VARIADIC) {
num_args++;
}
- for (i = 0; i < num_args; i++) {
- zend_string_release(op_array->arg_info[i].name);
- if (op_array->arg_info[i].class_name) {
- zend_string_release(op_array->arg_info[i].class_name);
+ for (i = 0 ; i < num_args; i++) {
+ if (arg_info[i].name) {
+ zend_string_release(arg_info[i].name);
+ }
+ if (arg_info[i].class_name) {
+ zend_string_release(arg_info[i].class_name);
}
}
- efree(op_array->arg_info);
+ efree(arg_info);
}
}
@@ -762,6 +770,11 @@ ZEND_API int pass_two(zend_op_array *op_array)
case ZEND_FE_FETCH:
ZEND_PASS_TWO_UPDATE_JMP_TARGET(op_array, opline, opline->op2);
break;
+ case ZEND_VERIFY_RETURN_TYPE:
+ if (op_array->fn_flags & ZEND_ACC_GENERATOR) {
+ MAKE_NOP(opline);
+ }
+ break;
case ZEND_RETURN:
case ZEND_RETURN_BY_REF:
if (op_array->fn_flags & ZEND_ACC_GENERATOR) {