X-Git-Url: https://vcs.fsf.org/?p=squirrelmail.git;a=blobdiff_plain;f=class%2Ferror.class.php;h=aabfedef1705ed8a731970ffda28df8698f79b47;hp=0f9f13c8ad300bd646159467e129b5558eae20d2;hb=4803e9cd9f30451ad96e034434d7816eacf25013;hpb=6c99d1de81366bceab6c9d6cf12179eedc81f9bc diff --git a/class/error.class.php b/class/error.class.php index 0f9f13c8..aabfedef 100644 --- a/class/error.class.php +++ b/class/error.class.php @@ -40,10 +40,13 @@ class ErrorHandler { * @since 1.5.1 */ function ErrorHandler(&$oTemplate, $sTemplateFile) { +# echo 'init error handler...'; $this->TemplateName = $sTemplateFile; $this->Template =& $oTemplate; $this->aErrors = array(); $this->header_sent = false; + $this->delayed_errors = false; + $this->Template->assign('delayed_errors', $this->delayed_errors); } /** @@ -60,8 +63,18 @@ class ErrorHandler { */ function HeaderSent() { $this->header_sent = true; + $this->Template->assign('header_sent', true); } + /** + * Turn on/off delayed error handling + * @since 1.5.2 + */ + function setDelayedErrors ($val = true) { + $this->delayed_errors = $val===true; + $this->Template->assign('delayed_errors', $this->delayed_errors); + } + /** * Store errors generated in a previous script but couldn't be displayed * due to a header redirect. This requires storing of aDelayedErrors in the session @@ -125,7 +138,7 @@ class ErrorHandler { $aError['message'] = $sErrStr; $aError['extra'] = array( 'FILE' => $sErrFile, - 'LINE' => $iErrLine) ;; + 'LINE' => $iErrLine) ; // what todo with $aContext? break; case E_USER_ERROR: @@ -181,6 +194,17 @@ class ErrorHandler { default: break; } + /** + * If delayed error handling is enabled, always record the location + * and tag the error is delayed to make debugging easier. + */ + if (isset($this->Template->values['delayed_errors']) && $this->Template->values['delayed_errors']) { + $aErrorCategory[] = 'Delayed'; + $aError['extra'] = array( + 'FILE' => $sErrFile, + 'LINE' => $iErrLine) ; + } + $aErrorTpl = array( 'type' => $iType, 'category' => $aErrorCategory, @@ -195,8 +219,15 @@ class ErrorHandler { // Show the error immediate in case of fatal errors if ($iType == SQM_ERROR) { - if (!$this->header_sent) { - // TODO replace this with template that can be assigned + if (isset($this->Template->values['header_sent']) && !$this->Template->values['header_sent']) { +// TODO replace this with template that can be assigned +// UPDATE: displayHtmlHeader() no longer sends anything +// directly to the browser itself and instead +// displays all output through the template file +// "protocol_header" as well as calls to the +// template's header() method, so perhaps the +// above TODO is alleviated?? (however, I don't fully +// understand the problem behind the TODO comment myself (Paul)) displayHtmlHeader(_("Error"),'',false); } $this->DisplayErrors(); @@ -204,14 +235,55 @@ class ErrorHandler { } } + /** + * Force the delayed errors to be stored in the session in case + * $this->displayErrors() never gets called, e.g. in compose.php + */ + function saveDelayedErrors () { + if($this->delayed_errors) { + // Check for previous delayed errors... + sqgetGlobalVar('delayed_errors', $delayed_errors, SQ_SESSION); + if (is_array($delayed_errors)) { + $this->AssignDelayedErrors($delayed_errors); + sqsession_unregister("delayed_errors"); + } + + if (count($this->aErrors) > 0) { + sqsession_register($this->aErrors,"delayed_errors"); + } + } + } + /** * Display the error array in the error template * @return void * @since 1.5.1 */ function DisplayErrors() { - if (count($this->aErrors)) { - $this->Template->display($this->TemplateName); + // Check for delayed errors... + if (!$this->delayed_errors) { + sqgetGlobalVar('delayed_errors', $delayed_errors, SQ_SESSION); + if (is_array($delayed_errors)) { + $this->AssignDelayedErrors($delayed_errors); + sqsession_unregister("delayed_errors"); + } + } + + if (isset($this->Template->values['aErrors']) && count($this->Template->values['aErrors']) > 0) { + foreach ($this->Template->values['aErrors'] as $err) { + if (!in_array($err, $this->aErrors, true)) { + $this->aErrors[] = $err; + } + } + $this->Template->assign('aErrors',$this->aErrors); + } + + if (count($this->aErrors) > 0) { + if ($this->delayed_errors) { + sqsession_register($this->aErrors,"delayed_errors"); + } else { + $this->Template->display($this->TemplateName); + } } } }