mirror of
				https://github.com/phpbb/phpbb.git
				synced 2025-10-26 13:16:14 +01:00 
			
		
		
		
	Merge pull request #2483 from Nicofuma/ticket/12575
[ticket/12575] Use a proxy pattern in \phpbb\di\service_collection * Nicofuma/ticket/12575: [ticket/12575] Use strict comparison [ticket/12575] Add missing property [ticket/12575] Usethe new header [ticket/12575] Fix 2 typos in comments [ticket/12575] Fix typos in comments [ticket/12575] Skip sniffer issue triggered by the solution of a php bug [ticket/12575] Remove inline assignments [ticket/12575] Fix the tests [ticket/12575] Move service_collection_iterator to its own file [ticket/12575] Speed up load_class()
This commit is contained in:
		| @@ -20,6 +20,11 @@ use Symfony\Component\DependencyInjection\ContainerInterface; | ||||
| */ | ||||
| class service_collection extends \ArrayObject | ||||
| { | ||||
| 	/** | ||||
| 	* @var \Symfony\Component\DependencyInjection\ContainerInterface | ||||
| 	*/ | ||||
| 	protected $container; | ||||
|  | ||||
| 	/** | ||||
| 	* Constructor | ||||
| 	* | ||||
| @@ -30,6 +35,44 @@ class service_collection extends \ArrayObject | ||||
| 		$this->container = $container; | ||||
| 	} | ||||
|  | ||||
| 	/** | ||||
| 	* {@inheritdoc} | ||||
| 	*/ | ||||
| 	public function getIterator() | ||||
| 	{ | ||||
| 		return new service_collection_iterator($this->container, $this); | ||||
| 	} | ||||
|  | ||||
| 	// Because of a PHP issue we have to redefine offsetExists | ||||
| 	// (even with a call to the parent): | ||||
| 	// 		https://bugs.php.net/bug.php?id=66834 | ||||
| 	// 		https://bugs.php.net/bug.php?id=67067 | ||||
| 	// But it triggers a sniffer issue that we have to skip | ||||
| 	// @codingStandardsIgnoreStart | ||||
| 	/** | ||||
| 	* {@inheritdoc} | ||||
| 	*/ | ||||
| 	public function offsetExists($index) | ||||
| 	{ | ||||
| 		return parent::offsetExists($index); | ||||
| 	} | ||||
| 	// @codingStandardsIgnoreEnd | ||||
|  | ||||
| 	/** | ||||
| 	* {@inheritdoc} | ||||
| 	*/ | ||||
| 	public function offsetGet($index) | ||||
| 	{ | ||||
| 		$task = parent::offsetGet($index); | ||||
| 		if ($task === null) | ||||
| 		{ | ||||
| 			$task = $this->container->get($index); | ||||
| 			$this->offsetSet($index, $task); | ||||
| 		} | ||||
|  | ||||
| 		return $task; | ||||
| 	} | ||||
|  | ||||
| 	/** | ||||
| 	* Add a service to the collection | ||||
| 	* | ||||
| @@ -38,8 +81,6 @@ class service_collection extends \ArrayObject | ||||
| 	*/ | ||||
| 	public function add($name) | ||||
| 	{ | ||||
| 		$task = $this->container->get($name); | ||||
|  | ||||
| 		$this->offsetSet($name, $task); | ||||
| 		$this->offsetSet($name, null); | ||||
| 	} | ||||
| } | ||||
|   | ||||
							
								
								
									
										87
									
								
								phpBB/phpbb/di/service_collection_iterator.php
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										87
									
								
								phpBB/phpbb/di/service_collection_iterator.php
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,87 @@ | ||||
| <?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; | ||||
|  | ||||
| /** | ||||
| * Iterator which loads the services when they are requested | ||||
| */ | ||||
| class service_collection_iterator extends \ArrayIterator | ||||
| { | ||||
| 	/** | ||||
| 	* @var \Symfony\Component\DependencyInjection\ContainerInterface | ||||
| 	*/ | ||||
| 	protected $container; | ||||
|  | ||||
| 	/** | ||||
| 	* Construct an ArrayIterator for service_collection | ||||
| 	* | ||||
| 	* @param ContainerInterface $container Container object | ||||
| 	* @param array $array The array or object to be iterated on. | ||||
| 	* @param int $flags Flags to control the behaviour of the ArrayObject object. | ||||
| 	* @see ArrayObject::setFlags() | ||||
| 	*/ | ||||
| 	public function __construct(ContainerInterface $container, $array = array(), $flags = 0) | ||||
| 	{ | ||||
| 		parent::__construct($array, $flags); | ||||
| 		$this->container = $container; | ||||
| 	} | ||||
|  | ||||
| 	/** | ||||
| 	* {@inheritdoc} | ||||
| 	*/ | ||||
| 	public function offsetGet($index) | ||||
| 	{ | ||||
| 		$task = parent::offsetGet($index); | ||||
| 		if ($task === null) | ||||
| 		{ | ||||
| 			$task = $this->container->get($index); | ||||
| 			$this->offsetSet($index, $task); | ||||
| 		} | ||||
|  | ||||
| 		return $task; | ||||
| 	} | ||||
|  | ||||
| 	// Because of a PHP issue we have to redefine offsetExists | ||||
| 	// (even with a call to the parent): | ||||
| 	// 		https://bugs.php.net/bug.php?id=66834 | ||||
| 	// 		https://bugs.php.net/bug.php?id=67067 | ||||
| 	// But it triggers a sniffer issue that we have to skip | ||||
| 	// @codingStandardsIgnoreStart | ||||
| 	/** | ||||
| 	* {@inheritdoc} | ||||
| 	*/ | ||||
| 	public function offsetExists($index) | ||||
| 	{ | ||||
| 		parent::offsetExists($index); | ||||
| 	} | ||||
| 	// @codingStandardsIgnoreEnd | ||||
|  | ||||
| 	/** | ||||
| 	* {@inheritdoc} | ||||
| 	*/ | ||||
| 	public function current() | ||||
| 	{ | ||||
| 		$task = parent::current(); | ||||
| 		if ($task === null) | ||||
| 		{ | ||||
| 			$name = $this->key(); | ||||
| 			$task = $this->container->get($name); | ||||
| 			$this->offsetSet($name, $task); | ||||
| 		} | ||||
|  | ||||
| 		return $task; | ||||
| 	} | ||||
| } | ||||
		Reference in New Issue
	
	Block a user