From 395e7e8e53c63cb35ab70f53e1ecd6a3a8daef66 Mon Sep 17 00:00:00 2001 From: Jakub Stasiak Date: Mon, 11 Sep 2023 23:43:25 +0200 Subject: [PATCH] Expand call_with_injection() documentation (#233) I thought it could use some clarifications. --- injector/__init__.py | 8 ++++++++ 1 file changed, 8 insertions(+) diff --git a/injector/__init__.py b/injector/__init__.py index f146db1..4136f8f 100644 --- a/injector/__init__.py +++ b/injector/__init__.py @@ -1007,6 +1007,14 @@ def call_with_injection( ) -> T: """Call a callable and provide its dependencies if needed. + Dependencies are provided when the callable is decorated with :func:`@inject ` + or some individual parameters are wrapped in :data:`Inject` – otherwise + ``call_with_injection()`` is equivalent to just calling the callable directly. + + If there is an overlap between arguments provided in ``args`` and ``kwargs`` + and injectable dependencies the provided values take precedence and no dependency + injection process will take place for the corresponding parameters. + :param self_: Instance of a class callable belongs to if it's a method, None otherwise. :param args: Arguments to pass to callable.