andrei Fri Oct 6 20:11:25 2006 UTC
Modified files:
/php-src/ext/standard type.c
Log:
Unicode support in is_callable().
http://cvs.php.net/viewvc.cgi/php-src/ext/standard/type.c?r1=1.44&r2=1.45&diff_format=u
Index: php-src/ext/standard/type.c
diff -u php-src/ext/standard/type.c:1.44 php-src/ext/standard/type.c:1.45
--- php-src/ext/standard/type.c:1.44 Mon Sep 25 01:37:55 2006
+++ php-src/ext/standard/type.c Fri Oct 6 20:11:25 2006
@@ -16,7 +16,7 @@
+----------------------------------------------------------------------+
*/
-/* $Id: type.c,v 1.44 2006/09/25 01:37:55 pollita Exp $ */
+/* $Id: type.c,v 1.45 2006/10/06 20:11:25 andrei Exp $ */
#include "php.h"
#include "php_incomplete_class.h"
@@ -441,31 +441,25 @@
}
/* }}} */
-/* {{{ proto bool is_callable(mixed var [, bool syntax_only [, string
callable_name]])
+/* {{{ proto bool is_callable(mixed var [, bool syntax_only [, string
callable_name]]) U
Returns true if var is callable. */
PHP_FUNCTION(is_callable)
{
- zval **var, **syntax_only, **callable_name;
+ zval *var, **callable_name;
zval name;
zend_bool retval;
- zend_bool syntax = 0;
- int argc=ZEND_NUM_ARGS();
+ zend_bool syntax_only = 0;
- if (argc < 1 || argc > 3 || zend_get_parameters_ex(argc, &var,
&syntax_only, &callable_name) == FAILURE) {
- WRONG_PARAM_COUNT;
- }
-
- if (argc > 1) {
- convert_to_boolean_ex(syntax_only);
- syntax = Z_BVAL_PP(syntax_only);
+ if (zend_parse_parameters(ZEND_NUM_ARGS() TSRMLS_CC, "z|bZ", &var,
+ &syntax_only,
&callable_name) == FAILURE) {
+ return;
}
- if (argc > 2) {
- retval = zend_is_callable(*var, syntax, &name);
- zval_dtor(*callable_name);
- **callable_name = name;
+ if (ZEND_NUM_ARGS() > 2) {
+ retval = zend_is_callable(var, syntax_only, &name);
+ REPLACE_ZVAL_VALUE(callable_name, &name, 0);
} else {
- retval = zend_is_callable(*var, syntax, NULL);
+ retval = zend_is_callable(var, syntax_only, NULL);
}
RETURN_BOOL(retval);
--
PHP CVS Mailing List (http://www.php.net/)
To unsubscribe, visit: http://www.php.net/unsub.php