mirror of
https://github.com/danog/amp.git
synced 2025-01-06 04:58:44 +01:00
43 lines
1.4 KiB
PHP
43 lines
1.4 KiB
PHP
|
<?php
|
||
|
|
||
|
namespace Amp;
|
||
|
|
||
|
use AsyncInterop\Promise;
|
||
|
|
||
|
/**
|
||
|
* Defines an asynchronous stream iterator that is designed to be used within a coroutine.
|
||
|
*/
|
||
|
interface Iterator {
|
||
|
/**
|
||
|
* Succeeds with true if an emitted value is available by calling getCurrent() or false if the stream has resolved.
|
||
|
* If the stream fails, the returned promise will fail with the same exception.
|
||
|
*
|
||
|
* @return \AsyncInterop\Promise<bool>
|
||
|
*
|
||
|
* @throws \Error If the prior promise returned from this method has not resolved.
|
||
|
* @throws \Throwable The exception used to fail the stream.
|
||
|
*/
|
||
|
public function advance(): Promise;
|
||
|
|
||
|
/**
|
||
|
* Gets the last emitted value or throws an exception if the stream has completed.
|
||
|
*
|
||
|
* @return mixed Value emitted from the stream.
|
||
|
*
|
||
|
* @throws \Error If the stream has resolved or advance() was not called before calling this method.
|
||
|
* @throws \Throwable The exception used to fail the stream.
|
||
|
*/
|
||
|
public function getCurrent();
|
||
|
|
||
|
/**
|
||
|
* Gets the result of the stream or throws the failure reason. Also throws an exception if the stream has
|
||
|
* not completed.
|
||
|
*
|
||
|
* @return mixed Final return value of the stream.
|
||
|
*
|
||
|
* @throws \Error If the stream has not completed.
|
||
|
* @throws \Throwable The exception used to fail the stream.
|
||
|
*/
|
||
|
public function getResult();
|
||
|
}
|