summaryrefslogtreecommitdiff
path: root/Zend/zend_inheritance.c
diff options
context:
space:
mode:
authorDmitry Stogov <dmitry@zend.com>2018-10-19 13:21:31 +0300
committerDmitry Stogov <dmitry@zend.com>2018-10-19 13:21:31 +0300
commit03384cae3c46254ccfd5d703b408a0f1d011ee3c (patch)
tree7d042487db340a2266e13194529eef6167bb4635 /Zend/zend_inheritance.c
parent1257664ca2d1403a27e696808eb818c0b92a4eb3 (diff)
downloadphp-git-03384cae3c46254ccfd5d703b408a0f1d011ee3c.tar.gz
Don't initialize static_member_tables during start-up, when inherit internal classes.
Diffstat (limited to 'Zend/zend_inheritance.c')
-rw-r--r--Zend/zend_inheritance.c11
1 files changed, 7 insertions, 4 deletions
diff --git a/Zend/zend_inheritance.c b/Zend/zend_inheritance.c
index ed5a554fb6..174d814524 100644
--- a/Zend/zend_inheritance.c
+++ b/Zend/zend_inheritance.c
@@ -885,12 +885,11 @@ ZEND_API void zend_do_inheritance(zend_class_entry *ce, zend_class_entry *parent
dst = end + parent_ce->default_static_members_count;
ce->default_static_members_table = end;
}
- if (CE_STATIC_MEMBERS(parent_ce) == NULL) {
- ZEND_ASSERT(parent_ce->type == ZEND_INTERNAL_CLASS || (parent_ce->ce_flags & ZEND_ACC_IMMUTABLE));
- zend_class_init_statics(parent_ce);
- }
if (UNEXPECTED(parent_ce->type != ce->type)) {
/* User class extends internal */
+ if (CE_STATIC_MEMBERS(parent_ce) == NULL) {
+ zend_class_init_statics(parent_ce);
+ }
if (UNEXPECTED(zend_update_class_constants(parent_ce) != SUCCESS)) {
ZEND_ASSERT(0);
}
@@ -905,6 +904,10 @@ ZEND_API void zend_do_inheritance(zend_class_entry *ce, zend_class_entry *parent
}
} while (dst != end);
} else if (ce->type == ZEND_USER_CLASS) {
+ if (CE_STATIC_MEMBERS(parent_ce) == NULL) {
+ ZEND_ASSERT(parent_ce->ce_flags & ZEND_ACC_IMMUTABLE);
+ zend_class_init_statics(parent_ce);
+ }
src = CE_STATIC_MEMBERS(parent_ce) + parent_ce->default_static_members_count;
do {
dst--;