1
0
mirror of https://github.com/danog/amp.git synced 2024-12-11 17:09:40 +01:00
amp/lib/Iterator.php

41 lines
1.3 KiB
PHP
Raw Normal View History

2017-02-01 00:09:38 +01:00
<?php
namespace Amp;
/**
* 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 \Amp\Promise<bool>
2017-02-01 00:09:38 +01:00
*
* @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();
}