Submit
Path:
~
/
/
opt
/
psa
/
phpMyAdmin
/
vendor
/
symfony
/
dependency-injection
/
Compiler
/
File Content:
ResolveChildDefinitionsPass.php
<?php /* * This file is part of the Symfony package. * * (c) Fabien Potencier <fabien@symfony.com> * * For the full copyright and license information, please view the LICENSE * file that was distributed with this source code. */ namespace Symfony\Component\DependencyInjection\Compiler; use Symfony\Component\DependencyInjection\ChildDefinition; use Symfony\Component\DependencyInjection\ContainerInterface; use Symfony\Component\DependencyInjection\Definition; use Symfony\Component\DependencyInjection\Exception\ExceptionInterface; use Symfony\Component\DependencyInjection\Exception\RuntimeException; use Symfony\Component\DependencyInjection\Exception\ServiceCircularReferenceException; /** * This replaces all ChildDefinition instances with their equivalent fully * merged Definition instance. * * @author Johannes M. Schmitt <schmittjoh@gmail.com> * @author Nicolas Grekas <p@tchwork.com> */ class ResolveChildDefinitionsPass extends AbstractRecursivePass { private $currentPath; protected function processValue($value, bool $isRoot = false) { if (!$value instanceof Definition) { return parent::processValue($value, $isRoot); } if ($isRoot) { // yes, we are specifically fetching the definition from the // container to ensure we are not operating on stale data $value = $this->container->getDefinition($this->currentId); } if ($value instanceof ChildDefinition) { $this->currentPath = []; $value = $this->resolveDefinition($value); if ($isRoot) { $this->container->setDefinition($this->currentId, $value); } } return parent::processValue($value, $isRoot); } /** * Resolves the definition. * * @throws RuntimeException When the definition is invalid */ private function resolveDefinition(ChildDefinition $definition): Definition { try { return $this->doResolveDefinition($definition); } catch (ServiceCircularReferenceException $e) { throw $e; } catch (ExceptionInterface $e) { $r = new \ReflectionProperty($e, 'message'); $r->setAccessible(true); $r->setValue($e, sprintf('Service "%s": %s', $this->currentId, $e->getMessage())); throw $e; } } private function doResolveDefinition(ChildDefinition $definition): Definition { if (!$this->container->has($parent = $definition->getParent())) { throw new RuntimeException(sprintf('Parent definition "%s" does not exist.', $parent)); } $searchKey = array_search($parent, $this->currentPath); $this->currentPath[] = $parent; if (false !== $searchKey) { throw new ServiceCircularReferenceException($parent, \array_slice($this->currentPath, $searchKey)); } $parentDef = $this->container->findDefinition($parent); if ($parentDef instanceof ChildDefinition) { $id = $this->currentId; $this->currentId = $parent; $parentDef = $this->resolveDefinition($parentDef); $this->container->setDefinition($parent, $parentDef); $this->currentId = $id; } $this->container->log($this, sprintf('Resolving inheritance for "%s" (parent: %s).', $this->currentId, $parent)); $def = new Definition(); // merge in parent definition // purposely ignored attributes: abstract, shared, tags, autoconfigured $def->setClass($parentDef->getClass()); $def->setArguments($parentDef->getArguments()); $def->setMethodCalls($parentDef->getMethodCalls()); $def->setProperties($parentDef->getProperties()); if ($parentDef->isDeprecated()) { $deprecation = $parentDef->getDeprecation('%service_id%'); $def->setDeprecated($deprecation['package'], $deprecation['version'], $deprecation['message']); } $def->setFactory($parentDef->getFactory()); $def->setConfigurator($parentDef->getConfigurator()); $def->setFile($parentDef->getFile()); $def->setPublic($parentDef->isPublic()); $def->setLazy($parentDef->isLazy()); $def->setAutowired($parentDef->isAutowired()); $def->setChanges($parentDef->getChanges()); $def->setBindings($definition->getBindings() + $parentDef->getBindings()); $def->setSynthetic($definition->isSynthetic()); // overwrite with values specified in the decorator $changes = $definition->getChanges(); if (isset($changes['class'])) { $def->setClass($definition->getClass()); } if (isset($changes['factory'])) { $def->setFactory($definition->getFactory()); } if (isset($changes['configurator'])) { $def->setConfigurator($definition->getConfigurator()); } if (isset($changes['file'])) { $def->setFile($definition->getFile()); } if (isset($changes['public'])) { $def->setPublic($definition->isPublic()); } else { $def->setPublic($parentDef->isPublic()); } if (isset($changes['lazy'])) { $def->setLazy($definition->isLazy()); } if (isset($changes['deprecated'])) { if ($definition->isDeprecated()) { $deprecation = $definition->getDeprecation('%service_id%'); $def->setDeprecated($deprecation['package'], $deprecation['version'], $deprecation['message']); } else { $def->setDeprecated(false); } } if (isset($changes['autowired'])) { $def->setAutowired($definition->isAutowired()); } if (isset($changes['shared'])) { $def->setShared($definition->isShared()); } if (isset($changes['decorated_service'])) { $decoratedService = $definition->getDecoratedService(); if (null === $decoratedService) { $def->setDecoratedService($decoratedService); } else { $def->setDecoratedService($decoratedService[0], $decoratedService[1], $decoratedService[2], $decoratedService[3] ?? ContainerInterface::EXCEPTION_ON_INVALID_REFERENCE); } } // merge arguments foreach ($definition->getArguments() as $k => $v) { if (is_numeric($k)) { $def->addArgument($v); } elseif (str_starts_with($k, 'index_')) { $def->replaceArgument((int) substr($k, \strlen('index_')), $v); } else { $def->setArgument($k, $v); } } // merge properties foreach ($definition->getProperties() as $k => $v) { $def->setProperty($k, $v); } // append method calls if ($calls = $definition->getMethodCalls()) { $def->setMethodCalls(array_merge($def->getMethodCalls(), $calls)); } $def->addError($parentDef); $def->addError($definition); // these attributes are always taken from the child $def->setAbstract($definition->isAbstract()); $def->setTags($definition->getTags()); // autoconfigure is never taken from parent (on purpose) // and it's not legal on an instanceof $def->setAutoconfigured($definition->isAutoconfigured()); if (!$def->hasTag('proxy')) { foreach ($parentDef->getTag('proxy') as $v) { $def->addTag('proxy', $v); } } return $def; } }
Submit
FILE
FOLDER
INFO
Name
Size
Permission
Action
AbstractRecursivePass.php
9547 bytes
0644
AliasDeprecatedPublicServicesPass.php
2559 bytes
0644
AnalyzeServiceReferencesPass.php
6327 bytes
0644
AttributeAutoconfigurationPass.php
7622 bytes
0644
AutoAliasServicePass.php
1908 bytes
0644
AutowirePass.php
24971 bytes
0644
AutowireRequiredMethodsPass.php
3867 bytes
0644
AutowireRequiredPropertiesPass.php
2286 bytes
0644
CheckArgumentsValidityPass.php
4386 bytes
0644
CheckCircularReferencesPass.php
2448 bytes
0644
CheckDefinitionValidityPass.php
4742 bytes
0644
CheckExceptionOnInvalidReferenceBehaviorPass.php
4653 bytes
0644
CheckReferenceValidityPass.php
1477 bytes
0644
CheckTypeDeclarationsPass.php
12663 bytes
0644
Compiler.php
2724 bytes
0644
CompilerPassInterface.php
668 bytes
0644
DecoratorServicePass.php
5614 bytes
0644
DefinitionErrorExceptionPass.php
3283 bytes
0644
ExtensionCompilerPass.php
892 bytes
0644
InlineServiceDefinitionsPass.php
7636 bytes
0644
MergeExtensionConfigurationPass.php
8360 bytes
0644
PassConfig.php
7547 bytes
0644
PriorityTaggedServiceTrait.php
6984 bytes
0644
RegisterAutoconfigureAttributesPass.php
3376 bytes
0644
RegisterEnvVarProcessorsPass.php
3004 bytes
0644
RegisterReverseContainerPass.php
2422 bytes
0644
RegisterServiceSubscribersPass.php
6651 bytes
0644
RemoveAbstractDefinitionsPass.php
908 bytes
0644
RemovePrivateAliasesPass.php
1114 bytes
0644
RemoveUnusedDefinitionsPass.php
2860 bytes
0644
ReplaceAliasByActualDefinitionPass.php
4491 bytes
0644
ResolveBindingsPass.php
10054 bytes
0644
ResolveChildDefinitionsPass.php
7702 bytes
0644
ResolveClassPass.php
1561 bytes
0644
ResolveDecoratorStackPass.php
4610 bytes
0644
ResolveEnvPlaceholdersPass.php
1357 bytes
0644
ResolveFactoryClassPass.php
1217 bytes
0644
ResolveHotPathPass.php
2553 bytes
0644
ResolveInstanceofConditionalsPass.php
7272 bytes
0644
ResolveInvalidReferencesPass.php
5332 bytes
0644
ResolveNamedArgumentsPass.php
6074 bytes
0644
ResolveNoPreloadPass.php
3364 bytes
0644
ResolveParameterPlaceHoldersPass.php
3178 bytes
0644
ResolvePrivatesPass.php
1178 bytes
0644
ResolveReferencesToAliasesPass.php
2758 bytes
0644
ResolveServiceSubscribersPass.php
1637 bytes
0644
ResolveTaggedIteratorArgumentPass.php
952 bytes
0644
ServiceLocatorTagPass.php
5407 bytes
0644
ServiceReferenceGraph.php
2645 bytes
0644
ServiceReferenceGraphEdge.php
2184 bytes
0644
ServiceReferenceGraphNode.php
2299 bytes
0644
ValidateEnvPlaceholdersPass.php
3669 bytes
0644
N4ST4R_ID | Naxtarrr