Exception::getPrevious
(PHP 5 >= 5.3.0)
Exception::getPrevious — Возвращает предыдущее исключение
Описание
Возвращает предыдущее исключение (переданное третьим параметром в Exception::__construct()).
Список параметров
У этой функции нет параметров.
Возвращаемые значения
Возвращает предыдущее исключение(Exception) или NULL
если такового нет.
Примеры
Пример #1 Пример использования Exception::getPrevious()
Проходим по всем исключениям и поочередно выводим их
<?php
class MyCustomException extends Exception {}
function doStuff() {
try {
throw new InvalidArgumentException("Ты делаешь это неправильно!", 112);
} catch(Exception $e) {
throw new MyCustomException("Что-то случилось", 911, $e);
}
}
try {
doStuff();
} catch(Exception $e) {
do {
printf("%s:%d %s (%d) [%s]\n", $e->getFile(), $e->getLine(), $e->getMessage(), $e->getCode(), get_class($e));
} while($e = $e->getPrevious());
}
?>
Результатом выполнения данного примера будет что-то подобное:
/home/bjori/ex.php:8 Что-то случилось (911) [MyCustomException] /home/bjori/ex.php:6 Ты делаешь это неправильно! (112) [InvalidArgumentException]
- Функция Exception::__construct() - Создать исключение
- Функция Exception::getMessage() - Получает сообщение исключения
- Функция Exception::getPrevious() - Возвращает предыдущее исключение
- Функция Exception::getCode() - Получает код исключения
- Функция Exception::getFile() - Получает файл, в котором возникло исключение
- Функция Exception::getLine() - Получает строку, в которой возникло исключение
- Функция Exception::getTrace() - Получает трассировку стека
- Функция Exception::getTraceAsString() - Получает трассировку стека в виде строки
- Функция Exception::__toString() - Строковое представление исключения
- Функция Exception::__clone() - Клонировать исключение
Коментарии
/**
* Gets sequential array of all previously-chained errors
*
* @param Throwable $error
*
* @return Throwable[]
*/
function getChain(Throwable $error) : array
{
$chain = [];
do {
$chain[] = $error;
} while ($error = $error->getPrevious());
return $chain;
}