Julio Montoya 321ce65f18 Updating vendors 11 éve
..
Compiler 321ce65f18 Updating vendors 11 éve
Dumper 321ce65f18 Updating vendors 11 éve
Exception d7041815fc Updating vendors 11 éve
Extension c36303a24b Updating vendors 11 éve
LazyProxy 321ce65f18 Updating vendors 11 éve
Loader d7041815fc Updating vendors 11 éve
ParameterBag d7041815fc Updating vendors 11 éve
Tests 321ce65f18 Updating vendors 11 éve
Alias.php 32682a9ca8 Updating vendor 12 éve
CHANGELOG.md 1ad9119c46 Updating vendors + adding doctrine bridge, and forms 12 éve
Container.php 321ce65f18 Updating vendors 11 éve
ContainerAware.php 32682a9ca8 Updating vendor 12 éve
ContainerAwareInterface.php 06eb0a00e6 Updating vendors 12 éve
ContainerBuilder.php 3dd9d88e31 Updating vendors 11 éve
ContainerInterface.php 32682a9ca8 Updating vendor 12 éve
Definition.php d7041815fc Updating vendors 11 éve
DefinitionDecorator.php 321ce65f18 Updating vendors 11 éve
IntrospectableContainerInterface.php 32682a9ca8 Updating vendor 12 éve
LICENSE 32682a9ca8 Updating vendor 12 éve
Parameter.php 32682a9ca8 Updating vendor 12 éve
README.md 32682a9ca8 Updating vendor 12 éve
Reference.php 32682a9ca8 Updating vendor 12 éve
Scope.php 32682a9ca8 Updating vendor 12 éve
ScopeInterface.php 32682a9ca8 Updating vendor 12 éve
SimpleXMLElement.php 32682a9ca8 Updating vendor 12 éve
TaggedContainerInterface.php 32682a9ca8 Updating vendor 12 éve
Variable.php 32682a9ca8 Updating vendor 12 éve
composer.json 224a0e666e Updating vendors 11 éve
phpunit.xml.dist 32682a9ca8 Updating vendor 12 éve

README.md

DependencyInjection Component

DependencyInjection manages your services via a robust and flexible Dependency Injection Container.

Here is a simple example that shows how to register services and parameters:

use Symfony\Component\DependencyInjection\ContainerBuilder;
use Symfony\Component\DependencyInjection\Reference;

$sc = new ContainerBuilder();
$sc
    ->register('foo', '%foo.class%')
    ->addArgument(new Reference('bar'))
;
$sc->setParameter('foo.class', 'Foo');

$sc->get('foo');

Method Calls (Setter Injection):

$sc = new ContainerBuilder();

$sc
    ->register('bar', '%bar.class%')
    ->addMethodCall('setFoo', array(new Reference('foo')))
;
$sc->setParameter('bar.class', 'Bar');

$sc->get('bar');

Factory Class:

If your service is retrieved by calling a static method:

$sc = new ContainerBuilder();

$sc
    ->register('bar', '%bar.class%')
    ->setFactoryClass('%bar.class%')
    ->setFactoryMethod('getInstance')
    ->addArgument('Aarrg!!!')
;
$sc->setParameter('bar.class', 'Bar');

$sc->get('bar');

File Include:

For some services, especially those that are difficult or impossible to autoload, you may need the container to include a file before instantiating your class.

$sc = new ContainerBuilder();

$sc
    ->register('bar', '%bar.class%')
    ->setFile('/path/to/file')
    ->addArgument('Aarrg!!!')
;
$sc->setParameter('bar.class', 'Bar');

$sc->get('bar');

Resources

You can run the unit tests with the following command:

$ cd path/to/Symfony/Component/DependencyInjection/
$ composer.phar install --dev
$ phpunit