From: Ilia Alshanetsky Date: Mon, 20 Feb 2006 15:28:15 +0000 (+0000) Subject: MFB51: Fixed bug #36434 (Improper resolution of declaring class name of an X-Git-Tag: RELEASE_1_2~155 X-Git-Url: https://granicus.if.org/sourcecode?a=commitdiff_plain;h=3fa4bf210ff06ee18f6372b4af38f188315f5062;p=php MFB51: Fixed bug #36434 (Improper resolution of declaring class name of an inherited property). --- diff --git a/ext/reflection/php_reflection.c b/ext/reflection/php_reflection.c index f62b7453ff..d27f2a75cc 100644 --- a/ext/reflection/php_reflection.c +++ b/ext/reflection/php_reflection.c @@ -3809,11 +3809,19 @@ ZEND_METHOD(reflection_property, getDeclaringClass) { reflection_object *intern; property_reference *ref; + zend_class_entry *tmp_ce, *ce; + zend_property_info *tmp_info; METHOD_NOTSTATIC_NUMPARAMS(reflection_property_ptr, 0); GET_REFLECTION_OBJECT_PTR(ref); - zend_reflection_class_factory(ref->ce, return_value TSRMLS_CC); + ce = tmp_ce = ref->ce; + while (tmp_ce && zend_hash_find(&tmp_ce->properties_info, ref->prop->name, ref->prop->name_length + 1, (void **) &tmp_info) == SUCCESS) { + ce = tmp_ce; + tmp_ce = tmp_ce->parent; + } + + zend_reflection_class_factory(ce, return_value TSRMLS_CC); } /* {{{ proto public string ReflectionProperty::getDocComment()