mirror of
https://github.com/phpbb/phpbb.git
synced 2025-07-30 21:40:43 +02:00
Merge pull request #3726 from CHItA/ticket/13961
[ticket/13961] Add orderable service collections
This commit is contained in:
117
phpBB/phpbb/di/ordered_service_collection.php
Normal file
117
phpBB/phpbb/di/ordered_service_collection.php
Normal file
@@ -0,0 +1,117 @@
|
||||
<?php
|
||||
/**
|
||||
*
|
||||
* This file is part of the phpBB Forum Software package.
|
||||
*
|
||||
* @copyright (c) phpBB Limited <https://www.phpbb.com>
|
||||
* @license GNU General Public License, version 2 (GPL-2.0)
|
||||
*
|
||||
* For full copyright and license information, please see
|
||||
* the docs/CREDITS.txt file.
|
||||
*
|
||||
*/
|
||||
|
||||
namespace phpbb\di;
|
||||
|
||||
use Symfony\Component\DependencyInjection\ContainerInterface;
|
||||
|
||||
/**
|
||||
* Collection of services in a specified order
|
||||
*/
|
||||
class ordered_service_collection extends service_collection
|
||||
{
|
||||
/**
|
||||
* @var bool
|
||||
*/
|
||||
protected $is_ordered;
|
||||
|
||||
/**
|
||||
* @var array
|
||||
*/
|
||||
protected $service_ids;
|
||||
|
||||
/**
|
||||
* Constructor
|
||||
*
|
||||
* @param ContainerInterface $container Container object
|
||||
*/
|
||||
public function __construct(ContainerInterface $container)
|
||||
{
|
||||
$this->is_ordered = false;
|
||||
$this->service_ids = array();
|
||||
|
||||
parent::__construct($container);
|
||||
}
|
||||
|
||||
/**
|
||||
* {@inheritdoc}
|
||||
*/
|
||||
public function getIterator()
|
||||
{
|
||||
if (!$this->is_ordered)
|
||||
{
|
||||
$this->sort_services();
|
||||
}
|
||||
|
||||
return new service_collection_iterator($this);
|
||||
}
|
||||
|
||||
/**
|
||||
* {@inheritdoc}
|
||||
*/
|
||||
public function offsetExists($index)
|
||||
{
|
||||
if (!$this->is_ordered)
|
||||
{
|
||||
$this->sort_services();
|
||||
}
|
||||
|
||||
return parent::offsetExists($index);
|
||||
}
|
||||
|
||||
/**
|
||||
* {@inheritdoc}
|
||||
*/
|
||||
public function offsetGet($index)
|
||||
{
|
||||
if (!$this->is_ordered)
|
||||
{
|
||||
$this->sort_services();
|
||||
}
|
||||
|
||||
return parent::offsetGet($index);
|
||||
}
|
||||
|
||||
/**
|
||||
* Adds a service ID to the collection
|
||||
*
|
||||
* @param string $service_id
|
||||
* @param int $order
|
||||
*/
|
||||
public function add($service_id, $order = 0)
|
||||
{
|
||||
$order = (int) $order;
|
||||
$this->service_ids[$order][] = $service_id;
|
||||
$this->is_ordered = false;
|
||||
}
|
||||
|
||||
protected function sort_services()
|
||||
{
|
||||
if ($this->is_ordered)
|
||||
{
|
||||
return;
|
||||
}
|
||||
|
||||
$this->exchangeArray(array());
|
||||
ksort($this->service_ids);
|
||||
foreach ($this->service_ids as $service_order_group)
|
||||
{
|
||||
foreach ($service_order_group as $service_id)
|
||||
{
|
||||
$this->offsetSet($service_id, null);
|
||||
}
|
||||
}
|
||||
|
||||
$this->is_ordered = true;
|
||||
}
|
||||
}
|
@@ -37,7 +37,16 @@ class collection_pass implements CompilerPassInterface
|
||||
|
||||
foreach ($container->findTaggedServiceIds($data[0]['tag']) as $service_id => $service_data)
|
||||
{
|
||||
$definition->addMethodCall('add', array($service_id));
|
||||
if (substr($definition->getClass(), -strlen('ordered_service_collection')) === 'ordered_service_collection')
|
||||
{
|
||||
$arguments = array($service_id, $service_data[0]['order']);
|
||||
}
|
||||
else
|
||||
{
|
||||
$arguments = array($service_id);
|
||||
}
|
||||
|
||||
$definition->addMethodCall('add', $arguments);
|
||||
}
|
||||
}
|
||||
}
|
||||
|
@@ -32,7 +32,7 @@ class service_collection_iterator extends \ArrayIterator
|
||||
*/
|
||||
public function __construct(service_collection $collection, $flags = 0)
|
||||
{
|
||||
parent::__construct($collection, $flags);
|
||||
parent::__construct($collection->getArrayCopy(), $flags);
|
||||
$this->collection = $collection;
|
||||
}
|
||||
|
||||
|
Reference in New Issue
Block a user