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;
zend_execute_data execute_data;
zval *method_name;
zval *params_array;
- int call_via_handler = 0, success;
- char *func_pos;
+ int call_via_handler = 0;
switch (fci->size) {
case sizeof(zend_fcall_info):
function_name_lc = zend_str_tolower_dup(fci->function_name->value.str.val, fci->function_name->value.str.len);
- success = zend_hash_find(fci->function_table, function_name_lc, fci->function_name->value.str.len+1, (void **) &EX(function_state).function);
- if (success==FAILURE && !fci->object_pp && (func_pos=strstr(function_name_lc, "::"))) {
- int class_name_lc_len = (int)(func_pos - function_name_lc);
- char *class_name_lc = estrndup(function_name_lc, class_name_lc_len);
- zend_class_entry **ce;
-
- success = zend_lookup_class(class_name_lc, class_name_lc_len, &ce TSRMLS_CC);
-
- efree(class_name_lc);
- if (success == SUCCESS) {
- int func_len = fci->function_name->value.str.len - class_name_lc_len - 2;
- func_pos += 2;
- fci->function_table = &(*ce)->function_table;
- calling_scope = *ce;
- fci->object_pp = NULL;
- success = zend_hash_find(fci->function_table, func_pos, func_len + 1, (void **) &EX(function_state).function);
- }
- }
-
- if (success==FAILURE) {
+ if (zend_hash_find(fci->function_table, function_name_lc, fci->function_name->value.str.len+1, (void **) &EX(function_state).function)==FAILURE) {
/* try calling __call */
if (calling_scope && calling_scope->__call) {
EX(function_state).function = calling_scope->__call;