1
0
mirror of https://github.com/danog/parallel.git synced 2025-01-23 06:21:12 +01:00
parallel/lib/Worker/functions.php

79 lines
1.6 KiB
PHP
Raw Normal View History

2016-08-21 23:40:48 -05:00
<?php declare(strict_types = 1);
2016-08-18 11:04:48 -05:00
namespace Amp\Concurrent\Worker;
2016-08-18 11:04:48 -05:00
use Interop\Async\Awaitable;
2015-08-29 00:41:00 -05:00
2016-08-18 11:04:48 -05:00
/**
* Returns the global worker pool for the current context.
*
* @param \Amp\Concurrent\Worker\Pool|null $pool A worker pool instance.
*
* @return \Amp\Concurrent\Worker\Pool The global worker pool instance.
*/
function pool(Pool $pool = null): Pool {
static $instance;
2016-08-18 11:04:48 -05:00
if (null !== $pool) {
$instance = $pool;
} elseif (null === $instance) {
2016-08-22 18:25:19 -05:00
$instance = new DefaultPool;
}
2016-08-18 11:04:48 -05:00
if (!$instance->isRunning()) {
$instance->start();
}
2016-08-18 11:04:48 -05:00
return $instance;
}
/**
* Enqueues a task to be executed by the global worker pool.
*
* @param \Amp\Concurrent\Worker\Task $task The task to enqueue.
*
* @return \Interop\Async\Awaitable<mixed>
*/
function enqueue(Task $task): Awaitable {
return pool()->enqueue($task);
}
2016-01-11 09:32:06 -06:00
2016-08-18 11:04:48 -05:00
/**
* Creates a worker using the global worker factory.
*
* @return \Amp\Concurrent\Worker\Worker
*/
function create(): Worker {
$worker = factory()->create();
$worker->start();
return $worker;
}
2016-08-18 11:04:48 -05:00
/**
* Gets or sets the global worker factory.
*
* @param \Amp\Concurrent\Worker\WorkerFactory|null $factory
*
* @return \Amp\Concurrent\Worker\WorkerFactory
*/
function factory(WorkerFactory $factory = null): WorkerFactory {
static $instance;
2016-08-18 11:04:48 -05:00
if (null !== $factory) {
$instance = $factory;
} elseif (null === $instance) {
2016-08-22 18:25:19 -05:00
$instance = new DefaultWorkerFactory;
2016-01-11 09:32:06 -06:00
}
2016-08-18 11:04:48 -05:00
return $instance;
}
/**
* Gets a worker from the global worker pool.
*
* @return \Amp\Concurrent\Worker\Worker
*/
function get(): Worker {
return pool()->get();
}