From: Stanislav Malyshev Date: Thu, 14 Mar 2002 12:18:01 +0000 (+0000) Subject: Fix call_user_function X-Git-Tag: php-4.3.0dev-ZendEngine2-Preview1~1419 X-Git-Url: https://granicus.if.org/sourcecode?a=commitdiff_plain;h=3af5b15f309727363a6247ef7d38494d5f7656a7;p=php Fix call_user_function --- diff --git a/Zend/zend_execute_API.c b/Zend/zend_execute_API.c index 944c2aac39..bed4fb9685 100644 --- a/Zend/zend_execute_API.c +++ b/Zend/zend_execute_API.c @@ -480,16 +480,16 @@ int call_user_function_ex(HashTable *function_table, zval **object_pp, zval *fun if (object_pp) { /* TBI!! new object handlers */ - if(!IS_ZEND_STD_OBJECT(**object_pp)) { - zend_error(E_WARNING, "Cannot use call_user_function on overloaded objects"); - return FAILURE; - } - if (Z_TYPE_PP(object_pp) == IS_OBJECT) { + if(!IS_ZEND_STD_OBJECT(**object_pp)) { + zend_error(E_WARNING, "Cannot use call_user_function on overloaded objects"); + return FAILURE; + } + function_table = &Z_OBJCE_PP(object_pp)->function_table; calling_scope = Z_OBJCE_PP(object_pp); } else if (Z_TYPE_PP(object_pp) == IS_STRING) { - zend_class_entry *ce; + zend_class_entry **ce; char *lc_class; int found; @@ -500,8 +500,8 @@ int call_user_function_ex(HashTable *function_table, zval **object_pp, zval *fun if (found == FAILURE) return FAILURE; - function_table = &ce->function_table; - calling_scope = ce; + function_table = &(*ce)->function_table; + calling_scope = *ce; object_pp = NULL; } else return FAILURE;