From: Dmitry Stogov Date: Thu, 21 Feb 2008 15:14:27 +0000 (+0000) Subject: Fixed bug #43483 (get_class_methods() does not list all visible methods) X-Git-Tag: BEFORE_NEW_PARAMETER_PARSE~768 X-Git-Url: https://granicus.if.org/sourcecode?a=commitdiff_plain;h=18cc21c66266b86ba255301c25cfb08de786f112;p=php Fixed bug #43483 (get_class_methods() does not list all visible methods) --- diff --git a/Zend/tests/bug43483.phpt b/Zend/tests/bug43483.phpt new file mode 100644 index 0000000000..0cfbfe8780 --- /dev/null +++ b/Zend/tests/bug43483.phpt @@ -0,0 +1,24 @@ +--TEST-- +Bug #43483 (get_class_methods() does not list all visible methods) +--FILE-- + +--EXPECT-- +Successfully called D::prot(). +Array +( + [0] => prot + [1] => test +) diff --git a/Zend/zend_builtin_functions.c b/Zend/zend_builtin_functions.c index f450e57436..c30163a0b0 100644 --- a/Zend/zend_builtin_functions.c +++ b/Zend/zend_builtin_functions.c @@ -910,7 +910,7 @@ ZEND_FUNCTION(get_class_methods) if ((mptr->common.fn_flags & ZEND_ACC_PUBLIC) || (EG(scope) && (((mptr->common.fn_flags & ZEND_ACC_PROTECTED) && - instanceof_function(EG(scope), mptr->common.scope TSRMLS_CC)) + zend_check_protected(mptr->common.scope, EG(scope))) || ((mptr->common.fn_flags & ZEND_ACC_PRIVATE) && EG(scope) == mptr->common.scope)))) { char *key;