diff options
author | Dmitry Stogov <dmitry@zend.com> | 2015-02-20 13:28:26 +0300 |
---|---|---|
committer | Dmitry Stogov <dmitry@zend.com> | 2015-02-20 13:28:26 +0300 |
commit | d85113702cc6030a9149f518c55953ccb6933a7c (patch) | |
tree | d203e105d433a87050fca191298d1757d4aeeaba /ext/reflection/php_reflection.c | |
parent | 582aa41d6fb7bf803b5d731ec9f5d6627d01c4c7 (diff) | |
download | php-git-d85113702cc6030a9149f518c55953ccb6933a7c.tar.gz |
Lazy duplication of op_array->static_variables
Diffstat (limited to 'ext/reflection/php_reflection.c')
-rw-r--r-- | ext/reflection/php_reflection.c | 6 |
1 files changed, 6 insertions, 0 deletions
diff --git a/ext/reflection/php_reflection.c b/ext/reflection/php_reflection.c index 1f16c4da78..80e04046ed 100644 --- a/ext/reflection/php_reflection.c +++ b/ext/reflection/php_reflection.c @@ -1852,6 +1852,12 @@ ZEND_METHOD(reflection_function, getStaticVariables) /* Return an empty array in case no static variables exist */ array_init(return_value); if (fptr->type == ZEND_USER_FUNCTION && fptr->op_array.static_variables != NULL) { + if (GC_REFCOUNT(fptr->op_array.static_variables) > 1) { + if (!(GC_FLAGS(fptr->op_array.static_variables) & IS_ARRAY_IMMUTABLE)) { + GC_REFCOUNT(fptr->op_array.static_variables)--; + } + fptr->op_array.static_variables = zend_array_dup(fptr->op_array.static_variables); + } zend_hash_apply_with_argument(fptr->op_array.static_variables, (apply_func_arg_t) zval_update_constant_inline_change, fptr->common.scope); zend_hash_copy(Z_ARRVAL_P(return_value), fptr->op_array.static_variables, zval_add_ref); } |