python-injection 0.18.11__tar.gz → 0.18.13__tar.gz

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.
Files changed (30) hide show
  1. {python_injection-0.18.11 → python_injection-0.18.13}/PKG-INFO +1 -1
  2. {python_injection-0.18.11 → python_injection-0.18.13}/injection/__init__.pyi +7 -5
  3. {python_injection-0.18.11 → python_injection-0.18.13}/injection/_core/descriptors.py +4 -1
  4. {python_injection-0.18.11 → python_injection-0.18.13}/injection/ext/fastapi.py +1 -1
  5. {python_injection-0.18.11 → python_injection-0.18.13}/injection/loaders.py +15 -0
  6. {python_injection-0.18.11 → python_injection-0.18.13}/pyproject.toml +1 -1
  7. {python_injection-0.18.11 → python_injection-0.18.13}/.gitignore +0 -0
  8. {python_injection-0.18.11 → python_injection-0.18.13}/LICENSE +0 -0
  9. {python_injection-0.18.11 → python_injection-0.18.13}/README.md +0 -0
  10. {python_injection-0.18.11 → python_injection-0.18.13}/injection/__init__.py +0 -0
  11. {python_injection-0.18.11 → python_injection-0.18.13}/injection/_core/__init__.py +0 -0
  12. {python_injection-0.18.11 → python_injection-0.18.13}/injection/_core/common/__init__.py +0 -0
  13. {python_injection-0.18.11 → python_injection-0.18.13}/injection/_core/common/asynchronous.py +0 -0
  14. {python_injection-0.18.11 → python_injection-0.18.13}/injection/_core/common/event.py +0 -0
  15. {python_injection-0.18.11 → python_injection-0.18.13}/injection/_core/common/invertible.py +0 -0
  16. {python_injection-0.18.11 → python_injection-0.18.13}/injection/_core/common/key.py +0 -0
  17. {python_injection-0.18.11 → python_injection-0.18.13}/injection/_core/common/lazy.py +0 -0
  18. {python_injection-0.18.11 → python_injection-0.18.13}/injection/_core/common/threading.py +0 -0
  19. {python_injection-0.18.11 → python_injection-0.18.13}/injection/_core/common/type.py +0 -0
  20. {python_injection-0.18.11 → python_injection-0.18.13}/injection/_core/injectables.py +0 -0
  21. {python_injection-0.18.11 → python_injection-0.18.13}/injection/_core/module.py +0 -0
  22. {python_injection-0.18.11 → python_injection-0.18.13}/injection/_core/scope.py +0 -0
  23. {python_injection-0.18.11 → python_injection-0.18.13}/injection/_core/slots.py +0 -0
  24. {python_injection-0.18.11 → python_injection-0.18.13}/injection/entrypoint.py +0 -0
  25. {python_injection-0.18.11 → python_injection-0.18.13}/injection/exceptions.py +0 -0
  26. {python_injection-0.18.11 → python_injection-0.18.13}/injection/ext/__init__.py +0 -0
  27. {python_injection-0.18.11 → python_injection-0.18.13}/injection/ext/fastapi.pyi +0 -0
  28. {python_injection-0.18.11 → python_injection-0.18.13}/injection/py.typed +0 -0
  29. {python_injection-0.18.11 → python_injection-0.18.13}/injection/testing/__init__.py +0 -0
  30. {python_injection-0.18.11 → python_injection-0.18.13}/injection/testing/__init__.pyi +0 -0
@@ -1,6 +1,6 @@
1
1
  Metadata-Version: 2.4
2
2
  Name: python-injection
3
- Version: 0.18.11
3
+ Version: 0.18.13
4
4
  Summary: Fast and easy dependency injection framework.
5
5
  Project-URL: Repository, https://github.com/100nm/python-injection
6
6
  Author: remimd
@@ -78,7 +78,9 @@ class LazyInstance[T]:
78
78
  cls: _InputType[T],
79
79
  /,
80
80
  default: T = ...,
