Scope::setChildScopeExceptionHandler
(PHP 8.6+, True Async 1.0)
public function setChildScopeExceptionHandler(callable $exceptionHandler): void
Sets an exception handler for exceptions thrown in child scopes. When a child scope finishes with an error, this handler is called, preventing the exception from propagating to the parent scope.
Parameters
exceptionHandler — the exception handling function for child scopes. Accepts a \Throwable as an argument.
Return Value
No value is returned.
Examples
Example #1 Catching child scope errors
<?php
use Async\Scope;
$parentScope = new Scope();
$parentScope->setChildScopeExceptionHandler(function(\Throwable $e) {
error_log("Error in child scope: " . $e->getMessage());
});
$childScope = Scope::inherit($parentScope);
$childScope->spawn(function() {
throw new \RuntimeException("Child scope error");
});
$childScope->awaitCompletion();
// Error handled, does not propagate to $parentScope
Example #2 Isolating errors between modules
<?php
use Async\Scope;
$appScope = new Scope();
$appScope->setChildScopeExceptionHandler(function(\Throwable $e) {
error_log("[App] Module error: " . $e->getMessage());
});
// Each module in its own scope
$authScope = Scope::inherit($appScope);
$cacheScope = Scope::inherit($appScope);
$authScope->spawn(function() {
// An error here will not affect $cacheScope
throw new \RuntimeException("Auth failed");
});
$cacheScope->spawn(function() {
echo "Cache is working fine\n";
});
$appScope->awaitCompletion();
See Also
- Scope::setExceptionHandler — Exception handler for coroutines
- Scope::inherit — Create a child scope
- Scope::getChildScopes — Get child scopes