summaryrefslogtreecommitdiff
path: root/Zend/zend_opcode.c
diff options
context:
space:
mode:
authorDmitry Stogov <dmitry@zend.com>2015-01-13 03:32:51 +0300
committerDmitry Stogov <dmitry@zend.com>2015-01-13 03:32:51 +0300
commitdbe66fb2cf1d413268e66117b5b9be489e1a5b5d (patch)
treeea6cfcfb78d137f0278e8e24dbb8385fabc8153d /Zend/zend_opcode.c
parent0445974cb1e51135331a31b993487a3b5c594518 (diff)
downloadphp-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.c20
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);
}
}