addExtension() public method

Add custom configurator extension.
public addExtension ( $name, CompilerExtension $extension ) : self
$extension CompilerExtension
return self
Esempio n. 1
0
 protected function _before()
 {
     $this->compiler = new \Nette\DI\Compiler();
     $this->compiler->addConfig(['parameters' => ['debugMode' => TRUE]]);
     $this->compiler->addExtension('params', new \WebChemistry\Parameters\DI\ParametersExtension());
     $this->compiler->addExtension('http', new \Nette\Bridges\HttpDI\HttpExtension());
     $this->compiler->addExtension('mock', new MockExtension());
 }
Esempio n. 2
0
 /**
  * Register extension if not registered by user.
  */
 private static function registerAdditionalExtension(\Nette\DI\Compiler $compiler, $name, $newExtension)
 {
     $extensions = [];
     foreach (isset($compiler->config['extensions']) ? $compiler->config['extensions'] : [] as $extension) {
         if (is_string($extension)) {
             $extensions[] = $extension;
         } elseif ($extension instanceof \Nette\DI\Statement) {
             $extensions[] = $extension->getEntity();
         }
     }
     if ($extensions && !in_array(get_class($newExtension), $extensions)) {
         $compiler->addExtension($name, $newExtension);
     }
 }
Esempio n. 3
0
 /**
  * @return Compiler
  */
 protected function createCompiler()
 {
     $compiler = new DI\Compiler();
     foreach ($this->defaultExtensions as $name => $class) {
         $compiler->addExtension($name, new $class());
     }
     return $compiler;
 }
 protected function _before()
 {
     $this->compiler = new \Nette\DI\Compiler();
     $this->compiler->addExtension('multiplier', new \WebChemistry\Forms\Controls\DI\MultiplierExtension());
 }
Esempio n. 5
0
 /**
  * @return Compiler
  */
 protected function createCompiler()
 {
     $compiler = new DI\Compiler();
     $compiler->addExtension('php', new DI\Extensions\PhpExtension())->addExtension('constants', new DI\Extensions\ConstantsExtension())->addExtension('nette', new DI\Extensions\NetteExtension())->addExtension('extensions', new DI\Extensions\ExtensionsExtension());
     return $compiler;
 }
Esempio n. 6
0
 /**
  * @return string
  * @internal
  */
 public function generateContainer(DI\Compiler $compiler)
 {
     $loader = $this->createLoader();
     $compiler->addConfig(['parameters' => $this->parameters]);
     $fileInfo = [];
     foreach ($this->files as $info) {
         if (is_scalar($info[0])) {
             $fileInfo[] = "// source: {$info['0']} {$info['1']}";
             $info[0] = $loader->load($info[0], $info[1]);
         }
         $compiler->addConfig($this->fixCompatibility($info[0]));
     }
     $compiler->addDependencies($loader->getDependencies());
     $builder = $compiler->getContainerBuilder();
     $builder->addExcludedClasses($this->autowireExcludedClasses);
     foreach ($this->defaultExtensions as $name => $extension) {
         list($class, $args) = is_string($extension) ? [$extension, []] : $extension;
         if (class_exists($class)) {
             $args = DI\Helpers::expand($args, $this->parameters, TRUE);
             $compiler->addExtension($name, (new \ReflectionClass($class))->newInstanceArgs($args));
         }
     }
     $this->onCompile($this, $compiler);
     $classes = $compiler->compile();
     if (!empty($builder->parameters['container']['parent'])) {
         $classes[0]->setExtends($builder->parameters['container']['parent']);
     }
     return implode("\n", $fileInfo) . "\n\n" . implode("\n\n\n", $classes) . (($tmp = $builder->parameters['container']['class']) ? "\nclass {$tmp} extends {$builder->getClassName()} {}\n" : '');
 }