modern-di 0.9.0__py3-none-any.whl → 0.10.0__py3-none-any.whl
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Potentially problematic release.
This version of modern-di might be problematic. Click here for more details.
- modern_di/container.py +1 -1
- modern_di/providers/abstract.py +19 -21
- modern_di/providers/factory.py +7 -3
- modern_di/providers/injected_factory.py +20 -4
- {modern_di-0.9.0.dist-info → modern_di-0.10.0.dist-info}/METADATA +3 -3
- {modern_di-0.9.0.dist-info → modern_di-0.10.0.dist-info}/RECORD +7 -7
- {modern_di-0.9.0.dist-info → modern_di-0.10.0.dist-info}/WHEEL +1 -1
modern_di/container.py
CHANGED
|
@@ -13,7 +13,7 @@ if typing.TYPE_CHECKING:
|
|
|
13
13
|
T_co = typing.TypeVar("T_co", covariant=True)
|
|
14
14
|
|
|
15
15
|
|
|
16
|
-
class Container(contextlib.AbstractAsyncContextManager["Container"]):
|
|
16
|
+
class Container(contextlib.AbstractAsyncContextManager["Container"], contextlib.AbstractContextManager["Container"]):
|
|
17
17
|
__slots__ = (
|
|
18
18
|
"_is_async",
|
|
19
19
|
"_overrides",
|
modern_di/providers/abstract.py
CHANGED
|
@@ -61,31 +61,29 @@ class AbstractCreatorProvider(AbstractOverrideProvider[T_co], abc.ABC):
|
|
|
61
61
|
self._args: typing.Final = args
|
|
62
62
|
self._kwargs: typing.Final = kwargs
|
|
63
63
|
|
|
64
|
+
def _sync_resolve_args(self, container: Container) -> list[typing.Any]:
|
|
65
|
+
return [x.sync_resolve(container) if isinstance(x, AbstractProvider) else x for x in self._args]
|
|
66
|
+
|
|
67
|
+
def _sync_resolve_kwargs(self, container: Container) -> dict[str, typing.Any]:
|
|
68
|
+
return {k: v.sync_resolve(container) if isinstance(v, AbstractProvider) else v for k, v in self._kwargs.items()}
|
|
69
|
+
|
|
64
70
|
def _sync_build_creator(self, container: Container) -> typing.Any: # noqa: ANN401
|
|
65
71
|
return self._creator(
|
|
66
|
-
*typing.cast(
|
|
67
|
-
|
|
68
|
-
),
|
|
69
|
-
**typing.cast(
|
|
70
|
-
P.kwargs,
|
|
71
|
-
{
|
|
72
|
-
k: v.sync_resolve(container) if isinstance(v, AbstractProvider) else v
|
|
73
|
-
for k, v in self._kwargs.items()
|
|
74
|
-
},
|
|
75
|
-
),
|
|
72
|
+
*typing.cast(P.args, self._sync_resolve_args(container)),
|
|
73
|
+
**typing.cast(P.kwargs, self._sync_resolve_kwargs(container)),
|
|
76
74
|
)
|
|
77
75
|
|
|
76
|
+
async def _async_resolve_args(self, container: Container) -> list[typing.Any]:
|
|
77
|
+
return [await x.async_resolve(container) if isinstance(x, AbstractProvider) else x for x in self._args]
|
|
78
|
+
|
|
79
|
+
async def _async_resolve_kwargs(self, container: Container) -> dict[str, typing.Any]:
|
|
80
|
+
return {
|
|
81
|
+
k: await v.async_resolve(container) if isinstance(v, AbstractProvider) else v
|
|
82
|
+
for k, v in self._kwargs.items()
|
|
83
|
+
}
|
|
84
|
+
|
|
78
85
|
async def _async_build_creator(self, container: Container) -> typing.Any: # noqa: ANN401
|
|
79
86
|
return self._creator(
|
|
80
|
-
*typing.cast(
|
|
81
|
-
|
|
82
|
-
[await x.async_resolve(container) if isinstance(x, AbstractProvider) else x for x in self._args],
|
|
83
|
-
),
|
|
84
|
-
**typing.cast(
|
|
85
|
-
P.kwargs,
|
|
86
|
-
{
|
|
87
|
-
k: await v.async_resolve(container) if isinstance(v, AbstractProvider) else v
|
|
88
|
-
for k, v in self._kwargs.items()
|
|
89
|
-
},
|
|
90
|
-
),
|
|
87
|
+
*typing.cast(P.args, await self._async_resolve_args(container)),
|
|
88
|
+
**typing.cast(P.kwargs, await self._async_resolve_kwargs(container)),
|
|
91
89
|
)
|
modern_di/providers/factory.py
CHANGED
|
@@ -3,7 +3,7 @@ import typing
|
|
|
3
3
|
|
|
4
4
|
from modern_di import Container
|
|
5
5
|
from modern_di.providers.abstract import AbstractCreatorProvider
|
|
6
|
-
from modern_di.providers.injected_factory import
|
|
6
|
+
from modern_di.providers.injected_factory import AsyncInjectedFactory, SyncInjectedFactory
|
|
7
7
|
|
|
8
8
|
|
|
9
9
|
T_co = typing.TypeVar("T_co", covariant=True)
|
|
@@ -23,8 +23,12 @@ class Factory(AbstractCreatorProvider[T_co]):
|
|
|
23
23
|
super().__init__(scope, creator, *args, **kwargs)
|
|
24
24
|
|
|
25
25
|
@property
|
|
26
|
-
def
|
|
27
|
-
return
|
|
26
|
+
def sync_provider(self) -> SyncInjectedFactory[T_co]:
|
|
27
|
+
return SyncInjectedFactory(self)
|
|
28
|
+
|
|
29
|
+
@property
|
|
30
|
+
def async_provider(self) -> AsyncInjectedFactory[T_co]:
|
|
31
|
+
return AsyncInjectedFactory(self)
|
|
28
32
|
|
|
29
33
|
async def async_resolve(self, container: Container) -> T_co:
|
|
30
34
|
container = container.find_container(self.scope)
|
|
@@ -9,7 +9,7 @@ T_co = typing.TypeVar("T_co", covariant=True)
|
|
|
9
9
|
P = typing.ParamSpec("P")
|
|
10
10
|
|
|
11
11
|
|
|
12
|
-
class
|
|
12
|
+
class SyncInjectedFactory(AbstractProvider[T_co]):
|
|
13
13
|
__slots__ = [*AbstractProvider.BASE_SLOTS, "_factory_provider"]
|
|
14
14
|
|
|
15
15
|
def __init__(self, factory_provider: AbstractProvider[T_co]) -> None:
|
|
@@ -17,13 +17,29 @@ class InjectedFactory(AbstractProvider[T_co]):
|
|
|
17
17
|
self._factory_provider = factory_provider
|
|
18
18
|
|
|
19
19
|
async def async_resolve(self, container: Container) -> typing.Callable[[], T_co]: # type: ignore[override]
|
|
20
|
-
|
|
21
|
-
return functools.partial(self._factory_provider.sync_resolve, container)
|
|
20
|
+
return self.sync_resolve(container)
|
|
22
21
|
|
|
23
22
|
def sync_resolve(self, container: Container) -> typing.Callable[[], T_co]: # type: ignore[override]
|
|
24
|
-
self._factory_provider.sync_resolve(container)
|
|
25
23
|
return functools.partial(self._factory_provider.sync_resolve, container)
|
|
26
24
|
|
|
27
25
|
@property
|
|
28
26
|
def cast(self) -> typing.Callable[[], T_co]: # type: ignore[override]
|
|
29
27
|
return typing.cast(typing.Callable[[], T_co], self)
|
|
28
|
+
|
|
29
|
+
|
|
30
|
+
class AsyncInjectedFactory(AbstractProvider[T_co]):
|
|
31
|
+
__slots__ = [*AbstractProvider.BASE_SLOTS, "_factory_provider"]
|
|
32
|
+
|
|
33
|
+
def __init__(self, factory_provider: AbstractProvider[T_co]) -> None:
|
|
34
|
+
super().__init__(factory_provider.scope)
|
|
35
|
+
self._factory_provider = factory_provider
|
|
36
|
+
|
|
37
|
+
async def async_resolve(self, container: Container) -> typing.Callable[[], typing.Awaitable[T_co]]: # type: ignore[override]
|
|
38
|
+
return self.sync_resolve(container)
|
|
39
|
+
|
|
40
|
+
def sync_resolve(self, container: Container) -> typing.Callable[[], typing.Awaitable[T_co]]: # type: ignore[override]
|
|
41
|
+
return functools.partial(self._factory_provider.async_resolve, container)
|
|
42
|
+
|
|
43
|
+
@property
|
|
44
|
+
def cast(self) -> typing.Callable[[], typing.Awaitable[T_co]]: # type: ignore[override]
|
|
45
|
+
return typing.cast(typing.Callable[[], typing.Awaitable[T_co]], self)
|
|
@@ -1,11 +1,11 @@
|
|
|
1
|
-
Metadata-Version: 2.
|
|
1
|
+
Metadata-Version: 2.4
|
|
2
2
|
Name: modern-di
|
|
3
|
-
Version: 0.
|
|
3
|
+
Version: 0.10.0
|
|
4
4
|
Summary: Dependency Injection framework with IOC-container and scopes
|
|
5
5
|
Project-URL: repository, https://github.com/modern-python/modern-di
|
|
6
6
|
Project-URL: docs, https://modern-di.readthedocs.io
|
|
7
7
|
Author-email: Artur Shiriev <me@shiriev.ru>
|
|
8
|
-
License: MIT
|
|
8
|
+
License-Expression: MIT
|
|
9
9
|
Keywords: DI,dependency injector,ioc-container,mocks,python
|
|
10
10
|
Classifier: Programming Language :: Python :: 3.10
|
|
11
11
|
Classifier: Programming Language :: Python :: 3.11
|
|
@@ -1,20 +1,20 @@
|
|
|
1
1
|
modern_di/__init__.py,sha256=L01VkzSJiV0d0FPrh1DZ-Wy5mUmoG6X-oLz7xYxtehI,194
|
|
2
|
-
modern_di/container.py,sha256=
|
|
2
|
+
modern_di/container.py,sha256=BmviR8lr01EcdHpzvm63_otMUtw0Ytp9rUk7eG3i2IE,4948
|
|
3
3
|
modern_di/graph.py,sha256=X60wtG3Mqus_5YZNiZlQuXoHODBp7rYl_IHJs7GzSQM,1356
|
|
4
4
|
modern_di/provider_state.py,sha256=oU08QnMr0yhIZKkz0Pee8_RnWtETDE9ux4JB83qhwTI,1358
|
|
5
5
|
modern_di/py.typed,sha256=47DEQpj8HBSa-_TImW-5JCeuQeRkm5NMpJWZG3hSuFU,0
|
|
6
6
|
modern_di/scope.py,sha256=e6Olc-CF89clbYDNGciy-F8EqJt1Mw2703zfuJaEY94,113
|
|
7
7
|
modern_di/providers/__init__.py,sha256=tnF38UC-INW1GPPsGlj5tLqGi6fMfHodpi91wHDW-jY,649
|
|
8
|
-
modern_di/providers/abstract.py,sha256=
|
|
8
|
+
modern_di/providers/abstract.py,sha256=dgtAwzwtK-zyIHroxAT3QB5CV06sx3PUugYweZexkMc,3408
|
|
9
9
|
modern_di/providers/container_provider.py,sha256=r5IEQXgKtPwvHvbqkbPnmGyDGGCCjokTtdard9Rvt40,548
|
|
10
10
|
modern_di/providers/context_adapter.py,sha256=_b1x3ToQPWT-9KkDioFhw1W8Q1VXZYUnczfYzMTobVA,760
|
|
11
11
|
modern_di/providers/dict.py,sha256=nCU9iaqteYHDbILAfhrdnbMgS9_emE4MS7Xn2VoUlPo,858
|
|
12
|
-
modern_di/providers/factory.py,sha256=
|
|
13
|
-
modern_di/providers/injected_factory.py,sha256=
|
|
12
|
+
modern_di/providers/factory.py,sha256=Nn9WZuOHF4r5Go4vOuW_jAjmXs0A2WJCGiGQ1eUFB58,1507
|
|
13
|
+
modern_di/providers/injected_factory.py,sha256=KkDww-zUgm41LFt5j8crRzzFuBSkmKvOfptzHWMgVok,1848
|
|
14
14
|
modern_di/providers/list.py,sha256=3hx34RfBRmqzh-cT5D6wSTDJPkBGMK_ul4n9gQz-o9M,769
|
|
15
15
|
modern_di/providers/resource.py,sha256=CsMekkVISklTqN539XqH4iE80vfc6sQMav5OT8fZvyA,4591
|
|
16
16
|
modern_di/providers/selector.py,sha256=RQbHD2-Liw-TGqu6UELbfCzXYuqxiO_Mg1tLyF3mKQo,1419
|
|
17
17
|
modern_di/providers/singleton.py,sha256=_hUpCmbHgLAigdhBiu0zypwWwrIGdB6_oZkGfuLxzNE,2372
|
|
18
|
-
modern_di-0.
|
|
19
|
-
modern_di-0.
|
|
20
|
-
modern_di-0.
|
|
18
|
+
modern_di-0.10.0.dist-info/METADATA,sha256=CwHhtofaNICrWExZ-9i_E9clyCsMxfWsU60qqpYzyJU,5505
|
|
19
|
+
modern_di-0.10.0.dist-info/WHEEL,sha256=qtCwoSJWgHk21S1Kb4ihdzI2rlJ1ZKaIurTj_ngOhyQ,87
|
|
20
|
+
modern_di-0.10.0.dist-info/RECORD,,
|