diff options
author | Dmitry Stogov <dmitry@zend.com> | 2012-11-20 12:51:55 +0400 |
---|---|---|
committer | Dmitry Stogov <dmitry@zend.com> | 2012-11-20 12:51:55 +0400 |
commit | 396c1e990a0e513cf2e8510e9b6f82ab425c9e3a (patch) | |
tree | 14053627cff9dd623625c3540d37cefb9a2e3b7a | |
parent | d412152f31f145bf07b243465cdffa84ceba70be (diff) | |
download | php-git-396c1e990a0e513cf2e8510e9b6f82ab425c9e3a.tar.gz |
Fixed bug #63468 (wrong called method as callback with inheritance)
-rw-r--r-- | NEWS | 2 | ||||
-rw-r--r-- | Zend/tests/bug63468.phpt | 30 | ||||
-rw-r--r-- | Zend/zend_API.c | 2 |
3 files changed, 33 insertions, 1 deletions
@@ -5,6 +5,8 @@ PHP NEWS - Zend Engine: . Fixed bug #63512 (parse_ini_file() with INI_SCANNER_RAW removes quotes from value). (Pierrick) + . Fixed bug #63468 (wrong called method as callback with inheritance). + (Laruence) - Core: . Fixed bug #63451 (config.guess file does not have AIX 7 defined, shared objects are not created). (kemcline at au1 dot ibm dot com) diff --git a/Zend/tests/bug63468.phpt b/Zend/tests/bug63468.phpt new file mode 100644 index 0000000000..00b5a41c90 --- /dev/null +++ b/Zend/tests/bug63468.phpt @@ -0,0 +1,30 @@ +--TEST-- +Bug #63468 (wrong called method as callback with inheritance) +--FILE-- +<?php +class Foo +{ + public function run() + { + return call_user_func(array('Bar', 'getValue')); + } + + private static function getValue() + { + return 'Foo'; + } +} + +class Bar extends Foo +{ + public static function getValue() + { + return 'Bar'; + } +} + +$x = new Bar; +var_dump($x->run()); +--EXPECT-- +string(3) "Bar" + diff --git a/Zend/zend_API.c b/Zend/zend_API.c index d529775764..c1b501b0b7 100644 --- a/Zend/zend_API.c +++ b/Zend/zend_API.c @@ -2520,7 +2520,7 @@ static int zend_is_callable_check_func(int check_flags, zval *callable, zend_fca } else if (zend_hash_find(ftable, lmname, mlen+1, (void**)&fcc->function_handler) == SUCCESS) { retval = 1; if ((fcc->function_handler->op_array.fn_flags & ZEND_ACC_CHANGED) && - EG(scope) && + !strict_class && EG(scope) && instanceof_function(fcc->function_handler->common.scope, EG(scope) TSRMLS_CC)) { zend_function *priv_fbc; |