1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071 |
- <?php
- declare(strict_types=1);
- namespace GuzzleHttp\Promise;
- /**
- * A task queue that executes tasks in a FIFO order.
- *
- * This task queue class is used to settle promises asynchronously and
- * maintains a constant stack size. You can use the task queue asynchronously
- * by calling the `run()` function of the global task queue in an event loop.
- *
- * GuzzleHttp\Promise\Utils::queue()->run();
- *
- * @final
- */
- class TaskQueue implements TaskQueueInterface
- {
- private $enableShutdown = true;
- private $queue = [];
- public function __construct(bool $withShutdown = true)
- {
- if ($withShutdown) {
- register_shutdown_function(function (): void {
- if ($this->enableShutdown) {
- // Only run the tasks if an E_ERROR didn't occur.
- $err = error_get_last();
- if (!$err || ($err['type'] ^ E_ERROR)) {
- $this->run();
- }
- }
- });
- }
- }
- public function isEmpty(): bool
- {
- return !$this->queue;
- }
- public function add(callable $task): void
- {
- $this->queue[] = $task;
- }
- public function run(): void
- {
- while ($task = array_shift($this->queue)) {
- /** @var callable $task */
- $task();
- }
- }
- /**
- * The task queue will be run and exhausted by default when the process
- * exits IFF the exit is not the result of a PHP E_ERROR error.
- *
- * You can disable running the automatic shutdown of the queue by calling
- * this function. If you disable the task queue shutdown process, then you
- * MUST either run the task queue (as a result of running your event loop
- * or manually using the run() method) or wait on each outstanding promise.
- *
- * Note: This shutdown will occur before any destructors are triggered.
- */
- public function disableShutdown(): void
- {
- $this->enableShutdown = false;
- }
- }
|