diff options
author | Dmitry Stogov <dmitry@zend.com> | 2015-01-13 03:32:51 +0300 |
---|---|---|
committer | Dmitry Stogov <dmitry@zend.com> | 2015-01-13 03:32:51 +0300 |
commit | dbe66fb2cf1d413268e66117b5b9be489e1a5b5d (patch) | |
tree | ea6cfcfb78d137f0278e8e24dbb8385fabc8153d /Zend/zend_opcode.c | |
parent | 0445974cb1e51135331a31b993487a3b5c594518 (diff) | |
download | php-git-dbe66fb2cf1d413268e66117b5b9be489e1a5b5d.tar.gz |
Improved access to static property. Now we cache pointers to zval instead of pointers to property_info.
Diffstat (limited to 'Zend/zend_opcode.c')
-rw-r--r-- | Zend/zend_opcode.c | 20 |
1 files changed, 8 insertions, 12 deletions
diff --git a/Zend/zend_opcode.c b/Zend/zend_opcode.c index 6e77716119..7b1232ab27 100644 --- a/Zend/zend_opcode.c +++ b/Zend/zend_opcode.c @@ -150,35 +150,31 @@ ZEND_API void zend_cleanup_user_class_data(zend_class_entry *ce) } ZEND_HASH_FOREACH_END(); } if (ce->static_members_table) { + zval *static_members = ce->static_members_table; int i; + ce->static_members_table = NULL; for (i = 0; i < ce->default_static_members_count; i++) { - if (Z_TYPE(ce->static_members_table[i]) != IS_UNDEF) { - zval tmp; - - ZVAL_COPY_VALUE(&tmp, &ce->static_members_table[i]); - ZVAL_UNDEF(&ce->static_members_table[i]); - zval_ptr_dtor(&tmp); - } + zval_ptr_dtor(&static_members[i]); } - ce->static_members_table = NULL; } } ZEND_API void zend_cleanup_internal_class_data(zend_class_entry *ce) { if (CE_STATIC_MEMBERS(ce)) { + zval *static_members = CE_STATIC_MEMBERS(ce); int i; - for (i = 0; i < ce->default_static_members_count; i++) { - zval_ptr_dtor(&CE_STATIC_MEMBERS(ce)[i]); - } - efree(CE_STATIC_MEMBERS(ce)); #ifdef ZTS CG(static_members_table)[(zend_intptr_t)(ce->static_members_table)] = NULL; #else ce->static_members_table = NULL; #endif + for (i = 0; i < ce->default_static_members_count; i++) { + zval_ptr_dtor(&static_members[i]); + } + efree(static_members); } } |