public function Container::__construct in Drupal 9
Same name and namespace in other branches
- 8 core/lib/Drupal/Component/DependencyInjection/Container.php \Drupal\Component\DependencyInjection\Container::__construct()
Constructs a new Container instance.
Parameters
array $container_definition: An array containing the following keys:
- aliases: The aliases of the container.
- parameters: The parameters of the container.
- services: The service definitions of the container.
- frozen: Whether the container definition came from a frozen container builder or not.
- machine_format: Whether this container definition uses the optimized machine-readable container format.
1 method overrides Container::__construct()
- PhpArrayContainer::__construct in core/
lib/ Drupal/ Component/ DependencyInjection/ PhpArrayContainer.php - Constructs a new Container instance.
File
- core/
lib/ Drupal/ Component/ DependencyInjection/ Container.php, line 113
Class
- Container
- Provides a container optimized for Drupal's needs.
Namespace
Drupal\Component\DependencyInjectionCode
public function __construct(array $container_definition = []) {
if (!empty($container_definition) && (!isset($container_definition['machine_format']) || $container_definition['machine_format'] !== TRUE)) {
throw new InvalidArgumentException('The non-optimized format is not supported by this class. Use an optimized machine-readable format instead, e.g. as produced by \\Drupal\\Component\\DependencyInjection\\Dumper\\OptimizedPhpArrayDumper.');
}
$this->aliases = isset($container_definition['aliases']) ? $container_definition['aliases'] : [];
$this->parameters = isset($container_definition['parameters']) ? $container_definition['parameters'] : [];
$this->serviceDefinitions = isset($container_definition['services']) ? $container_definition['services'] : [];
$this->frozen = isset($container_definition['frozen']) ? $container_definition['frozen'] : FALSE;
// Register the service_container with itself.
$this->services['service_container'] = $this;
}