/* extended error handling function */
static void php_error_cb(int type, const char *error_filename, const uint error_lineno, const char *format, va_list orig_args)
{
- char buffer[1024];
+ char buffer[1024],buf2[1024],*alt_func = NULL;
int size = 0;
va_list args;
ELS_FETCH();
va_end(args);
buffer[sizeof(buffer) - 1] = 0;
+ if(strstr(format,"Call to undefined function:")) {
+ int dist,min,stat;
+ char *name,*str,*p;
+ char *string_key;
+ ulong num_key;
+
+ size = vsnprintf(buf2, sizeof(buf2) - 1, "%s", args);
+ buf2[sizeof(buf2) - 1] = 0;
+
+ str=estrdup(buf2);
+ for(p=str;*p;p++)
+ *p=tolower(*p);
+
+ min=5;
+ if(strlen(str)<10) min=3;
+ if(strlen(str)<6) min=2;
+
+ zend_hash_internal_pointer_reset(EG(function_table));
+ while(1) {
+ stat=zend_hash_get_current_key(EG(function_table),&string_key,&num_key);
+ if(stat==HASH_KEY_IS_STRING)
+ {
+ dist = fastest_levdist(str,string_key);
+ if(dist<=min) {
+ if(alt_func!=NULL) efree(alt_func);
+ alt_func=estrdup(string_key);
+ min=dist;
+ }
+ }
+ else if(stat==HASH_KEY_IS_LONG)
+ { /* empty */ }
+ else
+ break;
+ zend_hash_move_forward(EG(function_table));
+ }
+ efree(str);
+ }
+
if (!module_initialized || PG(log_errors)) {
char log_buffer[1024];
#endif
snprintf(log_buffer, 1024, "PHP %s: %s in %s on line %d", error_type_str, buffer, error_filename, error_lineno);
php_log_err(log_buffer);
+ if(alt_func) {
+ snprintf(log_buffer, 1024, " ( maybe you were looking for %s() instead of %s() ? )",alt_func,buf2);
+ php_log_err(log_buffer);
+ }
}
if (module_initialized && PG(display_errors)) {
char *prepend_string = INI_STR("error_prepend_string");
}
php_printf(error_format, error_type_str, buffer,
error_filename, error_lineno);
+ if(alt_func) {
+ php_printf(" ( maybe you were looking for <b>%s()</b> instead of <b>%s()</b> ? )<br>\n",alt_func,buf2);
+ }
if (append_string) {
PUTS(append_string);
}