diff options
| author | Andrei Zmievski <andrei@php.net> | 2001-03-02 20:22:14 +0000 | 
|---|---|---|
| committer | Andrei Zmievski <andrei@php.net> | 2001-03-02 20:22:14 +0000 | 
| commit | 80cdb812c197b8de68555c0003f576e7cb45bbcb (patch) | |
| tree | 77625b927e6d2d907f1374f4882f8a4e3d65de82 | |
| parent | de6c69f7167d1f07e3e15808c908d7f437036756 (diff) | |
| download | php-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.c | 23 | 
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, ¶ms) == 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); | 
