summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorAndrei Zmievski <andrei@php.net>2001-03-02 20:22:14 +0000
committerAndrei Zmievski <andrei@php.net>2001-03-02 20:22:14 +0000
commit80cdb812c197b8de68555c0003f576e7cb45bbcb (patch)
tree77625b927e6d2d907f1374f4882f8a4e3d65de82
parentde6c69f7167d1f07e3e15808c908d7f437036756 (diff)
downloadphp-git-80cdb812c197b8de68555c0003f576e7cb45bbcb.tar.gz
@- Forced call_user_method() and call_user_method_array() to take the
@ object argument by reference. (Andrei) * Forced call_user_method() and call_user_method_array() to take the object argument by reference. * Also cleaned up the protos for those functions and brought call_user_method_array() into functional equivalence with call_user_method().
-rw-r--r--ext/standard/basic_functions.c23
1 files changed, 14 insertions, 9 deletions
diff --git a/ext/standard/basic_functions.c b/ext/standard/basic_functions.c
index cf1300270b..bc58c05045 100644
--- a/ext/standard/basic_functions.c
+++ b/ext/standard/basic_functions.c
@@ -340,8 +340,8 @@ function_entry basic_functions[] = {
PHP_FE(error_log, NULL)
PHP_FE(call_user_func, NULL)
PHP_FE(call_user_func_array, NULL)
- PHP_FE(call_user_method, NULL)
- PHP_FE(call_user_method_array, NULL)
+ PHP_FE(call_user_method, second_arg_force_ref)
+ PHP_FE(call_user_method_array, second_arg_force_ref)
PHP_FE(var_dump, NULL)
PHP_FE(serialize, first_arg_allow_ref)
@@ -1651,8 +1651,8 @@ PHP_FUNCTION(call_user_func_array)
}
/* }}} */
-/* {{{ proto mixed call_user_method(string method_name, object object [, mixed parameter] [, mixed ...])
- Call a user method, on a specific object where the first argument is the method name, the second argument is the object and the subsequent arguments are the parameters */
+/* {{{ proto mixed call_user_method(string method_name, mixed object [, mixed parameter] [, mixed ...])
+ Call a user method on a specific object or class */
PHP_FUNCTION(call_user_method)
{
pval ***params;
@@ -1675,7 +1675,6 @@ PHP_FUNCTION(call_user_method)
RETURN_FALSE;
}
SEPARATE_ZVAL(params[0]);
- SEPARATE_ZVAL(params[1]);
convert_to_string(*params[0]);
if (call_user_function_ex(CG(function_table), params[1], *params[0], &retval_ptr, arg_count-2, params+2, 1, NULL)==SUCCESS
&& retval_ptr) {
@@ -1687,8 +1686,8 @@ PHP_FUNCTION(call_user_method)
}
/* }}} */
-/* {{{ proto mixed call_user_method_array(object obj, string methodname, array params)
- Call a user method using a parameter array */
+/* {{{ proto mixed call_user_method_array(string method_name, mixed object, array params)
+ Call a user method on a specific object or class using a parameter array */
PHP_FUNCTION(call_user_method_array)
{
zval **method_name,
@@ -1705,9 +1704,15 @@ PHP_FUNCTION(call_user_method_array)
zend_get_parameters_ex(3, &method_name, &obj, &params) == FAILURE) {
WRONG_PARAM_COUNT;
}
+
+ if (Z_TYPE_PP(obj) != IS_OBJECT && Z_TYPE_PP(obj) != IS_STRING) {
+ php_error(E_WARNING,"2nd argument is not an object or class name\n");
+ RETURN_FALSE;
+ }
+
+ SEPARATE_ZVAL(method_name);
+ SEPARATE_ZVAL(params);
convert_to_string_ex(method_name);
- if (Z_TYPE_PP(obj) != IS_OBJECT && Z_TYPE_PP(obj) != IS_STRING)
- convert_to_object_ex(obj);
convert_to_array_ex(params);
params_ar = HASH_OF(*params);