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

33 lines
1.0 KiB
PHP
Raw Normal View History

<?php
2016-08-15 23:46:26 -05:00
2016-05-24 11:47:14 -05:00
namespace Amp;
2016-06-01 11:37:12 -05:00
/**
2017-04-27 11:18:25 -05:00
* Defines an asynchronous iterator over a set of values that is designed to be used within a coroutine.
*
* @template-covariant TValue
2016-06-01 11:37:12 -05:00
*/
2018-06-18 20:00:01 +02:00
interface Iterator
{
2016-05-24 11:47:14 -05:00
/**
* Succeeds with true if an emitted value is available by calling getCurrent() or false if the iterator has
* resolved. If the iterator fails, the returned promise will fail with the same exception.
2016-05-26 18:20:05 -05:00
*
* @return \Amp\Promise<bool>
2016-05-27 15:44:01 -05:00
*
* @throws \Error If the prior promise returned from this method has not resolved.
* @throws \Throwable The exception used to fail the iterator.
2016-05-24 11:47:14 -05:00
*/
public function advance(): Promise;
/**
* Gets the last emitted value or throws an exception if the iterator has completed.
*
* @return TValue Value emitted from the iterator.
*
* @throws \Error If the iterator has resolved or advance() was not called before calling this method.
* @throws \Throwable The exception used to fail the iterator.
*/
public function getCurrent();
2016-05-24 11:47:14 -05:00
}