diff options
| author | Dmitry Stogov <dmitry@zend.com> | 2015-01-28 06:56:19 +0300 |
|---|---|---|
| committer | Dmitry Stogov <dmitry@zend.com> | 2015-01-28 06:56:19 +0300 |
| commit | 638d0cb7531525201e00577d5a77f1da3f84811e (patch) | |
| tree | 79d288d48c40d0aa720158d43b053145b8c9fe73 /Zend/zend_opcode.c | |
| parent | 598c935245eca96ce93d1cc112cd8bbd1cf412c9 (diff) | |
| parent | c8576c5a46508ce87f7d2eb2442e6a9283b6a1ce (diff) | |
| download | php-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.c | 25 |
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) { |
