diff options
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); } } |