icingaweb2/library/Icinga/Exception/IcingaException.php

64 lines
1.6 KiB
PHP
Raw Normal View History

2014-08-22 10:23:12 +02:00
<?php
/* Icinga Web 2 | (c) 2013-2015 Icinga Development Team | GPLv2+ */
2014-08-22 10:23:12 +02:00
namespace Icinga\Exception;
use Exception;
use ReflectionClass;
2014-08-22 10:23:12 +02:00
class IcingaException extends Exception
{
/**
* Create a new exception
2014-08-22 10:23:12 +02:00
*
* @param string $message Exception message or exception format string
* @param mixed ...$arg Format string argument
*
* If there is at least one exception, the last one will be used for exception chaining.
2014-08-22 10:23:12 +02:00
*/
public function __construct($message)
2014-08-22 10:23:12 +02:00
{
$args = array_slice(func_get_args(), 1);
$exc = null;
foreach ($args as &$arg) {
if ($arg instanceof Exception) {
$exc = $arg;
}
}
parent::__construct(vsprintf($message, $args), 0, $exc);
}
/**
* Create the exception from an array of arguments
*
* @param array $args
*
* @return static
*/
public static function create(array $args)
{
$e = new ReflectionClass(get_called_class());
return $e->newInstanceArgs($args);
}
/**
* Return the given exception formatted as one-liner
*
* The format used is: %class% in %path%:%line% with message: %message%
*
* @param Exception $exception
*
* @return string
*/
public static function describe(Exception $exception)
{
return sprintf(
'%s in %s:%d with message: %s',
get_class($exception),
$exception->getFile(),
$exception->getLine(),
$exception->getMessage()
);
}
2014-08-22 10:23:12 +02:00
}