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

47 lines
1.4 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-05-19 00:21:33 -04:00
* A placeholder value for the deferred result of an asynchronous computation
2014-09-22 16:47:48 -04:00
*/
interface Promise {
/**
* Notify the $cb callback when the promise resolves (whether successful or not)
2014-09-22 16:47:48 -04:00
*
* Implementations MUST invoke the $cb callback in error-first style, e.g.:
2014-09-22 16:47:48 -04:00
*
* <?php
* $promise->when(function(\Exception $error = null, $result = null) {
* if ($error) {
* // failed
* } else {
* // succeeded
* }
* });
*
* Implementations MUST return the current object instance.
*
* @param callable $cb An error-first callback to invoke upon promise resolution
* @param mixed $cbData Optional data to pass as a third parameter to $cb
* @return self
2014-09-22 16:47:48 -04:00
*/
public function when(callable $cb, $cbData = null);
2014-09-22 16:47:48 -04:00
/**
* Notify the $cb callback when resolution progress events are emitted
2014-09-22 16:47:48 -04:00
*
* Implementations MUST invoke $cb callback with a single update parameter, e.g.:
2014-09-22 16:47:48 -04:00
*
* <?php
* $promise->watch(function($update) { ... });
*
* Implementations MUST return the current object instance.
*
* @param callable $cb A callback to invoke when data updates are available
* @param mixed $cbData Optional data to pass as an additional parameter to $cb
* @return self
2014-09-22 16:47:48 -04:00
*/
public function watch(callable $cb, $cbData = null);
2014-09-22 16:47:48 -04:00
}