diff options
| author | Xinchen Hui <laruence@php.net> | 2011-11-24 09:16:11 +0000 |
|---|---|---|
| committer | Xinchen Hui <laruence@php.net> | 2011-11-24 09:16:11 +0000 |
| commit | e0137255164d3eb544efd9737ebb5f76477e7f33 (patch) | |
| tree | 5ed0818c832ef9312ffc39e5ffcdd5f12d2dda88 | |
| parent | da2797108fb854d13df2a11a4c0712bd5e656113 (diff) | |
| download | php-git-e0137255164d3eb544efd9737ebb5f76477e7f33.tar.gz | |
Fixed bug #60367 (Reflection and Late Static Binding)
| -rw-r--r-- | ext/reflection/php_reflection.c | 2 | ||||
| -rw-r--r-- | ext/reflection/tests/bug60367.phpt | 26 |
2 files changed, 27 insertions, 1 deletions
diff --git a/ext/reflection/php_reflection.c b/ext/reflection/php_reflection.c index 1e0386a601..754be1483c 100644 --- a/ext/reflection/php_reflection.c +++ b/ext/reflection/php_reflection.c @@ -2811,7 +2811,7 @@ ZEND_METHOD(reflection_method, invoke) fcc.initialized = 1; fcc.function_handler = mptr; fcc.calling_scope = obj_ce; - fcc.called_scope = obj_ce; + fcc.called_scope = intern->ce; fcc.object_ptr = object_ptr; result = zend_call_function(&fci, &fcc TSRMLS_CC); diff --git a/ext/reflection/tests/bug60367.phpt b/ext/reflection/tests/bug60367.phpt new file mode 100644 index 0000000000..31e8a2e947 --- /dev/null +++ b/ext/reflection/tests/bug60367.phpt @@ -0,0 +1,26 @@ +--TEST-- +Bug #60367 (Reflection and Late Static Binding) +--FILE-- +<?php +abstract class A { + + const WHAT = 'A'; + + public static function call() { + echo static::WHAT; + } + +} + +class B extends A { + + const WHAT = 'B'; + +} + +$method = new ReflectionMethod("b::call"); +$method->invoke(null); +$method = new ReflectionMethod("A::call"); +$method->invoke(null); +--EXPECTF-- +BA |
