OcraDiCompiler
A compiler module to make Zend\Di\Di based applications blazing fast!, (*1)
Requirements
Installation
- Add
"ocramius/ocra-di-compiler": "dev-master" to your composer.json
- Run
php composer.phar install
- Enable the module in your
config/application.config.php by adding OcraDiCompiler to modules
or, (*2)
php composer.phar ocramius/ocra-di-compiler
Functionality
OcraDiCompiler interacts with the bootstrap process of your application by trying to write a compiled Zend\Di\Di class
into your data directory.
The compiled Di container will be available after the bootstrap event of your application. Before that, any attempt
to access Di will fetch the default one.
You can customize where the compiled Di class will be written (and from where it will be read) by overriding the values
in config/module.config.php in your own config file in the config/autoload directory., (*3)
Given a default setup of an application with doctrine/DoctrineORMModule enabled and following class:, (*4)
<?php
class MyClass
{
public function __construct(\Doctrine\ORM\EntityManager $em)
{
}
}
following code, (*5)
<?php
$serviceManager->get('Application')->bootstrap();
$serviceManager->get('Di')->get('MyClass');
should be noticeably faster (please leave me your feedback and your personal results!)., (*6)
Credits
Many thanks to Sascha Oliver Prolic, who wrote the implementation of the DiProxyGenerator
and patiently waited for me to get this module implemented, (*7)