1
0
mirror of https://github.com/danog/parallel.git synced 2024-12-02 17:52:14 +01:00
parallel/lib/Sync/ExitFailure.php

61 lines
1.4 KiB
PHP
Raw Normal View History

2016-12-30 02:16:04 +01:00
<?php
2015-08-07 01:59:25 +02:00
namespace Amp\Parallel\Sync;
2015-08-07 01:59:25 +02:00
2018-10-21 17:54:46 +02:00
final class ExitFailure implements ExitResult
2018-10-07 16:50:45 +02:00
{
2016-08-26 17:10:03 +02:00
/** @var string */
2015-08-07 01:59:25 +02:00
private $type;
2016-08-26 17:10:03 +02:00
/** @var string */
2015-08-07 01:59:25 +02:00
private $message;
/** @var int|string */
2015-08-07 01:59:25 +02:00
private $code;
2016-08-26 17:10:03 +02:00
/** @var array */
2015-08-07 01:59:25 +02:00
private $trace;
/** @var self|null */
private $previous;
2018-10-07 16:50:45 +02:00
public function __construct(\Throwable $exception)
{
$this->type = \get_class($exception);
2015-08-07 01:59:25 +02:00
$this->message = $exception->getMessage();
$this->code = $exception->getCode();
$this->trace = $exception->getTraceAsString();
if ($previous = $exception->getPrevious()) {
$this->previous = new self($previous);
}
2015-08-07 01:59:25 +02:00
}
/**
* {@inheritdoc}
*/
2018-10-07 16:50:45 +02:00
public function getResult()
{
throw $this->createException();
}
private function createException(): PanicError
{
$previous = $this->previous ? $this->previous->createException() : null;
return new PanicError(
$this->type,
2016-08-18 18:04:48 +02:00
\sprintf(
'Uncaught %s in worker with message "%s" and code "%s"; use %s::getPanicTrace() '
. 'for the stack trace in the context',
2015-08-27 16:10:08 +02:00
$this->type,
$this->message,
$this->code,
PanicError::class
2015-08-27 16:10:08 +02:00
),
$this->trace,
$previous
2015-08-07 01:59:25 +02:00
);
}
2017-05-18 09:51:31 +02:00
}