Coroutine::isCompleted
(PHP 8.6+, True Async 1.0)
php
public Coroutine::isCompleted(): boolChecks whether the coroutine has finished execution. A coroutine is considered completed on successful completion, on completion with an error, or on cancellation.
Return Value
bool -- true if the coroutine has finished execution.
Examples
Example #1 Checking completion
php
<?php
use function Async\spawn;
use function Async\await;
$coroutine = spawn(function() {
return "test";
});
var_dump($coroutine->isCompleted()); // bool(false)
await($coroutine);
var_dump($coroutine->isCompleted()); // bool(true)Example #2 Non-blocking readiness check
php
<?php
use function Async\spawn;
use function Async\suspend;
$tasks = [
spawn(fn() => file_get_contents('https://api1.example.com')),
spawn(fn() => file_get_contents('https://api2.example.com')),
];
// Wait until all are completed
while (true) {
$allDone = true;
foreach ($tasks as $task) {
if (!$task->isCompleted()) {
$allDone = false;
break;
}
}
if ($allDone) break;
suspend();
}See Also
- Coroutine::getResult -- Get the result
- Coroutine::getException -- Get the exception
- Coroutine::isCancelled -- Check cancellation