81
+ *,
81
82
  module: Module = ...,
83
+ threadsafe: bool = ...,
82
84
  ) -> None: ...
83
85
  @overload
84
86
  def __get__(self, instance: object, owner: type | None = ...) -> T: ...
@@ -178,9 +180,9 @@ class Module:
178
180
  mode: Mode | ModeStr = ...,
179
181
  ) -> Any:
180
182
  """
181
- Decorator applicable to a class or function. It is used to indicate how the
182
- constant is constructed. At injection time, the injected instance will always
183
- be the same. Unlike `@singleton`, dependencies will not be resolved.
183
+ Decorator applicable to a class. It is used to indicate how the constant is
184
+ constructed. At injection time, the injected instance will always be the same.
185
+ Unlike `@singleton`, dependencies will not be resolved.
184
186
  """
185
187
 
186
188
  def set_constant[T](
@@ -292,8 +294,8 @@ class Module:
292
294
  ) -> _Invertible[T | Default]:
293
295
  """
294
296
  Function used to retrieve an instance associated with the type passed in
295
- parameter or `NotImplemented`. Return a `Invertible` object. To access the instance
296
- contained in an invertible object, simply use a wavy line (~).
297
+ parameter or `NotImplemented`. Return an `Invertible` object. To access the
298
+ instance contained in an invertible object, simply use a wavy line (~).
297
299
 
298
300
  Example: instance = ~lazy_instance
299
301
  """
@@ -15,9 +15,12 @@ class LazyInstance[T]:
15
15
  cls: InputType[T],
16
16
  /,
17
17
  default: T = NotImplemented,
18
+ *,
18
19
  module: Module | None = None,
20
+ threadsafe: bool = False,
19
21
  ) -> None:
20
- self.__value = (module or mod()).get_lazy_instance(cls, default)
22
+ module = module or mod()
23
+ self.__value = module.get_lazy_instance(cls, default, threadsafe=threadsafe)
21
24
 
22
25
  def __get__(
23
26
  self,
@@ -12,7 +12,7 @@ __all__ = ("Inject", "InjectThreadSafe")
12
12
  @dataclass(eq=False, frozen=True, slots=True)
13
13
  class FastAPIInject:
14
14
  module: Module = field(default_factory=mod)
15
- threadsafe: bool = field(default=False)
15
+ threadsafe: bool = field(default=False, kw_only=True)
16
16
 
17
17
  def __call__[T](
18
18
  self,
@@ -149,6 +149,15 @@ class ProfileLoader:
149
149
  def __is_empty(self) -> bool:
150
150
  return not self.module_subsets
151
151
 
152
+ def required_module_names(self, name: str | None = None, /) -> frozenset[str]:
153
+ names = {self.module.name}
154
+
155
+ if name is not None:
156
+ names.add(name)
157
+
158
+ subsets = (self.__walk_subsets_for(name) for name in names)
159
+ return frozenset(itertools.chain.from_iterable(subsets))
160
+
152
161
  def init(self) -> Self:
153
162
  self.__init_subsets_for(self.module)
154
163
  return self
@@ -179,6 +188,12 @@ class ProfileLoader:
179
188
  def __mark_initialized(self, module: Module) -> None:
180
189
  self.__initialized_modules.add(module.name)
181
190
 
191
+ def __walk_subsets_for(self, module_name: str) -> Iterator[str]:
192
+ yield module_name
193
+
194
+ for name in self.module_subsets.get(module_name, ()):
195
+ yield from self.__walk_subsets_for(name)
196
+
182
197
 
183
198
  @runtime_checkable
184
199
  class LoadedProfile(Protocol):
@@ -29,7 +29,7 @@ test = [
29
29
 
30
30
  [project]
31
31
  name = "python-injection"
32
- version = "0.18.11"
32
+ version = "0.18.13"
33
33
  description = "Fast and easy dependency injection framework."
34
34
  license = "MIT"
35
35
  license-files = ["LICENSE"]