InlineServiceDefinitionsPass.php in Service Container 7
File
modules/providers/service_container_symfony/lib/Symfony/Component/DependencyInjection/Compiler/InlineServiceDefinitionsPass.php
View source
<?php
namespace Symfony\Component\DependencyInjection\Compiler;
use Symfony\Component\DependencyInjection\ContainerInterface;
use Symfony\Component\DependencyInjection\Definition;
use Symfony\Component\DependencyInjection\Reference;
use Symfony\Component\DependencyInjection\ContainerBuilder;
class InlineServiceDefinitionsPass implements RepeatablePassInterface {
private $repeatedPass;
private $graph;
private $compiler;
private $formatter;
private $currentId;
public function setRepeatedPass(RepeatedPass $repeatedPass) {
$this->repeatedPass = $repeatedPass;
}
public function process(ContainerBuilder $container) {
$this->compiler = $container
->getCompiler();
$this->formatter = $this->compiler
->getLoggingFormatter();
$this->graph = $this->compiler
->getServiceReferenceGraph();
foreach ($container
->getDefinitions() as $id => $definition) {
$this->currentId = $id;
$definition
->setArguments($this
->inlineArguments($container, $definition
->getArguments()));
$definition
->setMethodCalls($this
->inlineArguments($container, $definition
->getMethodCalls()));
$definition
->setProperties($this
->inlineArguments($container, $definition
->getProperties()));
$configurator = $this
->inlineArguments($container, array(
$definition
->getConfigurator(),
));
$definition
->setConfigurator($configurator[0]);
$factory = $this
->inlineArguments($container, array(
$definition
->getFactory(),
));
$definition
->setFactory($factory[0]);
}
}
private function inlineArguments(ContainerBuilder $container, array $arguments) {
foreach ($arguments as $k => $argument) {
if (is_array($argument)) {
$arguments[$k] = $this
->inlineArguments($container, $argument);
}
elseif ($argument instanceof Reference) {
if (!$container
->hasDefinition($id = (string) $argument)) {
continue;
}
if ($this
->isInlineableDefinition($container, $id, $definition = $container
->getDefinition($id))) {
$this->compiler
->addLogMessage($this->formatter
->formatInlineService($this, $id, $this->currentId));
if (ContainerInterface::SCOPE_PROTOTYPE !== $definition
->getScope()) {
$arguments[$k] = $definition;
}
else {
$arguments[$k] = clone $definition;
}
}
}
elseif ($argument instanceof Definition) {
$argument
->setArguments($this
->inlineArguments($container, $argument
->getArguments()));
$argument
->setMethodCalls($this
->inlineArguments($container, $argument
->getMethodCalls()));
$argument
->setProperties($this
->inlineArguments($container, $argument
->getProperties()));
}
}
return $arguments;
}
private function isInlineableDefinition(ContainerBuilder $container, $id, Definition $definition) {
if (ContainerInterface::SCOPE_PROTOTYPE === $definition
->getScope()) {
return true;
}
if ($definition
->isPublic() || $definition
->isLazy()) {
return false;
}
if (!$this->graph
->hasNode($id)) {
return true;
}
if ($this->currentId == $id) {
return false;
}
$ids = array();
foreach ($this->graph
->getNode($id)
->getInEdges() as $edge) {
$ids[] = $edge
->getSourceNode()
->getId();
}
if (count(array_unique($ids)) > 1) {
return false;
}
if (count($ids) > 1 && is_array($factory = $definition
->getFactory()) && ($factory[0] instanceof Reference || $factory[0] instanceof Definition)) {
return false;
}
if (count($ids) > 1 && $definition
->getFactoryService(false)) {
return false;
}
return $container
->getDefinition(reset($ids))
->getScope() === $definition
->getScope();
}
}