mirror of
https://github.com/ets-labs/python-dependency-injector.git
synced 2024-11-29 04:53:59 +03:00
62 lines
2.3 KiB
ReStructuredText
62 lines
2.3 KiB
ReStructuredText
Callable providers
|
|
------------------
|
|
|
|
``di.Callable`` provider is a provider that wraps particular callable with
|
|
some injections. Every call of this provider returns result of call of initial
|
|
callable.
|
|
|
|
Callable providers and injections
|
|
~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
|
|
|
|
``di.Callable`` takes a various number of positional and keyword arguments
|
|
that are used as decorated callable injections. Every time, when
|
|
``di.Callable`` is called, positional and keyword argument injections would be
|
|
passed as an callable arguments.
|
|
|
|
Such behaviour is very similar to the standard Python ``functools.partial``
|
|
object, except of one thing: all injectable values are provided
|
|
*"as is"*, except of providers (subclasses of ``di.Provider``). Providers
|
|
will be called every time, when injection needs to be done. For example,
|
|
if injectable value of injection is a ``di.Factory``, it will provide new one
|
|
instance (as a result of its call) every time, when injection needs to be done.
|
|
|
|
``di.Callable`` behaviour with context positional and keyword arguments is
|
|
very like a standard Python ``functools.partial``:
|
|
|
|
- Positional context arguments will be appended after ``di.Callable``
|
|
positional injections.
|
|
- Keyword context arguments have priority on ``di.Callable`` keyword
|
|
injections and will be merged over them.
|
|
|
|
Example that shows usage of ``di.Callable`` with positional argument
|
|
injections:
|
|
|
|
.. literalinclude:: ../../examples/providers/callable_args.py
|
|
:language: python
|
|
|
|
Next one example shows usage of ``di.Callable`` with keyword argument
|
|
injections:
|
|
|
|
.. image:: /images/providers/callable.png
|
|
:width: 100%
|
|
:align: center
|
|
|
|
.. literalinclude:: ../../examples/providers/callable_kwargs.py
|
|
:language: python
|
|
|
|
Callable providers delegation
|
|
~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
|
|
|
|
``di.Callable`` provider could be delegated to any other provider via any kind
|
|
of injection. Delegation of ``di.Callable`` providers is the same as
|
|
``di.Factory`` and ``di.Singleton`` providers delegation, please follow
|
|
*Factory providers delegation* section for example.
|
|
|
|
``di.Callable`` delegate could be created obviously using
|
|
``di.Delegate(di.Callable())`` or by calling ``di.Callable.delegate()`` method.
|
|
|
|
Example:
|
|
|
|
.. literalinclude:: ../../examples/providers/callable_delegation.py
|
|
:language: python
|