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 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",
@@ -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
- P.args, [x.sync_resolve(container) if isinstance(x, AbstractProvider) else x for x in self._args]
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
- P.args,
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
  )
@@ -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 InjectedFactory
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 factory_provider(self) -> InjectedFactory[T_co]:
27
- return InjectedFactory(self)
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 InjectedFactory(AbstractProvider[T_co]):
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
- await self._factory_provider.async_resolve(container)
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.3
1
+ Metadata-Version: 2.4
2
2
  Name: modern-di
3
- Version: 0.9.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=a9NB7P4OQ92seGGztu9SGBChmv79nJ9kHxeF8V2zwpg,4900
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=UMj4CRn-JfGZfiveWFTkH7V92h4UXS4eYf8noZqPWGQ,3107
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=NozbrprJlRJPWSNdvKR0kOwPt1Q9i_ZLJTPOfzdDDJo,1359
13
- modern_di/providers/injected_factory.py,sha256=wK9GG5_d33BdrpimnR6W-zeviZcCS8qe8ZGTmjYtFf4,1135
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.9.0.dist-info/METADATA,sha256=jmn_QkeNOtjU_z1raF5FECSDkaLMhBkTXjb8SEqT7Hc,5493
19
- modern_di-0.9.0.dist-info/WHEEL,sha256=C2FUgwZgiLbznR-k0b_5k3Ai_1aASOXDss3lzCUsUug,87
20
- modern_di-0.9.0.dist-info/RECORD,,
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,,
@@ -1,4 +1,4 @@
1
1
  Wheel-Version: 1.0
2
- Generator: hatchling 1.26.3
2
+ Generator: hatchling 1.27.0
3
3
  Root-Is-Purelib: true
4
4
  Tag: py3-none-any