aboutsummaryrefslogtreecommitdiffstats
path: root/phpBB/includes/di/pass
diff options
context:
space:
mode:
authorNils Adermann <naderman@naderman.de>2012-11-11 09:05:15 -0800
committerNils Adermann <naderman@naderman.de>2012-11-11 09:05:15 -0800
commit69845585a2bc6720e6c512227f436782c7bf5d29 (patch)
tree70fc24b25612a99f2c3ac8664e1df7561d69f680 /phpBB/includes/di/pass
parent504158ceaba18bb8bc61d54504a2c870d0eb0407 (diff)
parent1bf7f0bde73a8528f77b5f9cfffd6f113afcf63d (diff)
downloadforums-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.php47
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));
+ }
+ }
+}