| Code Coverage | ||||||||||
| Classes and Traits | Functions and Methods | Lines | ||||||||
| Total |  | 100.00% | 1 / 1 |  | 100.00% | 1 / 1 | CRAP |  | 100.00% | 9 / 9 | 
| SystemException |  | 100.00% | 1 / 1 |  | 100.00% | 1 / 1 | 2 |  | 100.00% | 9 / 9 | 
| __construct($messageOrException = null , $code = null, \Exception $previous = null) |  | 100.00% | 1 / 1 | 2 |  | 100.00% | 9 / 9 | |||
| <?php | |
| /* Copyright (c) 2012, Geert Bergman (geert@scrivo.nl) | |
| * All rights reserved. | |
| * | |
| * Redistribution and use in source and binary forms, with or without | |
| * modification, are permitted provided that the following conditions are met: | |
| * | |
| * 1. Redistributions of source code must retain the above copyright notice, | |
| * this list of conditions and the following disclaimer. | |
| * 2. Redistributions in binary form must reproduce the above copyright notice, | |
| * this list of conditions and the following disclaimer in the documentation | |
| * and/or other materials provided with the distribution. | |
| * 3. Neither the name of "Scrivo" nor the names of its contributors may be | |
| * used to endorse or promote products derived from this software without | |
| * specific prior written permission. | |
| * | |
| * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" | |
| * AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE | |
| * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE | |
| * ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE | |
| * LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR | |
| * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF | |
| * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS | |
| * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN | |
| * CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) | |
| * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE | |
| * POSSIBILITY OF SUCH DAMAGE. | |
| * | |
| * $Id: SystemException.php 711 2013-07-04 12:05:36Z geert $ | |
| */ | |
| /** | |
| * Implementation of the \Scrivo\SystemException class. | |
| */ | |
| namespace Scrivo; | |
| /** | |
| * Class to represent an error raised due failure in Scrivo program logic. | |
| * | |
| * This class is for runtime errors of a technical nature that should normaly | |
| * not occur in script execution, with script termination as most the likely | |
| * course of action. For instance: | |
| * | |
| * * Division by zero where there was no user input. | |
| * * Illegal argument types. | |
| * * Index out of bounds. | |
| * | |
| * You can use these errors to discriminate between resource exceptions, | |
| * system exceptions and application exceptions to take appropriate | |
| * action: f.i. notify the system admin, send out bug report or prompt the | |
| * user for new input. | |
| */ | |
| class SystemException extends \Exception { | |
| /** | |
| * Construct a \Scrivo\SystemException. It is possible to create a | |
| * \Scrivo\SystemException based upon an existing exception: | |
| * | |
| * .... | |
| * } catch (\InvalidArgumentException $e) { | |
| * trhow \Scrivo\SystemException($e); | |
| * } | |
| * | |
| * or use the standard exception parameters: | |
| * | |
| * .... | |
| * } catch (\InvalidArgumentException $e) { | |
| * trhow \Scrivo\SystemException("Message", 123, $e); | |
| * } | |
| * | |
| * @param \Exception|string $messageOrException The error message or | |
| * original exception. | |
| * @param int $code Optional exception code if the first parameter was | |
| * an error string, else not applicable. | |
| * @param \Exception $previous Optional, the original exception if the | |
| * first parameter was an error string, else not applicable. | |
| */ | |
| public function __construct($messageOrException = null , $code = null, | |
| \Exception $previous = null) { | |
| if ($messageOrException instanceof \Exception) { | |
| parent::__construct($messageOrException->message, | |
| 0, $messageOrException); | |
| $this->code = $messageOrException->code; | |
| $this->file = $messageOrException->file; | |
| $this->line = $messageOrException->line; | |
| } else { | |
| parent::__construct($messageOrException, $code, $previous); | |
| } | |
| } | |
| } | |