diff options
| author | Marcus Boerger <helly@php.net> | 2003-10-25 22:58:06 +0000 |
|---|---|---|
| committer | Marcus Boerger <helly@php.net> | 2003-10-25 22:58:06 +0000 |
| commit | 26bfe3f83a22b371fb2bf741600ab49d7ea39c04 (patch) | |
| tree | 20501dafa69cdf4df49af7c2e4293b7325767037 /Zend/zend_API.c | |
| parent | 46251fa3f80844c34b55787c81a5535463685621 (diff) | |
| download | php-git-26bfe3f83a22b371fb2bf741600ab49d7ea39c04.tar.gz | |
Add zend_make_callable() which allows to make zval's callable zval's.
At the moment this function only converts strings of the form class::method
to an array(class,method).
Diffstat (limited to 'Zend/zend_API.c')
| -rw-r--r-- | Zend/zend_API.c | 29 |
1 files changed, 28 insertions, 1 deletions
diff --git a/Zend/zend_API.c b/Zend/zend_API.c index f9a868ddda..a18de9fda7 100644 --- a/Zend/zend_API.c +++ b/Zend/zend_API.c @@ -1573,7 +1573,7 @@ ZEND_API int zend_disable_class(char *class_name, uint class_name_length TSRMLS_ return 1; } -zend_bool zend_is_callable(zval *callable, zend_bool syntax_only, char **callable_name) +ZEND_API zend_bool zend_is_callable(zval *callable, zend_bool syntax_only, char **callable_name) { char *lcname; zend_bool retval = 0; @@ -1685,6 +1685,33 @@ zend_bool zend_is_callable(zval *callable, zend_bool syntax_only, char **callabl } +ZEND_API zend_bool zend_make_callable(zval *callable, char **callable_name TSRMLS_DC) +{ + char *lcname, *func; + zend_bool retval = 0; + + if (zend_is_callable(callable, 0, callable_name)) { + return 1; + } + switch (Z_TYPE_P(callable)) { + case IS_STRING: + lcname = zend_str_tolower_dup(Z_STRVAL_P(callable), Z_STRLEN_P(callable)); + + if ((func = strstr(lcname, "::")) != NULL) { + zval_dtor(callable); + array_init(callable); + add_next_index_stringl(callable, lcname, func - lcname, 1); + func += 2; + add_next_index_stringl(callable, func, strlen(func), 1); + retval = 1; + } + efree(lcname); + break; + } + return retval; +} + + ZEND_API char *zend_get_module_version(char *module_name) { zend_module_entry *module; |
