From: Janusz Dobrowolski Date: Wed, 3 Sep 2008 21:17:08 +0000 (+0000) Subject: Fixed fatal error handling for php5. X-Git-Tag: 2.3-final~1484 X-Git-Url: https://delta.frontaccounting.com/gitweb/?a=commitdiff_plain;h=96a7ff2ca1ad19cd6c8e064da2184f4e2f4dce26;p=fa-stable.git Fixed fatal error handling for php5. --- diff --git a/includes/errors.inc b/includes/errors.inc index 04874a39..536d23ad 100644 --- a/includes/errors.inc +++ b/includes/errors.inc @@ -11,7 +11,6 @@ $msg_colors = array( //----------------------------------------------------------------------------- // Error handler - collects all php/user messages for // display in message box. -// FIX: fatal errors ? function error_handler($errno, $errstr, $file, $line) { global $messages; @@ -65,6 +64,7 @@ function error_box() { echo "
"; $before_box = ob_get_clean(); // save html content before error box // Necessary restart instead of get_contents/clean calls due to a bug in php 4.3.2 + register_shutdown_function('ob_end_flush'); ob_start('output_html'); echo "
"; } diff --git a/includes/session.inc b/includes/session.inc index 34e01cd2..9089c693 100644 --- a/includes/session.inc +++ b/includes/session.inc @@ -15,9 +15,9 @@ // Fatal errors are not send to error_handler, // so we must check the output if ($text && preg_match('/\bFatal error(<.*?>)?:(.*)/i', $text, $m)) { - $Ajax->aCommands = array(); // Don't update page on errors - - $messages[] = array(E_ERROR, $m[0], null, null); + $Ajax->aCommands = array(); // Don't update page via ajax on errors + $text = preg_replace('/\bFatal error(<.*?>)?:(.*)/i','', $text); + $messages[] = array(E_ERROR, $m[2], null, null); } $Ajax->run(); return in_ajax() ? fmt_errors() : ($before_box.fmt_errors().$text);