2016-12-29 19:16:04 -06:00
|
|
|
<?php
|
2015-08-28 00:18:50 -05:00
|
|
|
|
2016-08-23 16:47:40 -05:00
|
|
|
namespace Amp\Parallel\Worker;
|
2015-08-28 00:18:50 -05:00
|
|
|
|
2017-01-11 11:52:12 -06:00
|
|
|
use AsyncInterop\{ Loop, Promise };
|
|
|
|
|
|
|
|
const LOOP_POOL_IDENTIFIER = Pool::class;
|
|
|
|
const LOOP_FACTORY_IDENTIFIER = WorkerFactory::class;
|
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.
|
|
|
|
*
|
2016-08-23 16:47:40 -05:00
|
|
|
* @param \Amp\Parallel\Worker\Pool|null $pool A worker pool instance.
|
2016-08-18 11:04:48 -05:00
|
|
|
*
|
2016-08-23 16:47:40 -05:00
|
|
|
* @return \Amp\Parallel\Worker\Pool The global worker pool instance.
|
2016-08-18 11:04:48 -05:00
|
|
|
*/
|
|
|
|
function pool(Pool $pool = null): Pool {
|
2017-01-11 11:52:12 -06:00
|
|
|
if ($pool === null) {
|
|
|
|
$pool = Loop::getState(LOOP_POOL_IDENTIFIER);
|
|
|
|
if ($pool) {
|
|
|
|
return $pool;
|
|
|
|
}
|
2015-08-28 00:18:50 -05:00
|
|
|
|
2017-01-11 11:52:12 -06:00
|
|
|
$pool = new DefaultPool;
|
2015-08-28 00:18:50 -05:00
|
|
|
}
|
|
|
|
|
2017-01-11 11:52:12 -06:00
|
|
|
if (!$pool->isRunning()) {
|
|
|
|
$pool->start();
|
2015-08-28 00:18:50 -05:00
|
|
|
}
|
2015-09-02 08:51:59 -05:00
|
|
|
|
2017-01-11 11:52:12 -06:00
|
|
|
Loop::setState(LOOP_POOL_IDENTIFIER, $pool);
|
|
|
|
return $pool;
|
2016-08-18 11:04:48 -05:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Enqueues a task to be executed by the global worker pool.
|
|
|
|
*
|
2016-08-23 16:47:40 -05:00
|
|
|
* @param \Amp\Parallel\Worker\Task $task The task to enqueue.
|
2016-08-18 11:04:48 -05:00
|
|
|
*
|
2017-01-09 11:11:25 -06:00
|
|
|
* @return \AsyncInterop\Promise<mixed>
|
2016-08-18 11:04:48 -05:00
|
|
|
*/
|
2016-11-14 17:43:44 -06:00
|
|
|
function enqueue(Task $task): Promise {
|
2016-08-18 11:04:48 -05:00
|
|
|
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.
|
|
|
|
*
|
2016-08-23 16:47:40 -05:00
|
|
|
* @return \Amp\Parallel\Worker\Worker
|
2016-08-18 11:04:48 -05:00
|
|
|
*/
|
|
|
|
function create(): Worker {
|
|
|
|
$worker = factory()->create();
|
|
|
|
$worker->start();
|
|
|
|
return $worker;
|
|
|
|
}
|
2015-09-02 08:51:59 -05:00
|
|
|
|
2016-08-18 11:04:48 -05:00
|
|
|
/**
|
|
|
|
* Gets or sets the global worker factory.
|
|
|
|
*
|
2016-08-23 16:47:40 -05:00
|
|
|
* @param \Amp\Parallel\Worker\WorkerFactory|null $factory
|
2016-08-18 11:04:48 -05:00
|
|
|
*
|
2016-08-23 16:47:40 -05:00
|
|
|
* @return \Amp\Parallel\Worker\WorkerFactory
|
2016-08-18 11:04:48 -05:00
|
|
|
*/
|
|
|
|
function factory(WorkerFactory $factory = null): WorkerFactory {
|
2017-01-11 11:52:12 -06:00
|
|
|
if ($factory === null) {
|
|
|
|
$factory = Loop::getState(LOOP_FACTORY_IDENTIFIER);
|
|
|
|
if ($factory) {
|
|
|
|
return $factory;
|
|
|
|
}
|
2015-09-02 08:51:59 -05:00
|
|
|
|
2017-01-11 11:52:12 -06:00
|
|
|
$factory = new DefaultWorkerFactory;
|
2016-01-11 09:32:06 -06:00
|
|
|
}
|
2017-01-11 11:52:12 -06:00
|
|
|
Loop::setState(LOOP_FACTORY_IDENTIFIER, $factory);
|
|
|
|
return $factory;
|
2016-08-18 11:04:48 -05:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Gets a worker from the global worker pool.
|
|
|
|
*
|
2016-08-23 16:47:40 -05:00
|
|
|
* @return \Amp\Parallel\Worker\Worker
|
2016-08-18 11:04:48 -05:00
|
|
|
*/
|
|
|
|
function get(): Worker {
|
|
|
|
return pool()->get();
|
2015-08-28 00:18:50 -05:00
|
|
|
}
|