DependencyInjection.SourceGenerator.Microsoft
1.2.1-alpha2
See the version list below for details.
dotnet add package DependencyInjection.SourceGenerator.Microsoft --version 1.2.1-alpha2
NuGet\Install-Package DependencyInjection.SourceGenerator.Microsoft -Version 1.2.1-alpha2
<PackageReference Include="DependencyInjection.SourceGenerator.Microsoft" Version="1.2.1-alpha2" />
paket add DependencyInjection.SourceGenerator.Microsoft --version 1.2.1-alpha2
#r "nuget: DependencyInjection.SourceGenerator.Microsoft, 1.2.1-alpha2"
// Install DependencyInjection.SourceGenerator.Microsoft as a Cake Addin #addin nuget:?package=DependencyInjection.SourceGenerator.Microsoft&version=1.2.1-alpha2&prerelease // Install DependencyInjection.SourceGenerator.Microsoft as a Cake Tool #tool nuget:?package=DependencyInjection.SourceGenerator.Microsoft&version=1.2.1-alpha2&prerelease
DependencyInjection.SourceGenerator.Microsoft
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.
Microsoft.Extensions.DependencyInjection
namespace RootNamespace.Services;
public interface IExampleService
{
string GetExample();
}
public interface IAnotherService
{
string GetAnother();
}
[Register(ServiceName = "ServiceName", Lifetime = Lifetime.Singleton)]
public class ExampleService : IExampleService
{
public string GetExample()
{
return "Example";
}
}
[Decorate]
public class KeyedService : IExampleService
{
public string GetExample()
{
return "Keyed";
}
}
[Decorator]
public class ServiceDecorator : IExampleService
{
private readonly IExampleService _exampleService;
public ServiceDecorator(IExampleService exampleService)
{
_exampleService = exampleService;
}
public string GetExample()
{
return _exampleService.GetExample();
}
}
[Register<IAnotherService>]
public class MultipleInterfacesService : IExampleService, IAnotherService
{
public string GetExample()
{
return "MultipleInterfaces";
}
public string GetAnother()
{
return "Another";
}
}
Generates a class ServiceCollectionExtensions Assuming the project is named MyProject, the generated method will be named AddMyProject.
// <auto-generated/>
#pragma warning disable
#nullable enable
namespace RootNamespace;
using global::Microsoft.Extensions.DependencyInjection;
[global::System.Diagnostics.CodeAnalysis.ExcludeFromCodeCoverage]
public static class ServiceCollectionExtensions
{
public static global::Microsoft.Extensions.DependencyInjection.IServiceCollection AddMyProject(this global::Microsoft.Extensions.DependencyInjection.IServiceCollection services)
{
services.AddKeyedSingleton<global::RootNamespace.Services.IExampleService, global::RootNamespace.Services.ExampleService>("ServiceName");
services.Decorate<global::RootNamespace.Services.IExampleService, global::RootNamespace.Services.ServiceDecorator>();
services.AddTransient<global::RootNamespace.Services.IAnotherService, global::RootNamespace.Services.MultipleInterfacesService>();
return services;
}
}
You can also create a method that will be called by the AddMyProject method. This is useful if you want to register services in a different way.
using global::DependencyInjection.SourceGenerator.Contracts.Attributes;
namespace DependencyInjection.SourceGenerator.Microsoft.Demo;
public class Registrator
{
[RegistrationExtension]
internal static void Register(global::Microsoft.Extensions.DependencyInjection.IServiceCollection services)
{
// Register your additional services here
}
}
This will then produce the following code:
public static class ServiceCollectionExtensions
{
public static global::Microsoft.Extensions.DependencyInjection.IServiceCollection AddTestProject(this global::Microsoft.Extensions.DependencyInjection.IServiceCollection services)
{
global::DependencyInjection.SourceGenerator.Microsoft.Demo.Registrator.Register(services);
return services;
}
}
Lifetime
The lifetime is an enum with the following values:
- Transient
- Scoped
- Singleton
Learn more about Target Frameworks and .NET Standard.
-
.NETStandard 2.0
- DependencyInjection.SourceGenerator.Contracts (>= 1.2.1-alpha2)
- Microsoft.Extensions.DependencyInjection.Abstractions (>= 8.0.0)
- Scrutor (>= 4.2.2)
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 |
---|---|---|
2.0.0 | 119 | 8/30/2024 |
1.6.0 | 214 | 2/14/2024 |
1.5.1 | 218 | 1/15/2024 |
1.5.0 | 150 | 1/15/2024 |
1.4.3 | 209 | 1/10/2024 |
1.4.2 | 184 | 1/10/2024 |
1.4.1 | 201 | 1/9/2024 |
1.4.0 | 176 | 1/9/2024 |
1.3.3 | 191 | 1/8/2024 |
1.3.2 | 186 | 1/8/2024 |
1.3.1 | 177 | 1/8/2024 |
1.3.0 | 168 | 1/8/2024 |
1.2.2 | 160 | 1/8/2024 |
1.2.2-alpha3 | 173 | 1/8/2024 |
1.2.2-alpha2 | 150 | 1/8/2024 |
1.2.1 | 195 | 1/5/2024 |
1.2.1-alpha6 | 195 | 1/5/2024 |
1.2.1-alpha5 | 190 | 1/5/2024 |
1.2.1-alpha2 | 189 | 1/5/2024 |
1.2.1-alpha1 | 181 | 1/5/2024 |
1.2.0 | 181 | 1/5/2024 |
1.1.2 | 189 | 1/5/2024 |
1.1.1 | 157 | 1/5/2024 |
1.1.0 | 152 | 1/5/2024 |
1.0.2 | 184 | 1/5/2024 |
1.0.1 | 196 | 1/4/2024 |
1.0.0 | 196 | 1/4/2024 |