X-Git-Url: https://delta.frontaccounting.com/gitweb/?a=blobdiff_plain;ds=sidebyside;f=includes%2Ferrors.inc;h=bfa213d5514d96ab1ac59e87e22fa8ffcc2619ba;hb=af78fbb535a6fedbc2eb70a26ddc39739be2b986;hp=ed7f281ffbc56f31bab76d7edc7e1e0713646da3;hpb=da8311619dd73feae101d246a1957b972e00cbd2;p=fa-stable.git diff --git a/includes/errors.inc b/includes/errors.inc index ed7f281f..bfa213d5 100644 --- a/includes/errors.inc +++ b/includes/errors.inc @@ -1,25 +1,131 @@ . +***********************************************************************/ +$messages = array(); // container for system messages +$before_box = ''; // temporary container for output html data before error box + +//----------------------------------------------------------------------------- +// Error handler - collects all php/user messages for +// display in message box. + +function error_handler($errno, $errstr, $file, $line) { + global $messages, $go_debug; + + // skip well known warnings we don't care about. + // Please use restrainedly to not risk loss of important messages + $excluded_warnings = array('html_entity_decode', 'htmlspecialchars'); + foreach($excluded_warnings as $ref) { + if (strpos($errstr, $ref) !== false) { + return true; + } + } + + // error_reporting==0 when messages are set off with @ + if ($errno & error_reporting()) + $messages[] = array($errno, $errstr, $file, $line); + else if($errno&~E_NOTICE)// log all not displayed messages + error_log(user_company() . ':' . $_SESSION["wa_current_user"]->loginname.':' + . basename($file) .":$line: $errstr"); + + return true; +} +//------------------------------------------------------------------------------ +// Formats system messages before insert them into message