diff options
author | Nils Adermann <naderman@naderman.de> | 2012-11-11 09:05:15 -0800 |
---|---|---|
committer | Nils Adermann <naderman@naderman.de> | 2012-11-11 09:05:15 -0800 |
commit | 69845585a2bc6720e6c512227f436782c7bf5d29 (patch) | |
tree | 70fc24b25612a99f2c3ac8664e1df7561d69f680 /phpBB/includes/di/pass | |
parent | 504158ceaba18bb8bc61d54504a2c870d0eb0407 (diff) | |
parent | 1bf7f0bde73a8528f77b5f9cfffd6f113afcf63d (diff) | |
download | forums-69845585a2bc6720e6c512227f436782c7bf5d29.tar forums-69845585a2bc6720e6c512227f436782c7bf5d29.tar.gz forums-69845585a2bc6720e6c512227f436782c7bf5d29.tar.bz2 forums-69845585a2bc6720e6c512227f436782c7bf5d29.tar.xz forums-69845585a2bc6720e6c512227f436782c7bf5d29.zip |
Merge pull request #1056 from igorw/feature/compiled-dic
[feature/compiled-dic] Compile the DI Container into a cached class
Diffstat (limited to 'phpBB/includes/di/pass')
-rw-r--r-- | phpBB/includes/di/pass/collection_pass.php | 47 |
1 files changed, 47 insertions, 0 deletions
diff --git a/phpBB/includes/di/pass/collection_pass.php b/phpBB/includes/di/pass/collection_pass.php new file mode 100644 index 0000000000..70a44d1d51 --- /dev/null +++ b/phpBB/includes/di/pass/collection_pass.php @@ -0,0 +1,47 @@ +<?php +/** +* +* @package phpBB3 +* @copyright (c) 2012 phpBB Group +* @license http://opensource.org/licenses/gpl-2.0.php GNU General Public License v2 +* +*/ + +/** +* @ignore +*/ +if (!defined('IN_PHPBB')) +{ + exit; +} + +use Symfony\Component\DependencyInjection\ContainerBuilder; +use Symfony\Component\DependencyInjection\Compiler\CompilerPassInterface; + +class phpbb_di_pass_collection_pass implements CompilerPassInterface +{ + private $collection_service; + private $service_tag; + + public function __construct($collection_service, $service_tag) + { + $this->collection_service = $collection_service; + $this->service_tag = $service_tag; + } + + /** + * Modify the container before it is passed to the rest of the code + * + * @param ContainerBuilder $container ContainerBuilder object + * @return null + */ + public function process(ContainerBuilder $container) + { + $definition = $container->getDefinition($this->collection_service); + + foreach ($container->findTaggedServiceIds($this->service_tag) as $id => $data) + { + $definition->addMethodCall('add', array($id)); + } + } +} |