Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/Frederik91/DependencyInjection.SourceGenerator
Register services using attributes instead of registering.
https://github.com/Frederik91/DependencyInjection.SourceGenerator
Last synced: 3 months ago
JSON representation
Register services using attributes instead of registering.
- Host: GitHub
- URL: https://github.com/Frederik91/DependencyInjection.SourceGenerator
- Owner: Frederik91
- License: mit
- Created: 2022-12-12T20:09:48.000Z (about 2 years ago)
- Default Branch: main
- Last Pushed: 2024-02-19T12:52:45.000Z (11 months ago)
- Last Synced: 2024-08-01T22:43:51.603Z (6 months ago)
- Language: C#
- Size: 10.2 MB
- Stars: 4
- Watchers: 2
- Forks: 1
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
- RSCG_Examples - DI
README
# DependencyInjection.SourceGenerator
Register services using attributes instead of registering in code.## Usage
Add the "Register" attribute to the class you want to register. The attribute takes a type and a lifetime. The type is the type you want to register and the lifetime is the lifetime of the service. The lifetime is optional and defaults to Transient.This library supports the following dependency injection frameworks, follow the links for more information on how to use them:
- [Microsoft.Extensions.DependencyInjection](DependencyInjection.SourceGenerator.Microsoft/README.md)
- [LightInject](DependencyInjection.SourceGenerator.LightInject/README.md)To use this library you need to install the source generator package and the contacts package.
The source generator package is a development dependency and will not be exposed as a dependency to consumers of your projects, while the contracts package contains the attributes and enums used to configure the generator.### Microsoft.Extensions.DependencyInjection
* #### DependencyInjection.SourceGenerator.Microsoft [![NuGet](https://img.shields.io/nuget/vpre/DependencyInjection.SourceGenerator.Microsoft.svg)](https://www.nuget.org/packages/DependencyInjection.SourceGenerator.Microsoft)
* #### DependencyInjection.SourceGenerator.Microsoft.Contracts [![NuGet](https://img.shields.io/nuget/vpre/DependencyInjection.SourceGenerator.Microsoft.Contracts.svg)](https://www.nuget.org/packages/DependencyInjection.SourceGenerator.Microsoft.Contracts)### LightInject
* #### DependencyInjection.SourceGenerator.LightInject [![NuGet](https://img.shields.io/nuget/vpre/DependencyInjection.SourceGenerator.LightInject.svg)](https://www.nuget.org/packages/DependencyInjection.SourceGenerator.LightInject)
* #### DependencyInjection.SourceGenerator.LightInject.Contracts [![NuGet](https://img.shields.io/nuget/vpre/DependencyInjection.SourceGenerator.LightInject.Contracts.svg)](https://www.nuget.org/packages/DependencyInjection.SourceGenerator.LightInject.Contracts)Both contracts packages references the shared contracts package, which contains the attributes and enums used to configure the generator.
* #### DependencyInjection.SourceGenerator.Contracts [![NuGet](https://img.shields.io/nuget/vpre/DependencyInjection.SourceGenerator.Contracts.svg)](https://www.nuget.org/packages/DependencyInjection.SourceGenerator.Contracts)## Lifetime
The lifetime is an enum with the following values:
- Transient
- Scoped
- Singleton