1
0
mirror of https://github.com/danog/parallel.git synced 2024-12-02 17:52:14 +01:00
parallel/lib/Worker/functions.php
Aaron Piotrowski 312aecf1ff
Remove Worker::start()
The context can automatically be started when a job is enqueued.
2017-12-13 14:14:31 -06:00

80 lines
1.7 KiB
PHP

<?php
namespace Amp\Parallel\Worker;
use Amp\Loop;
use Amp\Promise;
const LOOP_POOL_IDENTIFIER = Pool::class;
const LOOP_FACTORY_IDENTIFIER = WorkerFactory::class;
/**
* Gets or sets the global worker pool.
*
* @param \Amp\Parallel\Worker\Pool|null $pool A worker pool instance.
*
* @return \Amp\Parallel\Worker\Pool The global worker pool instance.
*/
function pool(Pool $pool = null): Pool {
if ($pool === null) {
$pool = Loop::getState(LOOP_POOL_IDENTIFIER);
if ($pool) {
return $pool;
}
$pool = new DefaultPool;
}
Loop::setState(LOOP_POOL_IDENTIFIER, $pool);
return $pool;
}
/**
* Enqueues a task to be executed by the global worker pool.
*
* @param \Amp\Parallel\Worker\Task $task The task to enqueue.
*
* @return \Amp\Promise<mixed>
*/
function enqueue(Task $task): Promise {
return pool()->enqueue($task);
}
/**
* Gets a worker from the global worker pool.
*
* @return \Amp\Parallel\Worker\Worker
*/
function get(): Worker {
return pool()->get();
}
/**
* Creates a worker using the global worker factory. The worker is automatically started.
*
* @return \Amp\Parallel\Worker\Worker
*/
function create(): Worker {
return factory()->create();
}
/**
* Gets or sets the global worker factory.
*
* @param \Amp\Parallel\Worker\WorkerFactory|null $factory
*
* @return \Amp\Parallel\Worker\WorkerFactory
*/
function factory(WorkerFactory $factory = null): WorkerFactory {
if ($factory === null) {
$factory = Loop::getState(LOOP_FACTORY_IDENTIFIER);
if ($factory) {
return $factory;
}
$factory = new DefaultWorkerFactory;
}
Loop::setState(LOOP_FACTORY_IDENTIFIER, $factory);
return $factory;
}