Bread.Ioc.Generator
1.5.7
See the version list below for details.
dotnet add package Bread.Ioc.Generator --version 1.5.7
NuGet\Install-Package Bread.Ioc.Generator -Version 1.5.7
<PackageReference Include="Bread.Ioc.Generator" Version="1.5.7" />
<PackageVersion Include="Bread.Ioc.Generator" Version="1.5.7" />
<PackageReference Include="Bread.Ioc.Generator" />
paket add Bread.Ioc.Generator --version 1.5.7
#r "nuget: Bread.Ioc.Generator, 1.5.7"
#:package Bread.Ioc.Generator@1.5.7
#addin nuget:?package=Bread.Ioc.Generator&version=1.5.7
#tool nuget:?package=Bread.Ioc.Generator&version=1.5.7
Bread.IoC.Generator
Bread.IoC.Generator is a Source Generator for the Bread.IoC library. It simplifies dependency registration by automatically generating code at compile time, ensuring a seamless and efficient development experience.
Features
- Automatic Dependency Registration: Detects and registers dependencies in IoC containers automatically.
- Compile-Time Validation: Ensures correctness of dependency registration during compilation.
- Lightweight and Fast: Optimized for minimal overhead during the build process.
- Native AOT Compatibility: Fully supports .NET Native AOT scenarios.
- Customizable: Allows developers to extend and customize the generated code.
Installation
You can install Bread.IoC.Generator via NuGet:
dotnet add package Bread.IoC.Generator
Getting Started
1. Add the Source Generator to Your Project
Reference the Bread.IoC.Generator package in your project. Ensure it is added as an analyzer:
<ProjectReference Include="..\Bread.IoC.Generator\Bread.IoC.Generator.csproj" OutputItemType="Analyzer" ReferenceOutputAssembly="false" />
2. Define Your IoC Container
Create a class that inherits from IoCContainer and define your dependencies in the Bootstrap method:
using Bread.IoC;
public class MyIoCContainer : IoCContainer
{
protected override void Bootstrap(IBootstrapper ioc)
{
ioc.Regist<MyService>();
}
}
3. Let the Generator Do the Work
The Source Generator will automatically detect and register dependencies during compilation. You can inspect the generated code in the obj\Debug\netX.X\generated directory.
Advanced Features
Custom Dependency Registration
The generator supports advanced scenarios, such as custom dependency registration patterns. For example:
ioc.Regist<IMyInterface, MyImplementation>();
Debugging the Source Generator
To debug the Source Generator, add the following code to the Initialize method in the generator:
if (!System.Diagnostics.Debugger.IsAttached)
{
System.Diagnostics.Debugger.Launch();
}
Then attach a debugger to the build process (dotnet or devenv).
Limitations
- Bread.IoC Dependency:
Bread.IoC.Generatoris designed to work exclusively with theBread.IoClibrary. - Singleton Only: The generator assumes all dependencies are registered as singletons.
License
This project is licensed under the MIT License.
Repository
For more information, visit the GitHub repository.
Start using Bread.IoC.Generator to simplify your dependency management today!
| Product | Versions Compatible and additional computed target framework versions. |
|---|---|
| .NET | net5.0 was computed. net5.0-windows was computed. net6.0 was computed. net6.0-android was computed. net6.0-ios was computed. net6.0-maccatalyst was computed. net6.0-macos was computed. net6.0-tvos was computed. net6.0-windows was computed. net7.0 was computed. net7.0-android was computed. net7.0-ios was computed. net7.0-maccatalyst was computed. net7.0-macos was computed. net7.0-tvos was computed. net7.0-windows was computed. net8.0 was computed. net8.0-android was computed. net8.0-browser was computed. net8.0-ios was computed. net8.0-maccatalyst was computed. net8.0-macos was computed. net8.0-tvos was computed. net8.0-windows was computed. net9.0 was computed. net9.0-android was computed. net9.0-browser was computed. net9.0-ios was computed. net9.0-maccatalyst was computed. net9.0-macos was computed. net9.0-tvos was computed. net9.0-windows was computed. net10.0 was computed. net10.0-android was computed. net10.0-browser was computed. net10.0-ios was computed. net10.0-maccatalyst was computed. net10.0-macos was computed. net10.0-tvos was computed. net10.0-windows was computed. |
| .NET Core | netcoreapp2.0 was computed. netcoreapp2.1 was computed. netcoreapp2.2 was computed. netcoreapp3.0 was computed. netcoreapp3.1 was computed. |
| .NET Standard | netstandard2.0 is compatible. netstandard2.1 was computed. |
| .NET Framework | net461 was computed. net462 was computed. net463 was computed. net47 was computed. net471 was computed. net472 was computed. net48 was computed. net481 was computed. |
| MonoAndroid | monoandroid was computed. |
| MonoMac | monomac was computed. |
| MonoTouch | monotouch was computed. |
| Tizen | tizen40 was computed. tizen60 was computed. |
| Xamarin.iOS | xamarinios was computed. |
| Xamarin.Mac | xamarinmac was computed. |
| Xamarin.TVOS | xamarintvos was computed. |
| Xamarin.WatchOS | xamarinwatchos was computed. |
-
.NETStandard 2.0
- Bread.Ioc (>= 1.5.7)
- Microsoft.CodeAnalysis.CSharp (>= 5.0.0)
NuGet packages (1)
Showing the top 1 NuGet packages that depend on Bread.Ioc.Generator:
| Package | Downloads |
|---|---|
|
Bread.Mvc
A mvc framework for dotnet application development which fully support native aot. |
GitHub repositories
This package is not used by any popular GitHub repositories.