mirror of
https://github.com/ets-labs/python-dependency-injector.git
synced 2024-11-27 12:04:00 +03:00
6eff213a68
* Add bootstrap and remove created at from ghnav-flask app * Update readme * Add logo to the docs * Update key features description * Update README * Change headers of API docs * Add alabaster theme config * Update docs index * Add tutorials section * Update what is DI page * Update DI in Python page * Update tutorials index page * Update provider docs * Update container docs * Update examples docs
42 lines
1.4 KiB
ReStructuredText
42 lines
1.4 KiB
ReStructuredText
Overriding of containers
|
|
------------------------
|
|
|
|
.. currentmodule:: dependency_injector.containers
|
|
|
|
Containers can be overridden by other containers. This, actually, means that
|
|
all of the providers from overriding container will override providers with
|
|
the same names in overridden container.
|
|
|
|
There are two ways to override :py:class:`DeclarativeContainer` with another
|
|
container:
|
|
|
|
- Use :py:meth:`DeclarativeContainer.override` method.
|
|
- Use :py:func:`override` class decorator.
|
|
|
|
Example of overriding container using :py:meth:`DeclarativeContainer.override`
|
|
method:
|
|
|
|
.. literalinclude:: ../../examples/containers/override_declarative.py
|
|
:language: python
|
|
|
|
Example of overriding container using :py:func:`override` decorator:
|
|
|
|
.. literalinclude:: ../../examples/containers/override_declarative_decorator.py
|
|
:language: python
|
|
|
|
Also there are several useful :py:class:`DeclarativeContainer` methods and
|
|
properties that help to work with container overridings:
|
|
|
|
- :py:attr:`DeclarativeContainer.overridden` - tuple of all overriding
|
|
containers.
|
|
- :py:meth:`DeclarativeContainer.reset_last_overriding()` - reset last
|
|
overriding provider for each container providers.
|
|
- :py:meth:`DeclarativeContainer.reset_override()` - reset all overridings
|
|
for each container providers.
|
|
|
|
:py:class:`DynamicContainer` has exactly the same functionality, except of
|
|
:py:func:`override` decorator.
|
|
|
|
|
|
.. disqus::
|