Last active
October 10, 2018 06:44
-
-
Save bazo/358977a9c27d7ed92ef8 to your computer and use it in GitHub Desktop.
This file contains hidden or bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
<?php | |
use Nette\Application\UI\Presenter; | |
use Nette\DI\CompilerExtension; | |
/** | |
* Auto register presenters as services | |
* @author Martin Bažík <[email protected]> | |
*/ | |
class PresenterExtension extends CompilerExtension | |
{ | |
private $defaults = [ | |
'robotLoaderVarName' => 'robotLoader' | |
]; | |
public function loadConfiguration() | |
{ | |
$config = $this->getConfig($this->defaults); | |
$builder = $this->getContainerBuilder(); | |
$robotLoaderVarName = $config['robotLoaderVarName']; | |
global $$robotLoaderVarName; | |
$classes = $$robotLoaderVarName->getIndexedClasses(); | |
foreach ($classes as $class => $file) { | |
$r = new ReflectionClass($class); | |
if (!$r->isAbstract() and $r->isSubclassOf(Presenter::class)) { | |
$defName = str_replace('\\', '_', $r->getName()); | |
$builder | |
->addDefinition($defName) | |
->setClass($class) | |
->setAutowired(FALSE) | |
; | |
} | |
} | |
} | |
} |
@TomasVotruba in 2.2, there is addExcludedClasses
http://phpfashion.com/pet-duvodu-upgradovat-na-nette-2-2-3
Thanks both. With addExcludedClasses
and setAutowired(FALSE)
everything seems to work fine.
I've got more time for testing now and had problem:
- with inject as you wrote Filip
- and autowired property in trait. Had to made it public to make it work.
I really don't understand the output of your discussion with David. Could you sum up pls?
Sign up for free
to join this conversation on GitHub.
Already have an account?
Sign in to comment
@bazo Just pushing the boundaries :) Thanks for starting discussion with some specific code.
The component issue can be also solved via own BaseControl with empty __construct.
Thanks @fprochazka for extension, gonna test it soon.