diff options
| -rw-r--r-- | ext/reflection/php_reflection.c | 35 | ||||
| -rw-r--r-- | ext/reflection/tests/bug79487.phpt | 34 | 
2 files changed, 4 insertions, 65 deletions
| diff --git a/ext/reflection/php_reflection.c b/ext/reflection/php_reflection.c index b88712b7b5..0a116a0127 100644 --- a/ext/reflection/php_reflection.c +++ b/ext/reflection/php_reflection.c @@ -3845,7 +3845,9 @@ static void add_class_vars(zend_class_entry *ce, zend_bool statics, zval *return  	zend_string *key;  	ZEND_HASH_FOREACH_STR_KEY_PTR(&ce->properties_info, key, prop_info) { -		if (((prop_info->flags & ZEND_ACC_PRIVATE) && +		if (((prop_info->flags & ZEND_ACC_PROTECTED) && +		     !zend_check_protected(prop_info->ce, ce)) || +		    ((prop_info->flags & ZEND_ACC_PRIVATE) &&  		     prop_info->ce != ce)) {  			continue;  		} @@ -3883,9 +3885,6 @@ ZEND_METHOD(ReflectionClass, getStaticProperties)  {  	reflection_object *intern;  	zend_class_entry *ce; -	zend_property_info *prop_info; -	zval *prop; -	zend_string *key;  	if (zend_parse_parameters_none() == FAILURE) {  		RETURN_THROWS(); @@ -3897,34 +3896,8 @@ ZEND_METHOD(ReflectionClass, getStaticProperties)  		return;  	} -	if (!CE_STATIC_MEMBERS(ce)) { -		zend_class_init_statics(ce); -	} -  	array_init(return_value); - -	ZEND_HASH_FOREACH_STR_KEY_PTR(&ce->properties_info, key, prop_info) { -		if (((prop_info->flags & ZEND_ACC_PRIVATE) && -		     prop_info->ce != ce)) { -			continue; -		} -		if ((prop_info->flags & ZEND_ACC_STATIC) == 0) { -			continue; -		} - -		prop = &CE_STATIC_MEMBERS(ce)[prop_info->offset]; -		ZVAL_DEINDIRECT(prop); - -		if (prop_info->type && Z_ISUNDEF_P(prop)) { -			continue; -		} - -		/* enforce read only access */ -		ZVAL_DEREF(prop); -		Z_TRY_ADDREF_P(prop); - -		zend_hash_update(Z_ARRVAL_P(return_value), key, prop); -	} ZEND_HASH_FOREACH_END(); +	add_class_vars(ce, 1, return_value);  }  /* }}} */ diff --git a/ext/reflection/tests/bug79487.phpt b/ext/reflection/tests/bug79487.phpt deleted file mode 100644 index 5185c98bba..0000000000 --- a/ext/reflection/tests/bug79487.phpt +++ /dev/null @@ -1,34 +0,0 @@ ---TEST-- -Bug #79487 (::getStaticProperties() ignores property modifications) ---FILE-- -<?php -class Foo { -    public static $bar = 'orig'; -} - -Foo::$bar = 'new'; -$rc = new ReflectionClass('Foo'); -var_dump($rc->getStaticProperties()); - -class A { -  public static $a = 'A old'; -} -class B extends A { -  public static $b = 'B old'; -} - -$rc = new ReflectionClass(B::class); -A::$a = 'A new'; -var_dump($rc->getStaticProperties()); -?> ---EXPECT-- -array(1) { -  ["bar"]=> -  string(3) "new" -} -array(2) { -  ["b"]=> -  string(5) "B old" -  ["a"]=> -  string(5) "A new" -} | 
