1
0
mirror of https://github.com/danog/amp.git synced 2025-01-22 05:11:42 +01:00
amp/lib/Failure.php

51 lines
1.3 KiB
PHP
Raw Normal View History

2014-09-22 16:47:48 -04:00
<?php
2014-09-22 22:38:32 -04:00
namespace Amp;
2014-09-22 16:47:48 -04:00
/**
2015-07-20 22:24:51 -04:00
* A rejected (failed) promise
2014-09-22 16:47:48 -04:00
*/
class Failure implements Promise {
private $error;
/**
* The error parameter used to fail a promisor must always be an exception
* instance. However, we cannot typehint this parameter in environments
* where PHP5.x compatibility is required because PHP7 Throwable
* instances will break the typehint.
2015-07-20 22:24:51 -04:00
*
* @param Exception $error
* @TODO Add Throwable typehint and remove conditional once PHP7 is required
*/
public function __construct($error) {
2015-07-20 22:24:51 -04:00
if ($error instanceof \Throwable || $error instanceof \Exception) {
$this->error = $error;
} else {
throw new \InvalidArgumentException(
2015-07-20 22:24:51 -04:00
"Throwable Exception instance required"
);
}
2014-09-22 16:47:48 -04:00
}
/**
2015-07-20 22:24:51 -04:00
* {@inheritdoc}
*
* NOTE: because this object represents a resolved Promise it will *always* invoke
* the specified $func callback immediately.
2014-09-22 16:47:48 -04:00
*/
public function when(callable $func, $data = null) {
2015-07-20 22:24:51 -04:00
\call_user_func($func, $this->error, $result = null, $data);
return $this;
2014-09-22 16:47:48 -04:00
}
/**
2015-07-20 22:24:51 -04:00
* {@inheritdoc}
*
* Does nothing; a resolved promise has no progress updates
2014-09-22 16:47:48 -04:00
*/
public function watch(callable $func, $data = null) {
return $this;
2014-09-22 16:47:48 -04:00
}
}