1
0
mirror of https://github.com/danog/amp.git synced 2024-12-16 11:27:12 +01:00
amp/lib/PublicPromisor.php

66 lines
1.6 KiB
PHP
Raw Normal View History

<?php
namespace Amp;
trait PublicPromisor {
use Placeholder;
/**
* Promise future fulfillment via a temporary placeholder value
*
* This implementation acts as both Promisor and Promise so we simply return the
* current instance.
*
* @return \Amp\Promise
*/
public function promise() {
return $this;
}
/**
* Update watchers of progress resolving the promised value
*
2015-06-01 01:33:55 +02:00
* @param mixed $progress1, $progress2, ... $progressN
* @return void
*/
public function update($progress) {
if ($this->isResolved) {
throw new \LogicException(
2015-07-21 18:25:34 +02:00
"Cannot update resolved promise"
);
}
2015-06-01 01:33:55 +02:00
$baseArgs = func_get_args();
foreach ($this->watchers as $watcher) {
2015-06-01 01:33:55 +02:00
$args = $baseArgs;
$args[] = $watcher[1];
\call_user_func_array($watcher[0], $args);
}
}
/**
* Resolve the promised value as a success
*
* @param mixed $result
* @return void
*/
public function succeed($result = null) {
$this->resolve($error = null, $result);
}
/**
* Resolve the promised value as a failure
*
* 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.
*
* @param mixed $error An Exception or Throwable in PHP7 environments
* @return void
*/
public function fail($error) {
$this->resolve($error, $result = null);
}
}