X-Git-Url: https://vcs.fsf.org/?p=squirrelmail.git;a=blobdiff_plain;f=class%2Ferror.class.php;h=3c13df7b99f8163677d8a0e386515d2ca9c69bc3;hp=c741307effadc9887c7c187feb584ef8e6139305;hb=c404d448239826f2935fe804ed8b39b0a8918280;hpb=4ed31137c331d10be6d966762fa992f3ab915640 diff --git a/class/error.class.php b/class/error.class.php index c741307e..3c13df7b 100644 --- a/class/error.class.php +++ b/class/error.class.php @@ -219,7 +219,7 @@ class ErrorHandler { // Show the error immediate in case of fatal errors if ($iType == SQM_ERROR) { - if (!$this->header_sent || (isset($this->Template->values['header_sent']) && !$this->Template->values['header_sent'])) { + if (isset($this->Template->values['header_sent']) && !$this->Template->values['header_sent']) { // TODO replace this with template that can be assigned displayHtmlHeader(_("Error"),'',false); } @@ -228,6 +228,25 @@ 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 @@ -244,7 +263,11 @@ class ErrorHandler { } if (isset($this->Template->values['aErrors']) && count($this->Template->values['aErrors']) > 0) { - $this->aErrors = array_merge($this->aErrors, $this->Template->values['aErrors']); + foreach ($this->Template->values['aErrors'] as $err) { + if (!in_array($err, $this->aErrors, true)) { + $this->aErrors[] = $err; + } + } $this->Template->assign('aErrors',$this->aErrors); }