summaryrefslogtreecommitdiff
path: root/Zend/zend_interfaces.c
diff options
context:
space:
mode:
authorDmitry Stogov <dmitry@php.net>2009-03-25 10:39:26 +0000
committerDmitry Stogov <dmitry@php.net>2009-03-25 10:39:26 +0000
commit4a4d739e49eb3e637eb01118696803cde374392c (patch)
tree8412fc4b3ecb72c701f4e2bab8a7a819b790aa05 /Zend/zend_interfaces.c
parentb42f9a7f7d59db44e63334454716dd94711de579 (diff)
downloadphp-git-4a4d739e49eb3e637eb01118696803cde374392c.tar.gz
Fixed bug #47699 (autoload and late static binding)
Diffstat (limited to 'Zend/zend_interfaces.c')
-rwxr-xr-xZend/zend_interfaces.c10
1 files changed, 9 insertions, 1 deletions
diff --git a/Zend/zend_interfaces.c b/Zend/zend_interfaces.c
index 96ef70f21f..10c4a356e1 100755
--- a/Zend/zend_interfaces.c
+++ b/Zend/zend_interfaces.c
@@ -84,7 +84,15 @@ ZEND_API zval* zend_call_method(zval **object_pp, zend_class_entry *obj_ce, zend
fcic.function_handler = *fn_proxy;
}
fcic.calling_scope = obj_ce;
- fcic.called_scope = object_pp ? obj_ce : EG(called_scope);
+ if (object_pp) {
+ fcic.called_scope = Z_OBJCE_PP(object_pp);
+ } else if (obj_ce &&
+ !(EG(called_scope) &&
+ instanceof_function(EG(called_scope), obj_ce TSRMLS_CC))) {
+ fcic.called_scope = obj_ce;
+ } else {
+ fcic.called_scope = EG(called_scope);
+ }
fcic.object_ptr = object_pp ? *object_pp : NULL;
result = zend_call_function(&fci, &fcic TSRMLS_CC);
}