AterraEngine.DependencyInjection.Generators
4.5.0
Prefix Reserved
See the version list below for details.
dotnet add package AterraEngine.DependencyInjection.Generators --version 4.5.0
NuGet\Install-Package AterraEngine.DependencyInjection.Generators -Version 4.5.0
<PackageReference Include="AterraEngine.DependencyInjection.Generators" Version="4.5.0"> <PrivateAssets>all</PrivateAssets> <IncludeAssets>runtime; build; native; contentfiles; analyzers</IncludeAssets> </PackageReference>
paket add AterraEngine.DependencyInjection.Generators --version 4.5.0
#r "nuget: AterraEngine.DependencyInjection.Generators, 4.5.0"
// Install AterraEngine.DependencyInjection.Generators as a Cake Addin #addin nuget:?package=AterraEngine.DependencyInjection.Generators&version=4.5.0 // Install AterraEngine.DependencyInjection.Generators as a Cake Tool #tool nuget:?package=AterraEngine.DependencyInjection.Generators&version=4.5.0
⛓️💥 AterraEngine.DependencyInjection ⛓️💥
AterraEngine.DependencyInjection is a library that provides tools for automizing dependency injection in .NET projects. It includes source generators for automatic registration of services and attributes to facilitate DI.
Features
- Automatic Service Registration: Use source generators to automatically register services in your project.
- Custom Attributes: Define custom attributes to specify the lifetime and other details for your services.
Getting Started
Prerequisites
- .NET 9.0 or later
Installation
You can install AterraEngine.DependencyInjection
via NuGet Package Manager:
dotnet add package AterraEngine.DependencyInjection
You can install AterraEngine.DependencyInjection.Generator
via NuGet Package Manager:
dotnet add package AterraEngine.DependencyInjection.Generator
Usage
Define Services with Attributes
You can use the provided attributes to define services:
InjectableService
: Simple attribute to register a class to the implementation which is inserted as a type generic.public interface IExampleService; [InjectableService<IExampleService>(ServiceLifetime.Singleton)] public class ExampleService : IExampleService { // ... }
FactoryCreatedService
: Marks the class as a service which creation depends on another injected service.- The factory service must implement
IFactoryService<>
public interface ICreatedService; [FactoryCreatedService<IExampleFactory, ICreatedService>(ServiceLifetime.Transient)] public class CreatedService : ICreatedService; // The above service is something that is created by the Factory service [InjectableService<IExampleFactory>(ServiceLifetime.Singleton)] public class ExampleFactory : IExampleFactory { public ICreatedService Create() => new CreatedService(); } public interface IExampleFactory : IFactoryService<ICreatedService>;
- The factory service must implement
PooledInjectableService
: Marks the class as a poolable service. This library creates a classAutoPoolableService
under which the class will be registered.- It uses
PooledInjectableServiceObjectPolicy
to create a policy. - The poolable service must implement
PooledInjectableServiceObjectPolicy
public interface IExamplePooled : IManualPoolable; [PooledInjectableService<IExamplePooled, ExamplePooled>] public class ExamplePooled : IExamplePooled { public bool Reset() => true; }
- It uses
Generate Service Registrations
The source generator will automatically create the necessary registration code. C
all the generated registration method in your Startup
or Program
class:
using Microsoft.Extensions.DependencyInjection;
var services = new ServiceCollection();
services.RegisterServicesFromYourAssemblyName();
Contributing
Contributions are welcome! Please fork this repository and submit a pull request.
Learn more about Target Frameworks and .NET Standard.
-
.NETStandard 2.0
- No dependencies.
NuGet packages
This package is not used by any NuGet packages.
GitHub repositories
This package is not used by any popular GitHub repositories.
Version | Downloads | Last updated |
---|---|---|
4.8.0 | 0 | 2/8/2025 |
4.7.0 | 0 | 2/8/2025 |
4.6.0 | 0 | 2/8/2025 |
4.5.1 | 17 | 2/8/2025 |
4.5.0 | 22 | 2/8/2025 |
4.4.0 | 33 | 2/7/2025 |
4.3.0 | 13 | 2/6/2025 |
4.2.0 | 21 | 2/6/2025 |
4.1.0 | 34 | 2/5/2025 |
4.0.0 | 35 | 2/5/2025 |
3.0.1 | 34 | 2/5/2025 |
3.0.0 | 38 | 2/5/2025 |
2.1.1 | 36 | 2/4/2025 |
2.1.0 | 42 | 2/4/2025 |
2.0.1 | 38 | 1/29/2025 |
2.0.0-preview.6 | 30 | 1/27/2025 |
1.3.4 | 113 | 1/1/2025 |
1.3.3 | 93 | 1/1/2025 |
1.3.0 | 123 | 12/3/2024 |
1.2.0 | 82 | 12/2/2024 |
1.1.0 | 83 | 11/27/2024 |
1.0.0 | 78 | 11/27/2024 |