mirror of
				https://github.com/ets-labs/python-dependency-injector.git
				synced 2025-10-25 05:01:11 +03:00 
			
		
		
		
	* Add __class_getitem__ for Provider to null the typing in runtime * Make Provider stub generic and remove types module * Update types module tests * Return types module with deprecation warning * Return types module with deprecation warning * Update changelog * Add docs page
		
			
				
	
	
		
			59 lines
		
	
	
		
			1.2 KiB
		
	
	
	
		
			ReStructuredText
		
	
	
	
	
	
			
		
		
	
	
			59 lines
		
	
	
		
			1.2 KiB
		
	
	
	
		
			ReStructuredText
		
	
	
	
	
	
| .. _provider-typing:
 | |
| 
 | |
| Typing and mypy
 | |
| ===============
 | |
| 
 | |
| .. meta::
 | |
|    :keywords: Python,DI,Dependency injection,IoC,Inversion of Control,Providers,Typing,Mypy,
 | |
|               Pattern,Example
 | |
|    :description: Dependency Injector providers are mypy-friendly. Providers module goes with the
 | |
|                  typing stubs to provide the typing information to ``mypy``, IDEs and editors.
 | |
| 
 | |
| Providers are ``mypy``-friendly.
 | |
| 
 | |
| Providers module goes with the typing stubs. It provides typing information to ``mypy`` and your
 | |
| IDE.
 | |
| 
 | |
| .. code-block:: python
 | |
| 
 | |
|    from dependency_injector import providers
 | |
| 
 | |
| 
 | |
|    class Animal:
 | |
|        ...
 | |
| 
 | |
| 
 | |
|    class Cat(Animal)
 | |
|        ...
 | |
| 
 | |
| 
 | |
|    provider = providers.Factory(Cat)
 | |
| 
 | |
| 
 | |
|    if __name__ == '__main__':
 | |
|        animal = provider()  # mypy knows that animal is of type "Cat"
 | |
| 
 | |
| 
 | |
| You can use ``Provider`` as a generic type. This helps when a provider is an argument of a
 | |
| function or method.
 | |
| 
 | |
| .. code-block:: python
 | |
|    :emphasize-lines: 12
 | |
| 
 | |
|    from dependency_injector import providers
 | |
| 
 | |
| 
 | |
|    class Animal:
 | |
|        ...
 | |
| 
 | |
| 
 | |
|    class Cat(Animal)
 | |
|        ...
 | |
| 
 | |
| 
 | |
|    provider: providers.Provider[Animal] = providers.Factory(Cat)
 | |
| 
 | |
| 
 | |
|    if __name__ == '__main__':
 | |
|        animal = provider()  # mypy knows that animal is of type "Animal"
 |