python-injection 0.10.12.post0__py3-none-any.whl → 0.11.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.
- injection/__init__.py +2 -0
- injection/__init__.pyi +28 -4
- injection/_core/descriptors.py +25 -0
- injection/integrations/fastapi.py +4 -6
- injection/testing/__init__.py +2 -2
- injection/utils.py +2 -2
- {python_injection-0.10.12.post0.dist-info → python_injection-0.11.0.dist-info}/METADATA +1 -1
- {python_injection-0.10.12.post0.dist-info → python_injection-0.11.0.dist-info}/RECORD +9 -8
- {python_injection-0.10.12.post0.dist-info → python_injection-0.11.0.dist-info}/WHEEL +0 -0
injection/__init__.py
CHANGED
injection/__init__.pyi
CHANGED
@@ -9,6 +9,7 @@ from typing import (
|
|
9
9
|
Protocol,
|
10
10
|
Self,
|
11
11
|
final,
|
12
|
+
overload,
|
12
13
|
runtime_checkable,
|
13
14
|
)
|
14
15
|
|
@@ -136,23 +137,31 @@ class Module:
|
|
136
137
|
parameter or an exception will be raised.
|
137
138
|
"""
|
138
139
|
|
140
|
+
@overload
|
139
141
|
def get_instance[T, Default](
|
140
142
|
self,
|
141
143
|
cls: _InputType[T],
|
142
|
-
default: Default
|
143
|
-
) -> T | Default
|
144
|
+
default: Default,
|
145
|
+
) -> T | Default:
|
144
146
|
"""
|
145
147
|
Function used to retrieve an instance associated with the type passed in
|
146
148
|
parameter or return `None`.
|
147
149
|
"""
|
148
150
|
|
151
|
+
@overload
|
152
|
+
def get_instance[T, _](
|
153
|
+
self,
|
154
|
+
cls: _InputType[T],
|
155
|
+
default: None = ...,
|
156
|
+
) -> T | None: ...
|
157
|
+
@overload
|
149
158
|
def get_lazy_instance[T, Default](
|
150
159
|
self,
|
151
160
|
cls: _InputType[T],
|
152
|
-
default: Default
|
161
|
+
default: Default,
|
153
162
|
*,
|
154
163
|
cache: bool = ...,
|
155
|
-
) -> _Invertible[T | Default
|
164
|
+
) -> _Invertible[T | Default]:
|
156
165
|
"""
|
157
166
|
Function used to retrieve an instance associated with the type passed in
|
158
167
|
parameter or `None`. Return a `Invertible` object. To access the instance
|
@@ -162,6 +171,14 @@ class Module:
|
|
162
171
|
Example: instance = ~lazy_instance
|
163
172
|
"""
|
164
173
|
|
174
|
+
@overload
|
175
|
+
def get_lazy_instance[T, _](
|
176
|
+
self,
|
177
|
+
cls: _InputType[T],
|
178
|
+
default: None = ...,
|
179
|
+
*,
|
180
|
+
cache: bool = ...,
|
181
|
+
) -> _Invertible[T | None]: ...
|
165
182
|
def init_modules(self, *modules: Module) -> Self:
|
166
183
|
"""
|
167
184
|
Function to clean modules in use and to use those passed as parameters.
|
@@ -243,3 +260,10 @@ class Mode(Enum):
|
|
243
260
|
FALLBACK = ...
|
244
261
|
NORMAL = ...
|
245
262
|
OVERRIDE = ...
|
263
|
+
|
264
|
+
class LazyInstance[T]:
|
265
|
+
def __init__(self, cls: _InputType[T], module: Module = ...) -> None: ...
|
266
|
+
@overload
|
267
|
+
def __get__(self, instance: object, owner: type | None = ...) -> T: ...
|
268
|
+
@overload
|
269
|
+
def __get__(self, instance: None = ..., owner: type | None = ...) -> Self: ...
|
@@ -0,0 +1,25 @@
|
|
1
|
+
from typing import Self
|
2
|
+
|
3
|
+
from injection._core.common.invertible import Invertible
|
4
|
+
from injection._core.common.type import InputType
|
5
|
+
from injection._core.module import Module
|
6
|
+
|
7
|
+
|
8
|
+
class LazyInstance[T]:
|
9
|
+
__slots__ = ("__value",)
|
10
|
+
|
11
|
+
__value: Invertible[T]
|
12
|
+
|
13
|
+
def __init__(self, cls: InputType[T], module: Module | None = None) -> None:
|
14
|
+
module = module or Module.default()
|
15
|
+
self.__value = module.get_lazy_instance(cls, default=NotImplemented) # type: ignore[assignment]
|
16
|
+
|
17
|
+
def __get__(
|
18
|
+
self,
|
19
|
+
instance: object | None = None,
|
20
|
+
owner: type | None = None,
|
21
|
+
) -> Self | T:
|
22
|
+
if instance is None:
|
23
|
+
return self
|
24
|
+
|
25
|
+
return ~self.__value
|
@@ -1,6 +1,6 @@
|
|
1
1
|
from collections.abc import Callable
|
2
2
|
from types import GenericAlias
|
3
|
-
from typing import Any,
|
3
|
+
from typing import Any, TypeAliasType
|
4
4
|
|
5
5
|
from injection import Module, mod
|
6
6
|
from injection.exceptions import InjectionError
|
@@ -34,10 +34,8 @@ class InjectionDependency[T]:
|
|
34
34
|
__class: type[T] | TypeAliasType | GenericAlias
|
35
35
|
__module: Module
|
36
36
|
|
37
|
-
__sentinel: ClassVar[object] = object()
|
38
|
-
|
39
37
|
def __init__(self, cls: type[T] | TypeAliasType | GenericAlias, module: Module):
|
40
|
-
lazy_instance = module.get_lazy_instance(cls, default=
|
38
|
+
lazy_instance = module.get_lazy_instance(cls, default=NotImplemented)
|
41
39
|
self.__call__ = lambda: self.__ensure(~lazy_instance)
|
42
40
|
self.__class = cls
|
43
41
|
self.__module = module
|
@@ -55,8 +53,8 @@ class InjectionDependency[T]:
|
|
55
53
|
def __key(self) -> tuple[type[T] | TypeAliasType | GenericAlias, Module]:
|
56
54
|
return self.__class, self.__module
|
57
55
|
|
58
|
-
def __ensure(self, instance: T
|
59
|
-
if instance is
|
56
|
+
def __ensure(self, instance: T) -> T:
|
57
|
+
if instance is NotImplemented:
|
60
58
|
raise InjectionError(f"`{self.__class}` is an unknown dependency.")
|
61
59
|
|
62
60
|
return instance
|
injection/testing/__init__.py
CHANGED
@@ -21,5 +21,5 @@ test_injectable = mod(_TEST_PROFILE_NAME).injectable
|
|
21
21
|
test_singleton = mod(_TEST_PROFILE_NAME).singleton
|
22
22
|
|
23
23
|
|
24
|
-
def load_test_profile(*
|
25
|
-
return load_profile(_TEST_PROFILE_NAME, *
|
24
|
+
def load_test_profile(*names: str) -> ContextManager[None]:
|
25
|
+
return load_profile(_TEST_PROFILE_NAME, *names)
|
injection/utils.py
CHANGED
@@ -10,13 +10,13 @@ from injection import mod
|
|
10
10
|
__all__ = ("load_packages", "load_profile")
|
11
11
|
|
12
12
|
|
13
|
-
def load_profile(
|
13
|
+
def load_profile(*names: str) -> ContextManager[None]:
|
14
14
|
"""
|
15
15
|
Injection module initialization function based on profile name.
|
16
16
|
A profile name is equivalent to an injection module name.
|
17
17
|
"""
|
18
18
|
|
19
|
-
modules = tuple(mod(module_name) for module_name in
|
19
|
+
modules = tuple(mod(module_name) for module_name in names)
|
20
20
|
|
21
21
|
for module in modules:
|
22
22
|
module.unlock()
|
@@ -1,5 +1,5 @@
|
|
1
|
-
injection/__init__.py,sha256=
|
2
|
-
injection/__init__.pyi,sha256=
|
1
|
+
injection/__init__.py,sha256=4JWr0tMlFJb6Tz2Qsd7AupLiMh13XzleBtViJlWgdZA,833
|
2
|
+
injection/__init__.pyi,sha256=Tj6p9OonN4YEXvjswPSFOCSf6Eq3MidhBHR8ewuFc2w,7927
|
3
3
|
injection/_core/__init__.py,sha256=VMGLfdu0gYh82mt7zS297rQ7CE_gHVy0gRdI8RY_ZLY,1361
|
4
4
|
injection/_core/common/__init__.py,sha256=47DEQpj8HBSa-_TImW-5JCeuQeRkm5NMpJWZG3hSuFU,0
|
5
5
|
injection/_core/common/event.py,sha256=kev8WUESAXzMn11EJsbTcICaCvYiD556E6BOLvQ54s4,1243
|
@@ -7,16 +7,17 @@ injection/_core/common/invertible.py,sha256=QYXMqLrkAkz_7mq-jEYKtBr1CQ5aqzplP0FG
|
|
7
7
|
injection/_core/common/lazy.py,sha256=kCO1q4S6AdBhsP5RrihBJpgfeR4hxvMqSz1cpCgBdjo,1482
|
8
8
|
injection/_core/common/threading.py,sha256=OXm7L3p8c7O7eSkU-RTR7cobqIGMhuo-7gpDXsWKDNQ,214
|
9
9
|
injection/_core/common/type.py,sha256=TQTD-f_rnAHS0VgfkWxNFU8HAWPvkAktNDQ9_23JLHM,1705
|
10
|
+
injection/_core/descriptors.py,sha256=1DxrJpUXK2exSLAmdMHLNRRn7EBhQyu_vVvrchif2sw,696
|
10
11
|
injection/_core/hook.py,sha256=_TcwhF_DONfcoBz58RxVLeA950Rs8wtZSLGepZwGBRk,3009
|
11
12
|
injection/_core/module.py,sha256=zvYqUIAV9saTYGBuKbR4tNk2AFrMxyFxNPmvMMmKoe4,25300
|
12
13
|
injection/exceptions.py,sha256=-5Shs7R5rctQXhpMLfcjiMBCzrtFWxC88qETUIHz57s,692
|
13
14
|
injection/integrations/__init__.py,sha256=NYLcstr4ESdLj326LlDub143z6JGM1z1pCOVWhBXK10,304
|
14
15
|
injection/integrations/blacksheep.py,sha256=yO5gLb_l4W3bNPFt-v2qWIL9R8PNon4JmOxQEHdi-5o,923
|
15
|
-
injection/integrations/fastapi.py,sha256=
|
16
|
+
injection/integrations/fastapi.py,sha256=j5ASbMszua-Ti9A_dgFO629RjSIzIVbck78Ymz6CiTo,1723
|
16
17
|
injection/py.typed,sha256=47DEQpj8HBSa-_TImW-5JCeuQeRkm5NMpJWZG3hSuFU,0
|
17
|
-
injection/testing/__init__.py,sha256
|
18
|
+
injection/testing/__init__.py,sha256=Wd9sq43CJCV7GjYFSIaikIf4hJ5lfVNS7GP3iI8a1X8,719
|
18
19
|
injection/testing/__init__.pyi,sha256=6ZXbbS-9ppMdkxd03I6yBNurmR3Xw7sM_qiokibkLeY,386
|
19
|
-
injection/utils.py,sha256=
|
20
|
-
python_injection-0.
|
21
|
-
python_injection-0.
|
22
|
-
python_injection-0.
|
20
|
+
injection/utils.py,sha256=79VoIgxO1MNb_FlfRRbzfx3RXX3DPDtoxMgngfmNF-Q,1920
|
21
|
+
python_injection-0.11.0.dist-info/METADATA,sha256=whi_71OOame5OSWStDfKMvHxCXQjmKhgCybFhe2WA7s,3110
|
22
|
+
python_injection-0.11.0.dist-info/WHEEL,sha256=Nq82e9rUAnEjt98J6MlVmMCZb-t9cYE2Ir1kpBmnWfs,88
|
23
|
+
python_injection-0.11.0.dist-info/RECORD,,
|
File without changes
|