Skip to content

royopa/OcraDiCompiler

 
 

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

22 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

OcraDiCompiler

A compiler module to make Zend\Di\Di based applications blazing fast!

Requirements

Installation

  1. Add "ocramius/ocra-di-compiler": "dev-master" to your composer.json
  2. Run php composer.phar install
  3. Enable the module in your config/application.config.php by adding OcraDiCompiler to modules

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.

Performance comparison

Given a default setup of an application with doctrine/DoctrineORMModule enabled and following class:

<?php
class MyClass
{
    public function __construct(\Doctrine\ORM\EntityManager $em)
    {
    }
}

following code

<?php
$serviceManager->get('Application')->bootstrap();
$serviceManager->get('Di')->get('MyClass');

should be noticeably faster (please leave me your feedback and your personal results!).

Credits

Many thanks to Sascha Oliver Prolic, who wrote the implementation of the DiProxyGenerator and patiently waited for me to get this module implemented

About

Zend\Di compiler utility module to make ZF2 applications blazing fast

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages

  • PHP 100.0%