diff options
author | Marcus Boerger <helly@php.net> | 2003-10-24 18:24:28 +0000 |
---|---|---|
committer | Marcus Boerger <helly@php.net> | 2003-10-24 18:24:28 +0000 |
commit | 071eaf857633f36fb2b8748b3b08b3cac41f05bc (patch) | |
tree | 6c2bd2efc3fe0775017033609ad6d75bbf0fb565 /Zend/zend_API.c | |
parent | 074ca4539964d736f3a31a4fb10f4eabd77addfa (diff) | |
download | php-git-071eaf857633f36fb2b8748b3b08b3cac41f05bc.tar.gz |
Zend/ZEND_CHANGES
Diffstat (limited to 'Zend/zend_API.c')
-rw-r--r-- | Zend/zend_API.c | 17 |
1 files changed, 16 insertions, 1 deletions
diff --git a/Zend/zend_API.c b/Zend/zend_API.c index f9a868ddda..575d9daaa4 100644 --- a/Zend/zend_API.c +++ b/Zend/zend_API.c @@ -1588,8 +1588,23 @@ zend_bool zend_is_callable(zval *callable, zend_bool syntax_only, char **callabl return 1; lcname = zend_str_tolower_dup(Z_STRVAL_P(callable), Z_STRLEN_P(callable)); - if (zend_hash_exists(EG(function_table), lcname, Z_STRLEN_P(callable)+1)) + if (zend_hash_exists(EG(function_table), lcname, Z_STRLEN_P(callable)+1)) { retval = 1; + } else { + char *func_pos; + if ((func_pos=strstr(lcname, "::"))) { + int lcclass_len = (int)(func_pos - lcname); + char *lcclass = estrndup(lcname, lcclass_len); + zend_class_entry **ce; + + if (zend_lookup_class(lcclass, lcclass_len, &ce TSRMLS_CC) == SUCCESS) { + int func_len = Z_STRLEN_P(callable) - lcclass_len - 2; + func_pos += 2; + retval = zend_hash_exists(&(*ce)->function_table, func_pos, func_len + 1) ? 1 : 0; + } + efree(lcclass); + } + } efree(lcname); break; |