mirror of
https://github.com/danog/amp.git
synced 2024-11-30 04:29:08 +01:00
Subscriber no longer implements Awaitable
This commit is contained in:
parent
90d744537e
commit
32b4721c5e
@ -15,12 +15,12 @@ Loop::execute(Amp\coroutine(function () {
|
|||||||
|
|
||||||
$observable = $postponed->getObservable();
|
$observable = $postponed->getObservable();
|
||||||
|
|
||||||
$subscriber = $observable->subscribe(function ($value) {
|
$observable->subscribe(function ($value) {
|
||||||
printf("Observable emitted %d\n", $value);
|
printf("Observable emitted %d\n", $value);
|
||||||
return new Pause(500); // Artificial back-pressure on observable.
|
return new Pause(500); // Artificial back-pressure on observable.
|
||||||
});
|
});
|
||||||
|
|
||||||
$subscriber->when(function ($exception, $value) {
|
$observable->when(function ($exception, $value) {
|
||||||
if ($exception) {
|
if ($exception) {
|
||||||
printf("Observable failed: %s\n", $exception->getMessage());
|
printf("Observable failed: %s\n", $exception->getMessage());
|
||||||
return;
|
return;
|
||||||
|
@ -67,13 +67,11 @@ trait Producer {
|
|||||||
if ($this->result !== null) {
|
if ($this->result !== null) {
|
||||||
return new Subscriber(
|
return new Subscriber(
|
||||||
$this->nextId++,
|
$this->nextId++,
|
||||||
$this->result instanceof Awaitable ? $this->result : new Success($this->result),
|
|
||||||
$this->unsubscribe
|
$this->unsubscribe
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
$id = $this->nextId++;
|
$id = $this->nextId++;
|
||||||
$this->futures[$id] = $future = new Future;
|
|
||||||
$this->subscribers[$id] = $onNext;
|
$this->subscribers[$id] = $onNext;
|
||||||
|
|
||||||
if ($this->waiting !== null) {
|
if ($this->waiting !== null) {
|
||||||
@ -82,26 +80,23 @@ trait Producer {
|
|||||||
$waiting->resolve();
|
$waiting->resolve();
|
||||||
}
|
}
|
||||||
|
|
||||||
return new Subscriber($id, $future, $this->unsubscribe);
|
return new Subscriber($id, $this->unsubscribe);
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @param string $id
|
* @param string $id
|
||||||
* @param \Throwable|\Exception|null $exception
|
* @param \Throwable|\Exception|null $exception
|
||||||
*/
|
*/
|
||||||
if (!isset($this->futures[$id])) {
|
|
||||||
private function unsubscribe($id, $exception = null) {
|
private function unsubscribe($id, $exception = null) {
|
||||||
|
if (!isset($this->subscribers[$id])) {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
$future = $this->futures[$id];
|
unset($this->subscribers[$id]);
|
||||||
unset($this->subscribers[$id], $this->futures[$id]);
|
|
||||||
|
|
||||||
if (empty($this->subscribers)) {
|
if (empty($this->subscribers)) {
|
||||||
$this->waiting = new Future;
|
$this->waiting = new Future;
|
||||||
}
|
}
|
||||||
|
|
||||||
$future->fail($exception ?: new UnsubscribedException);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@ -196,9 +191,8 @@ trait Producer {
|
|||||||
*
|
*
|
||||||
* @throws \LogicException If the observable has already been resolved.
|
* @throws \LogicException If the observable has already been resolved.
|
||||||
*/
|
*/
|
||||||
$futures = $this->futures;
|
|
||||||
$this->subscribers = $this->futures = [];
|
|
||||||
private function resolve($value = null) {
|
private function resolve($value = null) {
|
||||||
|
$this->subscribers = [];
|
||||||
|
|
||||||
if ($this->waiting !== null) {
|
if ($this->waiting !== null) {
|
||||||
$waiting = $this->waiting;
|
$waiting = $this->waiting;
|
||||||
@ -207,9 +201,5 @@ trait Producer {
|
|||||||
}
|
}
|
||||||
|
|
||||||
$this->complete($value);
|
$this->complete($value);
|
||||||
|
|
||||||
foreach ($futures as $future) {
|
|
||||||
$future->resolve($value);
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -78,7 +78,7 @@ class Observer {
|
|||||||
$result = &$this->result;
|
$result = &$this->result;
|
||||||
$error = &$this->exception;
|
$error = &$this->exception;
|
||||||
|
|
||||||
$this->subscriber->when(static function ($exception, $value) use (&$deferred, &$result, &$error, &$resolved) {
|
$observable->when(static function ($exception, $value) use (&$deferred, &$result, &$error, &$resolved) {
|
||||||
$resolved = true;
|
$resolved = true;
|
||||||
|
|
||||||
if ($exception) {
|
if ($exception) {
|
||||||
|
@ -2,22 +2,15 @@
|
|||||||
|
|
||||||
namespace Amp;
|
namespace Amp;
|
||||||
|
|
||||||
use Interop\Async\Awaitable;
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Subscriber implementation returned from implementors of \Amp\Observable.
|
* Subscriber implementation returned from implementors of \Amp\Observable.
|
||||||
*/
|
*/
|
||||||
class Subscriber implements Awaitable {
|
class Subscriber {
|
||||||
/**
|
/**
|
||||||
* @var string
|
* @var string
|
||||||
*/
|
*/
|
||||||
private $id;
|
private $id;
|
||||||
|
|
||||||
/**
|
|
||||||
* @var \Interop\Async\Awaitable
|
|
||||||
*/
|
|
||||||
private $awaitable;
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @var callable
|
* @var callable
|
||||||
*/
|
*/
|
||||||
@ -25,24 +18,15 @@ class Subscriber implements Awaitable {
|
|||||||
|
|
||||||
/**
|
/**
|
||||||
* @param string $id
|
* @param string $id
|
||||||
* @param \Interop\Async\Awaitable $awaitable
|
|
||||||
* @param callable $unsubscribe
|
* @param callable $unsubscribe
|
||||||
*/
|
*/
|
||||||
public function __construct($id, Awaitable $awaitable, callable $unsubscribe) {
|
public function __construct($id, callable $unsubscribe) {
|
||||||
$this->id = $id;
|
$this->id = $id;
|
||||||
$this->awaitable = $awaitable;
|
|
||||||
$this->unsubscribe = $unsubscribe;
|
$this->unsubscribe = $unsubscribe;
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* {@inheritdoc}
|
* Unsubscribes from the Observable. No future values emitted by the Observable will be received.
|
||||||
*/
|
|
||||||
public function when(callable $onResolved) {
|
|
||||||
$this->awaitable->when($onResolved);
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* {@inheritdoc}
|
|
||||||
*/
|
*/
|
||||||
public function unsubscribe() {
|
public function unsubscribe() {
|
||||||
$unsubscribe = $this->unsubscribe;
|
$unsubscribe = $this->unsubscribe;
|
||||||
|
Loading…
Reference in New Issue
Block a user