1
0
mirror of https://github.com/danog/amp.git synced 2024-12-12 01:19:46 +01:00
amp/examples/pipeline/async-generator.php

43 lines
1.6 KiB
PHP
Raw Normal View History

2020-05-13 17:15:21 +02:00
#!/usr/bin/env php
<?php
require __DIR__ . '/../../vendor/autoload.php';
use Amp\AsyncGenerator;
use Amp\Delayed;
use Amp\Loop;
Loop::run(function () {
try {
/** @psalm-var AsyncGenerator<int, int, int> $generator */
2020-05-28 19:59:55 +02:00
$generator = new AsyncGenerator(function (callable $emit): \Generator {
$value = yield $emit(0);
$value = yield $emit(yield new Delayed(500, $value));
$value = yield $emit($value);
$value = yield $emit(yield new Delayed(300, $value));
$value = yield $emit($value);
$value = yield $emit($value);
$value = yield $emit(yield new Delayed(1000, $value));
$value = yield $emit($value);
$value = yield $emit($value);
$value = yield $emit(yield new Delayed(600, $value));
2020-05-13 17:15:21 +02:00
return $value;
});
2020-05-28 19:59:55 +02:00
// Use AsyncGenerator::continue() to get the first emitted value.
2020-05-21 17:11:22 +02:00
if (null !== $value = yield $generator->continue()) {
2020-05-13 17:15:21 +02:00
\printf("Async Generator yielded %d\n", $value);
2020-05-28 19:59:55 +02:00
// Use AsyncGenerator::send() to send values into the generator and get the next emitted value.
2020-05-21 17:11:22 +02:00
while (null !== $value = yield $generator->send($value + 1)) {
\printf("Async Generator yielded %d\n", $value);
yield new Delayed(100); // Listener consumption takes 100 ms.
}
2020-05-13 17:15:21 +02:00
}
\printf("Async Generator returned %d\n", yield $generator->getReturn());
} catch (\Exception $exception) {
\printf("Exception: %s\n", (string) $exception);
}
});