2020-08-23 09:18:28 -05:00
|
|
|
<?php
|
|
|
|
|
|
|
|
namespace Amp;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* A pipeline is an asynchronous set of ordered values.
|
|
|
|
*
|
|
|
|
* @template-covariant TValue
|
|
|
|
*/
|
2020-11-10 12:05:47 -06:00
|
|
|
interface Pipeline extends \Traversable
|
2020-08-23 09:18:28 -05:00
|
|
|
{
|
|
|
|
/**
|
2020-11-10 12:05:47 -06:00
|
|
|
* Returns the emitted value if the pipeline has emitted a value or null if the pipeline has completed.
|
|
|
|
* If the pipeline fails, the exception will be thrown from this method.
|
|
|
|
*
|
2021-04-04 13:31:08 -05:00
|
|
|
* This method exists primarily for async consumption using Revolt\Future\spawn(fn() => $pipeline->continue()).
|
2020-08-23 09:18:28 -05:00
|
|
|
*
|
2020-09-24 22:14:58 -05:00
|
|
|
* @return mixed Returns null if the pipeline has completed.
|
2020-08-23 09:18:28 -05:00
|
|
|
*
|
2020-11-10 13:28:43 -06:00
|
|
|
* @psalm-return TValue|null
|
2020-08-23 09:18:28 -05:00
|
|
|
*
|
|
|
|
* @throws \Throwable The exception used to fail the pipeline.
|
|
|
|
*/
|
2020-09-24 22:14:58 -05:00
|
|
|
public function continue(): mixed;
|
2020-08-23 09:18:28 -05:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Disposes of the pipeline, indicating the consumer is no longer interested in the pipeline output.
|
|
|
|
*
|
|
|
|
* @return void
|
|
|
|
*/
|
2020-09-24 11:52:22 -05:00
|
|
|
public function dispose(): void;
|
2020-08-23 09:18:28 -05:00
|
|
|
}
|