File "ContainerBuilder.php"

Full Path: /home/warrior1/public_html/plugins/mailpoet/vendor-prefixed/symfony/dependency-injection/ContainerBuilder.php
File size: 34.97 KB
MIME-type: text/x-php
Charset: utf-8

<?php
namespace MailPoetVendor\Symfony\Component\DependencyInjection;
if (!defined('ABSPATH')) exit;
use MailPoetVendor\Composer\InstalledVersions;
use MailPoetVendor\Psr\Container\ContainerInterface as PsrContainerInterface;
use MailPoetVendor\Symfony\Component\Config\Resource\ClassExistenceResource;
use MailPoetVendor\Symfony\Component\Config\Resource\ComposerResource;
use MailPoetVendor\Symfony\Component\Config\Resource\DirectoryResource;
use MailPoetVendor\Symfony\Component\Config\Resource\FileExistenceResource;
use MailPoetVendor\Symfony\Component\Config\Resource\FileResource;
use MailPoetVendor\Symfony\Component\Config\Resource\GlobResource;
use MailPoetVendor\Symfony\Component\Config\Resource\ReflectionClassResource;
use MailPoetVendor\Symfony\Component\Config\Resource\ResourceInterface;
use MailPoetVendor\Symfony\Component\DependencyInjection\Argument\AbstractArgument;
use MailPoetVendor\Symfony\Component\DependencyInjection\Argument\IteratorArgument;
use MailPoetVendor\Symfony\Component\DependencyInjection\Argument\RewindableGenerator;
use MailPoetVendor\Symfony\Component\DependencyInjection\Argument\ServiceClosureArgument;
use MailPoetVendor\Symfony\Component\DependencyInjection\Argument\ServiceLocator;
use MailPoetVendor\Symfony\Component\DependencyInjection\Argument\ServiceLocatorArgument;
use MailPoetVendor\Symfony\Component\DependencyInjection\Attribute\Target;
use MailPoetVendor\Symfony\Component\DependencyInjection\Compiler\Compiler;
use MailPoetVendor\Symfony\Component\DependencyInjection\Compiler\CompilerPassInterface;
use MailPoetVendor\Symfony\Component\DependencyInjection\Compiler\PassConfig;
use MailPoetVendor\Symfony\Component\DependencyInjection\Compiler\ResolveEnvPlaceholdersPass;
use MailPoetVendor\Symfony\Component\DependencyInjection\Exception\BadMethodCallException;
use MailPoetVendor\Symfony\Component\DependencyInjection\Exception\InvalidArgumentException;
use MailPoetVendor\Symfony\Component\DependencyInjection\Exception\LogicException;
use MailPoetVendor\Symfony\Component\DependencyInjection\Exception\RuntimeException;
use MailPoetVendor\Symfony\Component\DependencyInjection\Exception\ServiceCircularReferenceException;
use MailPoetVendor\Symfony\Component\DependencyInjection\Exception\ServiceNotFoundException;
use MailPoetVendor\Symfony\Component\DependencyInjection\Extension\ExtensionInterface;
use MailPoetVendor\Symfony\Component\DependencyInjection\LazyProxy\Instantiator\InstantiatorInterface;
use MailPoetVendor\Symfony\Component\DependencyInjection\LazyProxy\Instantiator\RealServiceInstantiator;
use MailPoetVendor\Symfony\Component\DependencyInjection\ParameterBag\EnvPlaceholderParameterBag;
use MailPoetVendor\Symfony\Component\DependencyInjection\ParameterBag\ParameterBag;
use MailPoetVendor\Symfony\Component\DependencyInjection\ParameterBag\ParameterBagInterface;
use MailPoetVendor\Symfony\Component\ExpressionLanguage\Expression;
use MailPoetVendor\Symfony\Component\ExpressionLanguage\ExpressionFunctionProviderInterface;
class ContainerBuilder extends Container implements TaggedContainerInterface
{
 private $extensions = [];
 private $extensionsByNs = [];
 private $definitions = [];
 private $aliasDefinitions = [];
 private $resources = [];
 private $extensionConfigs = [];
 private $compiler;
 private $trackResources;
 private $proxyInstantiator;
 private $expressionLanguage;
 private $expressionLanguageProviders = [];
 private $usedTags = [];
 private $envPlaceholders = [];
 private $envCounters = [];
 private $vendors;
 private $autoconfiguredInstanceof = [];
 private $autoconfiguredAttributes = [];
 private $removedIds = [];
 private $removedBindingIds = [];
 private const INTERNAL_TYPES = ['int' => \true, 'float' => \true, 'string' => \true, 'bool' => \true, 'resource' => \true, 'object' => \true, 'array' => \true, 'null' => \true, 'callable' => \true, 'iterable' => \true, 'mixed' => \true];
 public function __construct(ParameterBagInterface $parameterBag = null)
 {
 parent::__construct($parameterBag);
 $this->trackResources = \interface_exists(ResourceInterface::class);
 $this->setDefinition('service_container', (new Definition(ContainerInterface::class))->setSynthetic(\true)->setPublic(\true));
 $this->setAlias(PsrContainerInterface::class, new Alias('service_container', \false))->setDeprecated('symfony/dependency-injection', '5.1', $deprecationMessage = 'The "%alias_id%" autowiring alias is deprecated. Define it explicitly in your app if you want to keep using it.');
 $this->setAlias(ContainerInterface::class, new Alias('service_container', \false))->setDeprecated('symfony/dependency-injection', '5.1', $deprecationMessage);
 }
 private $classReflectors;
 public function setResourceTracking(bool $track)
 {
 $this->trackResources = $track;
 }
 public function isTrackingResources()
 {
 return $this->trackResources;
 }
 public function setProxyInstantiator(InstantiatorInterface $proxyInstantiator)
 {
 $this->proxyInstantiator = $proxyInstantiator;
 }
 public function registerExtension(ExtensionInterface $extension)
 {
 $this->extensions[$extension->getAlias()] = $extension;
 if (\false !== $extension->getNamespace()) {
 $this->extensionsByNs[$extension->getNamespace()] = $extension;
 }
 }
 public function getExtension(string $name)
 {
 if (isset($this->extensions[$name])) {
 return $this->extensions[$name];
 }
 if (isset($this->extensionsByNs[$name])) {
 return $this->extensionsByNs[$name];
 }
 throw new LogicException(\sprintf('Container extension "%s" is not registered.', $name));
 }
 public function getExtensions()
 {
 return $this->extensions;
 }
 public function hasExtension(string $name)
 {
 return isset($this->extensions[$name]) || isset($this->extensionsByNs[$name]);
 }
 public function getResources()
 {
 return \array_values($this->resources);
 }
 public function addResource(ResourceInterface $resource)
 {
 if (!$this->trackResources) {
 return $this;
 }
 if ($resource instanceof GlobResource && $this->inVendors($resource->getPrefix())) {
 return $this;
 }
 $this->resources[(string) $resource] = $resource;
 return $this;
 }
 public function setResources(array $resources)
 {
 if (!$this->trackResources) {
 return $this;
 }
 $this->resources = $resources;
 return $this;
 }
 public function addObjectResource($object)
 {
 if ($this->trackResources) {
 if (\is_object($object)) {
 $object = \get_class($object);
 }
 if (!isset($this->classReflectors[$object])) {
 $this->classReflectors[$object] = new \ReflectionClass($object);
 }
 $class = $this->classReflectors[$object];
 foreach ($class->getInterfaceNames() as $name) {
 if (null === ($interface =& $this->classReflectors[$name])) {
 $interface = new \ReflectionClass($name);
 }
 $file = $interface->getFileName();
 if (\false !== $file && \file_exists($file)) {
 $this->fileExists($file);
 }
 }
 do {
 $file = $class->getFileName();
 if (\false !== $file && \file_exists($file)) {
 $this->fileExists($file);
 }
 foreach ($class->getTraitNames() as $name) {
 $this->addObjectResource($name);
 }
 } while ($class = $class->getParentClass());
 }
 return $this;
 }
 public function getReflectionClass(?string $class, bool $throw = \true) : ?\ReflectionClass
 {
 if (!($class = $this->getParameterBag()->resolveValue($class))) {
 return null;
 }
 if (isset(self::INTERNAL_TYPES[$class])) {
 return null;
 }
 $resource = $classReflector = null;
 try {
 if (isset($this->classReflectors[$class])) {
 $classReflector = $this->classReflectors[$class];
 } elseif (\class_exists(ClassExistenceResource::class)) {
 $resource = new ClassExistenceResource($class, \false);
 $classReflector = $resource->isFresh(0) ? \false : new \ReflectionClass($class);
 } else {
 $classReflector = \class_exists($class) ? new \ReflectionClass($class) : \false;
 }
 } catch (\ReflectionException $e) {
 if ($throw) {
 throw $e;
 }
 }
 if ($this->trackResources) {
 if (!$classReflector) {
 $this->addResource($resource ?? new ClassExistenceResource($class, \false));
 } elseif (!$classReflector->isInternal()) {
 $path = $classReflector->getFileName();
 if (!$this->inVendors($path)) {
 $this->addResource(new ReflectionClassResource($classReflector, $this->vendors));
 }
 }
 $this->classReflectors[$class] = $classReflector;
 }
 return $classReflector ?: null;
 }
 public function fileExists(string $path, $trackContents = \true) : bool
 {
 $exists = \file_exists($path);
 if (!$this->trackResources || $this->inVendors($path)) {
 return $exists;
 }
 if (!$exists) {
 $this->addResource(new FileExistenceResource($path));
 return $exists;
 }
 if (\is_dir($path)) {
 if ($trackContents) {
 $this->addResource(new DirectoryResource($path, \is_string($trackContents) ? $trackContents : null));
 } else {
 $this->addResource(new GlobResource($path, '/*', \false));
 }
 } elseif ($trackContents) {
 $this->addResource(new FileResource($path));
 }
 return $exists;
 }
 public function loadFromExtension(string $extension, array $values = null)
 {
 if ($this->isCompiled()) {
 throw new BadMethodCallException('Cannot load from an extension on a compiled container.');
 }
 $namespace = $this->getExtension($extension)->getAlias();
 $this->extensionConfigs[$namespace][] = $values ?? [];
 return $this;
 }
 public function addCompilerPass(CompilerPassInterface $pass, string $type = PassConfig::TYPE_BEFORE_OPTIMIZATION, int $priority = 0)
 {
 $this->getCompiler()->addPass($pass, $type, $priority);
 $this->addObjectResource($pass);
 return $this;
 }
 public function getCompilerPassConfig()
 {
 return $this->getCompiler()->getPassConfig();
 }
 public function getCompiler()
 {
 if (null === $this->compiler) {
 $this->compiler = new Compiler();
 }
 return $this->compiler;
 }
 public function set(string $id, ?object $service)
 {
 if ($this->isCompiled() && (isset($this->definitions[$id]) && !$this->definitions[$id]->isSynthetic())) {
 // setting a synthetic service on a compiled container is alright
 throw new BadMethodCallException(\sprintf('Setting service "%s" for an unknown or non-synthetic service definition on a compiled container is not allowed.', $id));
 }
 unset($this->definitions[$id], $this->aliasDefinitions[$id], $this->removedIds[$id]);
 parent::set($id, $service);
 }
 public function removeDefinition(string $id)
 {
 if (isset($this->definitions[$id])) {
 unset($this->definitions[$id]);
 $this->removedIds[$id] = \true;
 }
 }
 public function has(string $id)
 {
 return isset($this->definitions[$id]) || isset($this->aliasDefinitions[$id]) || parent::has($id);
 }
 public function get(string $id, int $invalidBehavior = ContainerInterface::EXCEPTION_ON_INVALID_REFERENCE)
 {
 if ($this->isCompiled() && isset($this->removedIds[$id]) && ContainerInterface::EXCEPTION_ON_INVALID_REFERENCE >= $invalidBehavior) {
 return parent::get($id);
 }
 return $this->doGet($id, $invalidBehavior);
 }
 private function doGet(string $id, int $invalidBehavior = ContainerInterface::EXCEPTION_ON_INVALID_REFERENCE, array &$inlineServices = null, bool $isConstructorArgument = \false)
 {
 if (isset($inlineServices[$id])) {
 return $inlineServices[$id];
 }
 if (null === $inlineServices) {
 $isConstructorArgument = \true;
 $inlineServices = [];
 }
 try {
 if (ContainerInterface::IGNORE_ON_UNINITIALIZED_REFERENCE === $invalidBehavior) {
 return parent::get($id, $invalidBehavior);
 }
 if ($service = parent::get($id, ContainerInterface::NULL_ON_INVALID_REFERENCE)) {
 return $service;
 }
 } catch (ServiceCircularReferenceException $e) {
 if ($isConstructorArgument) {
 throw $e;
 }
 }
 if (!isset($this->definitions[$id]) && isset($this->aliasDefinitions[$id])) {
 $alias = $this->aliasDefinitions[$id];
 if ($alias->isDeprecated()) {
 $deprecation = $alias->getDeprecation($id);
 trigger_deprecation($deprecation['package'], $deprecation['version'], $deprecation['message']);
 }
 return $this->doGet((string) $alias, $invalidBehavior, $inlineServices, $isConstructorArgument);
 }
 try {
 $definition = $this->getDefinition($id);
 } catch (ServiceNotFoundException $e) {
 if (ContainerInterface::EXCEPTION_ON_INVALID_REFERENCE < $invalidBehavior) {
 return null;
 }
 throw $e;
 }
 if ($definition->hasErrors() && ($e = $definition->getErrors())) {
 throw new RuntimeException(\reset($e));
 }
 if ($isConstructorArgument) {
 $this->loading[$id] = \true;
 }
 try {
 return $this->createService($definition, $inlineServices, $isConstructorArgument, $id);
 } finally {
 if ($isConstructorArgument) {
 unset($this->loading[$id]);
 }
 }
 }
 public function merge(self $container)
 {
 if ($this->isCompiled()) {
 throw new BadMethodCallException('Cannot merge on a compiled container.');
 }
 $this->addDefinitions($container->getDefinitions());
 $this->addAliases($container->getAliases());
 $this->getParameterBag()->add($container->getParameterBag()->all());
 if ($this->trackResources) {
 foreach ($container->getResources() as $resource) {
 $this->addResource($resource);
 }
 }
 foreach ($this->extensions as $name => $extension) {
 if (!isset($this->extensionConfigs[$name])) {
 $this->extensionConfigs[$name] = [];
 }
 $this->extensionConfigs[$name] = \array_merge($this->extensionConfigs[$name], $container->getExtensionConfig($name));
 }
 if ($this->getParameterBag() instanceof EnvPlaceholderParameterBag && $container->getParameterBag() instanceof EnvPlaceholderParameterBag) {
 $envPlaceholders = $container->getParameterBag()->getEnvPlaceholders();
 $this->getParameterBag()->mergeEnvPlaceholders($container->getParameterBag());
 } else {
 $envPlaceholders = [];
 }
 foreach ($container->envCounters as $env => $count) {
 if (!$count && !isset($envPlaceholders[$env])) {
 continue;
 }
 if (!isset($this->envCounters[$env])) {
 $this->envCounters[$env] = $count;
 } else {
 $this->envCounters[$env] += $count;
 }
 }
 foreach ($container->getAutoconfiguredInstanceof() as $interface => $childDefinition) {
 if (isset($this->autoconfiguredInstanceof[$interface])) {
 throw new InvalidArgumentException(\sprintf('"%s" has already been autoconfigured and merge() does not support merging autoconfiguration for the same class/interface.', $interface));
 }
 $this->autoconfiguredInstanceof[$interface] = $childDefinition;
 }
 foreach ($container->getAutoconfiguredAttributes() as $attribute => $configurator) {
 if (isset($this->autoconfiguredAttributes[$attribute])) {
 throw new InvalidArgumentException(\sprintf('"%s" has already been autoconfigured and merge() does not support merging autoconfiguration for the same attribute.', $attribute));
 }
 $this->autoconfiguredAttributes[$attribute] = $configurator;
 }
 }
 public function getExtensionConfig(string $name)
 {
 if (!isset($this->extensionConfigs[$name])) {
 $this->extensionConfigs[$name] = [];
 }
 return $this->extensionConfigs[$name];
 }
 public function prependExtensionConfig(string $name, array $config)
 {
 if (!isset($this->extensionConfigs[$name])) {
 $this->extensionConfigs[$name] = [];
 }
 \array_unshift($this->extensionConfigs[$name], $config);
 }
 public function compile(bool $resolveEnvPlaceholders = \false)
 {
 $compiler = $this->getCompiler();
 if ($this->trackResources) {
 foreach ($compiler->getPassConfig()->getPasses() as $pass) {
 $this->addObjectResource($pass);
 }
 }
 $bag = $this->getParameterBag();
 if ($resolveEnvPlaceholders && $bag instanceof EnvPlaceholderParameterBag) {
 $compiler->addPass(new ResolveEnvPlaceholdersPass(), PassConfig::TYPE_AFTER_REMOVING, -1000);
 }
 $compiler->compile($this);
 foreach ($this->definitions as $id => $definition) {
 if ($this->trackResources && $definition->isLazy()) {
 $this->getReflectionClass($definition->getClass());
 }
 }
 $this->extensionConfigs = [];
 if ($bag instanceof EnvPlaceholderParameterBag) {
 if ($resolveEnvPlaceholders) {
 $this->parameterBag = new ParameterBag($this->resolveEnvPlaceholders($bag->all(), \true));
 }
 $this->envPlaceholders = $bag->getEnvPlaceholders();
 }
 parent::compile();
 foreach ($this->definitions + $this->aliasDefinitions as $id => $definition) {
 if (!$definition->isPublic() || $definition->isPrivate()) {
 $this->removedIds[$id] = \true;
 }
 }
 }
 public function getServiceIds()
 {
 return \array_map('strval', \array_unique(\array_merge(\array_keys($this->getDefinitions()), \array_keys($this->aliasDefinitions), parent::getServiceIds())));
 }
 public function getRemovedIds()
 {
 return $this->removedIds;
 }
 public function addAliases(array $aliases)
 {
 foreach ($aliases as $alias => $id) {
 $this->setAlias($alias, $id);
 }
 }
 public function setAliases(array $aliases)
 {
 $this->aliasDefinitions = [];
 $this->addAliases($aliases);
 }
 public function setAlias(string $alias, $id)
 {
 if ('' === $alias || '\\' === $alias[-1] || \strlen($alias) !== \strcspn($alias, "\x00\r\n'")) {
 throw new InvalidArgumentException(\sprintf('Invalid alias id: "%s".', $alias));
 }
 if (\is_string($id)) {
 $id = new Alias($id);
 } elseif (!$id instanceof Alias) {
 throw new InvalidArgumentException('$id must be a string, or an Alias object.');
 }
 if ($alias === (string) $id) {
 throw new InvalidArgumentException(\sprintf('An alias cannot reference itself, got a circular reference on "%s".', $alias));
 }
 unset($this->definitions[$alias], $this->removedIds[$alias]);
 return $this->aliasDefinitions[$alias] = $id;
 }
 public function removeAlias(string $alias)
 {
 if (isset($this->aliasDefinitions[$alias])) {
 unset($this->aliasDefinitions[$alias]);
 $this->removedIds[$alias] = \true;
 }
 }
 public function hasAlias(string $id)
 {
 return isset($this->aliasDefinitions[$id]);
 }
 public function getAliases()
 {
 return $this->aliasDefinitions;
 }
 public function getAlias(string $id)
 {
 if (!isset($this->aliasDefinitions[$id])) {
 throw new InvalidArgumentException(\sprintf('The service alias "%s" does not exist.', $id));
 }
 return $this->aliasDefinitions[$id];
 }
 public function register(string $id, string $class = null)
 {
 return $this->setDefinition($id, new Definition($class));
 }
 public function autowire(string $id, string $class = null)
 {
 return $this->setDefinition($id, (new Definition($class))->setAutowired(\true));
 }
 public function addDefinitions(array $definitions)
 {
 foreach ($definitions as $id => $definition) {
 $this->setDefinition($id, $definition);
 }
 }
 public function setDefinitions(array $definitions)
 {
 $this->definitions = [];
 $this->addDefinitions($definitions);
 }
 public function getDefinitions()
 {
 return $this->definitions;
 }
 public function setDefinition(string $id, Definition $definition)
 {
 if ($this->isCompiled()) {
 throw new BadMethodCallException('Adding definition to a compiled container is not allowed.');
 }
 if ('' === $id || '\\' === $id[-1] || \strlen($id) !== \strcspn($id, "\x00\r\n'")) {
 throw new InvalidArgumentException(\sprintf('Invalid service id: "%s".', $id));
 }
 unset($this->aliasDefinitions[$id], $this->removedIds[$id]);
 return $this->definitions[$id] = $definition;
 }
 public function hasDefinition(string $id)
 {
 return isset($this->definitions[$id]);
 }
 public function getDefinition(string $id)
 {
 if (!isset($this->definitions[$id])) {
 throw new ServiceNotFoundException($id);
 }
 return $this->definitions[$id];
 }
 public function findDefinition(string $id)
 {
 $seen = [];
 while (isset($this->aliasDefinitions[$id])) {
 $id = (string) $this->aliasDefinitions[$id];
 if (isset($seen[$id])) {
 $seen = \array_values($seen);
 $seen = \array_slice($seen, \array_search($id, $seen));
 $seen[] = $id;
 throw new ServiceCircularReferenceException($id, $seen);
 }
 $seen[$id] = $id;
 }
 return $this->getDefinition($id);
 }
 private function createService(Definition $definition, array &$inlineServices, bool $isConstructorArgument = \false, string $id = null, bool $tryProxy = \true)
 {
 if (null === $id && isset($inlineServices[$h = \spl_object_hash($definition)])) {
 return $inlineServices[$h];
 }
 if ($definition instanceof ChildDefinition) {
 throw new RuntimeException(\sprintf('Constructing service "%s" from a parent definition is not supported at build time.', $id));
 }
 if ($definition->isSynthetic()) {
 throw new RuntimeException(\sprintf('You have requested a synthetic service ("%s"). The DIC does not know how to construct this service.', $id));
 }
 if ($definition->isDeprecated()) {
 $deprecation = $definition->getDeprecation($id);
 trigger_deprecation($deprecation['package'], $deprecation['version'], $deprecation['message']);
 }
 if ($tryProxy && $definition->isLazy() && !($tryProxy = !($proxy = $this->proxyInstantiator) || $proxy instanceof RealServiceInstantiator)) {
 $proxy = $proxy->instantiateProxy($this, $definition, $id, function () use($definition, &$inlineServices, $id) {
 return $this->createService($definition, $inlineServices, \true, $id, \false);
 });
 $this->shareService($definition, $proxy, $id, $inlineServices);
 return $proxy;
 }
 $parameterBag = $this->getParameterBag();
 if (null !== $definition->getFile()) {
 require_once $parameterBag->resolveValue($definition->getFile());
 }
 $arguments = $this->doResolveServices($parameterBag->unescapeValue($parameterBag->resolveValue($definition->getArguments())), $inlineServices, $isConstructorArgument);
 if (null !== ($factory = $definition->getFactory())) {
 if (\is_array($factory)) {
 $factory = [$this->doResolveServices($parameterBag->resolveValue($factory[0]), $inlineServices, $isConstructorArgument), $factory[1]];
 } elseif (!\is_string($factory)) {
 throw new RuntimeException(\sprintf('Cannot create service "%s" because of invalid factory.', $id));
 }
 }
 if (null !== $id && $definition->isShared() && isset($this->services[$id]) && ($tryProxy || !$definition->isLazy())) {
 return $this->services[$id];
 }
 if (null !== $factory) {
 $service = $factory(...$arguments);
 if (!$definition->isDeprecated() && \is_array($factory) && \is_string($factory[0])) {
 $r = new \ReflectionClass($factory[0]);
 if (0 < \strpos($r->getDocComment(), "\n * @deprecated ")) {
 trigger_deprecation('', '', 'The "%s" service relies on the deprecated "%s" factory class. It should either be deprecated or its factory upgraded.', $id, $r->name);
 }
 }
 } else {
 $r = new \ReflectionClass($parameterBag->resolveValue($definition->getClass()));
 $service = null === $r->getConstructor() ? $r->newInstance() : $r->newInstanceArgs(\array_values($arguments));
 if (!$definition->isDeprecated() && 0 < \strpos($r->getDocComment(), "\n * @deprecated ")) {
 trigger_deprecation('', '', 'The "%s" service relies on the deprecated "%s" class. It should either be deprecated or its implementation upgraded.', $id, $r->name);
 }
 }
 $lastWitherIndex = null;
 foreach ($definition->getMethodCalls() as $k => $call) {
 if ($call[2] ?? \false) {
 $lastWitherIndex = $k;
 }
 }
 if (null === $lastWitherIndex && ($tryProxy || !$definition->isLazy())) {
 // share only if proxying failed, or if not a proxy, and if no withers are found
 $this->shareService($definition, $service, $id, $inlineServices);
 }
 $properties = $this->doResolveServices($parameterBag->unescapeValue($parameterBag->resolveValue($definition->getProperties())), $inlineServices);
 foreach ($properties as $name => $value) {
 $service->{$name} = $value;
 }
 foreach ($definition->getMethodCalls() as $k => $call) {
 $service = $this->callMethod($service, $call, $inlineServices);
 if ($lastWitherIndex === $k && ($tryProxy || !$definition->isLazy())) {
 // share only if proxying failed, or if not a proxy, and this is the last wither
 $this->shareService($definition, $service, $id, $inlineServices);
 }
 }
 if ($callable = $definition->getConfigurator()) {
 if (\is_array($callable)) {
 $callable[0] = $parameterBag->resolveValue($callable[0]);
 if ($callable[0] instanceof Reference) {
 $callable[0] = $this->doGet((string) $callable[0], $callable[0]->getInvalidBehavior(), $inlineServices);
 } elseif ($callable[0] instanceof Definition) {
 $callable[0] = $this->createService($callable[0], $inlineServices);
 }
 }
 if (!\is_callable($callable)) {
 throw new InvalidArgumentException(\sprintf('The configure callable for class "%s" is not a callable.', \get_debug_type($service)));
 }
 $callable($service);
 }
 return $service;
 }
 public function resolveServices($value)
 {
 return $this->doResolveServices($value);
 }
 private function doResolveServices($value, array &$inlineServices = [], bool $isConstructorArgument = \false)
 {
 if (\is_array($value)) {
 foreach ($value as $k => $v) {
 $value[$k] = $this->doResolveServices($v, $inlineServices, $isConstructorArgument);
 }
 } elseif ($value instanceof ServiceClosureArgument) {
 $reference = $value->getValues()[0];
 $value = function () use($reference) {
 return $this->resolveServices($reference);
 };
 } elseif ($value instanceof IteratorArgument) {
 $value = new RewindableGenerator(function () use($value, &$inlineServices) {
 foreach ($value->getValues() as $k => $v) {
 foreach (self::getServiceConditionals($v) as $s) {
 if (!$this->has($s)) {
 continue 2;
 }
 }
 foreach (self::getInitializedConditionals($v) as $s) {
 if (!$this->doGet($s, ContainerInterface::IGNORE_ON_UNINITIALIZED_REFERENCE, $inlineServices)) {
 continue 2;
 }
 }
 (yield $k => $this->doResolveServices($v, $inlineServices));
 }
 }, function () use($value) : int {
 $count = 0;
 foreach ($value->getValues() as $v) {
 foreach (self::getServiceConditionals($v) as $s) {
 if (!$this->has($s)) {
 continue 2;
 }
 }
 foreach (self::getInitializedConditionals($v) as $s) {
 if (!$this->doGet($s, ContainerInterface::IGNORE_ON_UNINITIALIZED_REFERENCE)) {
 continue 2;
 }
 }
 ++$count;
 }
 return $count;
 });
 } elseif ($value instanceof ServiceLocatorArgument) {
 $refs = $types = [];
 foreach ($value->getValues() as $k => $v) {
 if ($v) {
 $refs[$k] = [$v];
 $types[$k] = $v instanceof TypedReference ? $v->getType() : '?';
 }
 }
 $value = new ServiceLocator(\Closure::fromCallable([$this, 'resolveServices']), $refs, $types);
 } elseif ($value instanceof Reference) {
 $value = $this->doGet((string) $value, $value->getInvalidBehavior(), $inlineServices, $isConstructorArgument);
 } elseif ($value instanceof Definition) {
 $value = $this->createService($value, $inlineServices, $isConstructorArgument);
 } elseif ($value instanceof Parameter) {
 $value = $this->getParameter((string) $value);
 } elseif ($value instanceof Expression) {
 $value = $this->getExpressionLanguage()->evaluate($value, ['container' => $this]);
 } elseif ($value instanceof AbstractArgument) {
 throw new RuntimeException($value->getTextWithContext());
 }
 return $value;
 }
 public function findTaggedServiceIds(string $name, bool $throwOnAbstract = \false)
 {
 $this->usedTags[] = $name;
 $tags = [];
 foreach ($this->getDefinitions() as $id => $definition) {
 if ($definition->hasTag($name)) {
 if ($throwOnAbstract && $definition->isAbstract()) {
 throw new InvalidArgumentException(\sprintf('The service "%s" tagged "%s" must not be abstract.', $id, $name));
 }
 $tags[$id] = $definition->getTag($name);
 }
 }
 return $tags;
 }
 public function findTags()
 {
 $tags = [];
 foreach ($this->getDefinitions() as $id => $definition) {
 $tags[] = \array_keys($definition->getTags());
 }
 return \array_unique(\array_merge([], ...$tags));
 }
 public function findUnusedTags()
 {
 return \array_values(\array_diff($this->findTags(), $this->usedTags));
 }
 public function addExpressionLanguageProvider(ExpressionFunctionProviderInterface $provider)
 {
 $this->expressionLanguageProviders[] = $provider;
 }
 public function getExpressionLanguageProviders()
 {
 return $this->expressionLanguageProviders;
 }
 public function registerForAutoconfiguration(string $interface)
 {
 if (!isset($this->autoconfiguredInstanceof[$interface])) {
 $this->autoconfiguredInstanceof[$interface] = new ChildDefinition('');
 }
 return $this->autoconfiguredInstanceof[$interface];
 }
 public function registerAttributeForAutoconfiguration(string $attributeClass, callable $configurator) : void
 {
 $this->autoconfiguredAttributes[$attributeClass] = $configurator;
 }
 public function registerAliasForArgument(string $id, string $type, string $name = null) : Alias
 {
 $name = (new Target($name ?? $id))->name;
 if (!\preg_match('/^[a-zA-Z_\\x7f-\\xff]/', $name)) {
 throw new InvalidArgumentException(\sprintf('Invalid argument name "%s" for service "%s": the first character must be a letter.', $name, $id));
 }
 return $this->setAlias($type . ' $' . $name, $id);
 }
 public function getAutoconfiguredInstanceof()
 {
 return $this->autoconfiguredInstanceof;
 }
 public function getAutoconfiguredAttributes() : array
 {
 return $this->autoconfiguredAttributes;
 }
 public function resolveEnvPlaceholders($value, $format = null, array &$usedEnvs = null)
 {
 if (null === $format) {
 $format = '%%env(%s)%%';
 }
 $bag = $this->getParameterBag();
 if (\true === $format) {
 $value = $bag->resolveValue($value);
 }
 if ($value instanceof Definition) {
 $value = (array) $value;
 }
 if (\is_array($value)) {
 $result = [];
 foreach ($value as $k => $v) {
 $result[\is_string($k) ? $this->resolveEnvPlaceholders($k, $format, $usedEnvs) : $k] = $this->resolveEnvPlaceholders($v, $format, $usedEnvs);
 }
 return $result;
 }
 if (!\is_string($value) || 38 > \strlen($value) || !\preg_match('/env[_(]/i', $value)) {
 return $value;
 }
 $envPlaceholders = $bag instanceof EnvPlaceholderParameterBag ? $bag->getEnvPlaceholders() : $this->envPlaceholders;
 $completed = \false;
 foreach ($envPlaceholders as $env => $placeholders) {
 foreach ($placeholders as $placeholder) {
 if (\false !== \stripos($value, $placeholder)) {
 if (\true === $format) {
 $resolved = $bag->escapeValue($this->getEnv($env));
 } else {
 $resolved = \sprintf($format, $env);
 }
 if ($placeholder === $value) {
 $value = $resolved;
 $completed = \true;
 } else {
 if (!\is_string($resolved) && !\is_numeric($resolved)) {
 throw new RuntimeException(\sprintf('A string value must be composed of strings and/or numbers, but found parameter "env(%s)" of type "%s" inside string value "%s".', $env, \get_debug_type($resolved), $this->resolveEnvPlaceholders($value)));
 }
 $value = \str_ireplace($placeholder, $resolved, $value);
 }
 $usedEnvs[$env] = $env;
 $this->envCounters[$env] = isset($this->envCounters[$env]) ? 1 + $this->envCounters[$env] : 1;
 if ($completed) {
 break 2;
 }
 }
 }
 }
 return $value;
 }
 public function getEnvCounters()
 {
 $bag = $this->getParameterBag();
 $envPlaceholders = $bag instanceof EnvPlaceholderParameterBag ? $bag->getEnvPlaceholders() : $this->envPlaceholders;
 foreach ($envPlaceholders as $env => $placeholders) {
 if (!isset($this->envCounters[$env])) {
 $this->envCounters[$env] = 0;
 }
 }
 return $this->envCounters;
 }
 public function log(CompilerPassInterface $pass, string $message)
 {
 $this->getCompiler()->log($pass, $this->resolveEnvPlaceholders($message));
 }
 public static final function willBeAvailable(string $package, string $class, array $parentPackages) : bool
 {
 $skipDeprecation = 3 < \func_num_args() && \func_get_arg(3);
 $hasRuntimeApi = \class_exists(InstalledVersions::class);
 if (!$hasRuntimeApi && !$skipDeprecation) {
 trigger_deprecation('symfony/dependency-injection', '5.4', 'Calling "%s" when dependencies have been installed with Composer 1 is deprecated. Consider upgrading to Composer 2.', __METHOD__);
 }
 if (!\class_exists($class) && !\interface_exists($class, \false) && !\trait_exists($class, \false)) {
 return \false;
 }
 if (!$hasRuntimeApi || !InstalledVersions::isInstalled($package) || InstalledVersions::isInstalled($package, \false)) {
 return \true;
 }
 // the package is installed but in dev-mode only, check if this applies to one of the parent packages too
 $rootPackage = InstalledVersions::getRootPackage()['name'] ?? '';
 if ('symfony/symfony' === $rootPackage) {
 return \true;
 }
 foreach ($parentPackages as $parentPackage) {
 if ($rootPackage === $parentPackage || InstalledVersions::isInstalled($parentPackage) && !InstalledVersions::isInstalled($parentPackage, \false)) {
 return \true;
 }
 }
 return \false;
 }
 public function getRemovedBindingIds() : array
 {
 return $this->removedBindingIds;
 }
 public function removeBindings(string $id)
 {
 if ($this->hasDefinition($id)) {
 foreach ($this->getDefinition($id)->getBindings() as $key => $binding) {
 [, $bindingId] = $binding->getValues();
 $this->removedBindingIds[(int) $bindingId] = \true;
 }
 }
 }
 public static function getServiceConditionals($value) : array
 {
 $services = [];
 if (\is_array($value)) {
 foreach ($value as $v) {
 $services = \array_unique(\array_merge($services, self::getServiceConditionals($v)));
 }
 } elseif ($value instanceof Reference && ContainerInterface::IGNORE_ON_INVALID_REFERENCE === $value->getInvalidBehavior()) {
 $services[] = (string) $value;
 }
 return $services;
 }
 public static function getInitializedConditionals($value) : array
 {
 $services = [];
 if (\is_array($value)) {
 foreach ($value as $v) {
 $services = \array_unique(\array_merge($services, self::getInitializedConditionals($v)));
 }
 } elseif ($value instanceof Reference && ContainerInterface::IGNORE_ON_UNINITIALIZED_REFERENCE === $value->getInvalidBehavior()) {
 $services[] = (string) $value;
 }
 return $services;
 }
 public static function hash($value)
 {
 $hash = \substr(\base64_encode(\hash('sha256', \serialize($value), \true)), 0, 7);
 return \str_replace(['/', '+'], ['.', '_'], $hash);
 }
 protected function getEnv(string $name)
 {
 $value = parent::getEnv($name);
 $bag = $this->getParameterBag();
 if (!\is_string($value) || !$bag instanceof EnvPlaceholderParameterBag) {
 return $value;
 }
 $envPlaceholders = $bag->getEnvPlaceholders();
 if (isset($envPlaceholders[$name][$value])) {
 $bag = new ParameterBag($bag->all());
 return $bag->unescapeValue($bag->get("env({$name})"));
 }
 foreach ($envPlaceholders as $env => $placeholders) {
 if (isset($placeholders[$value])) {
 return $this->getEnv($env);
 }
 }
 $this->resolving["env({$name})"] = \true;
 try {
 return $bag->unescapeValue($this->resolveEnvPlaceholders($bag->escapeValue($value), \true));
 } finally {
 unset($this->resolving["env({$name})"]);
 }
 }
 private function callMethod(object $service, array $call, array &$inlineServices)
 {
 foreach (self::getServiceConditionals($call[1]) as $s) {
 if (!$this->has($s)) {
 return $service;
 }
 }
 foreach (self::getInitializedConditionals($call[1]) as $s) {
 if (!$this->doGet($s, ContainerInterface::IGNORE_ON_UNINITIALIZED_REFERENCE, $inlineServices)) {
 return $service;
 }
 }
 $result = $service->{$call[0]}(...$this->doResolveServices($this->getParameterBag()->unescapeValue($this->getParameterBag()->resolveValue($call[1])), $inlineServices));
 return empty($call[2]) ? $service : $result;
 }
 private function shareService(Definition $definition, $service, ?string $id, array &$inlineServices)
 {
 $inlineServices[$id ?? \spl_object_hash($definition)] = $service;
 if (null !== $id && $definition->isShared()) {
 $this->services[$id] = $service;
 unset($this->loading[$id]);
 }
 }
 private function getExpressionLanguage() : ExpressionLanguage
 {
 if (null === $this->expressionLanguage) {
 if (!\class_exists(\MailPoetVendor\Symfony\Component\ExpressionLanguage\ExpressionLanguage::class)) {
 throw new LogicException('Unable to use expressions as the Symfony ExpressionLanguage component is not installed.');
 }
 $this->expressionLanguage = new ExpressionLanguage(null, $this->expressionLanguageProviders);
 }
 return $this->expressionLanguage;
 }
 private function inVendors(string $path) : bool
 {
 if (null === $this->vendors) {
 $this->vendors = (new ComposerResource())->getVendors();
 }
 $path = \realpath($path) ?: $path;
 foreach ($this->vendors as $vendor) {
 if (\str_starts_with($path, $vendor) && \false !== \strpbrk(\substr($path, \strlen($vendor), 1), '/' . \DIRECTORY_SEPARATOR)) {
 $this->addResource(new FileResource($vendor . '/composer/installed.json'));
 return \true;
 }
 }
 return \false;
 }
}