1
0
mirror of https://github.com/danog/amp.git synced 2025-01-22 13:21:16 +01:00
amp/lib/Observable.php

24 lines
937 B
PHP
Raw Normal View History

2016-08-17 22:25:54 -05:00
<?php declare(strict_types = 1);
2016-08-15 23:46:26 -05:00
2016-05-24 11:47:14 -05:00
namespace Amp;
2016-11-14 13:59:21 -06:00
use Interop\Async\Promise;
2016-05-29 11:35:09 -05:00
2016-06-01 11:37:12 -05:00
/**
* Represents a set of asynchronous values. An observable is analogous to an asynchronous generator, yielding (emitting)
* values when they are available, returning a value (success value) when the observable completes or throwing an
* exception (failure reason).
*/
2016-11-14 13:59:21 -06:00
interface Observable extends Promise {
2016-05-24 11:47:14 -05:00
/**
2016-05-27 15:44:01 -05:00
* Registers a callback to be invoked each time value is emitted from the observable. If the function returns an
2016-11-14 13:59:21 -06:00
* promise, back-pressure is applied to the promise until the returned promise is resolved.
2016-05-26 18:20:05 -05:00
*
2016-11-14 13:59:21 -06:00
* Exceptions thrown from $onNext (or failures of promises returned from $onNext) will fail the returned
* Subscriber with the thrown exception.
2016-05-27 15:44:01 -05:00
*
* @param callable $onNext Function invoked each time a value is emitted from the observable.
2016-05-24 11:47:14 -05:00
*/
2016-08-17 21:11:03 -05:00
public function subscribe(callable $onNext);
2016-05-24 11:47:14 -05:00
}