FluentScanning.DependencyInjection
2.0.1
dotnet add package FluentScanning.DependencyInjection --version 2.0.1
NuGet\Install-Package FluentScanning.DependencyInjection -Version 2.0.1
<PackageReference Include="FluentScanning.DependencyInjection" Version="2.0.1" />
paket add FluentScanning.DependencyInjection --version 2.0.1
#r "nuget: FluentScanning.DependencyInjection, 2.0.1"
// Install FluentScanning.DependencyInjection as a Cake Addin #addin nuget:?package=FluentScanning.DependencyInjection&version=2.0.1 // Install FluentScanning.DependencyInjection as a Cake Tool #tool nuget:?package=FluentScanning.DependencyInjection&version=2.0.1
FluentScanning
A package that provides abstraction and common functionality for performing assembly scanning.
// Creating an instance of assembly scanning with defined scanning scope.
// AsseblyScanner's constructor accepts Type, Assembly, () => Type, () => Assembly as params.
// Assemblies extracted from them form a scanning scope (assemblies are distinct).
var scanner = new AssemblyScanner(typeof(IAssemblyMarker), typeof(object));
// Start a scanning query
var baseQuery = scanner.ScanForTypesThat()
// Use extension methods to build up a query.
.MustBeAssignableTo<Base>();
// All queries are immutable and they support query branching.
// It means that you can save a mid-query and build up queries in
// different directions just like you would do with IEnumerable / IQueriable
var collectionQuery = baseQuery
.AreInterfaces()
.ToArray();
var notAbstractQuerty = baseQuery
.AreNotAbstractClasses()
// As the IScanningQuery implements IEnumerble<TypeInfo> you can use .AsType to convert it
// to IEnumerable<Type> and enumerate over it.
.AsTypes()
.ToArray();
FluentScanning.DependencyInjection
A package that provide functionality for adding assembly scanning results to Microsoft.Extensions.DependencyInjection.IServiceCollection
The use of IDisposable pattern implemented to make scanning to IServiceCollection clean and explicit.
BE AWARE! The types are being added to the collection only after scanner is disposed.
As IScanningQuery support query branching, only "dangling" queries are added to IServiceCollection, but not the
branching roots.
IServiceCollection collection = new ServiceCollection();
// Obtaining scanner from IServiceCollection, defining scanning scope
// just like with AssemblyScanner's constructor.
using (var scanner = collection.UseAssemblyScanner(typeof(IAssemblyMarker)))
{
// Query result would not be added to IServiceCollection.
var baseQuery = scanner.EnqueueAdditionOfTypesThat()
.WouldBeRegisteredAs<Base>()
.WithSingletonLifetime()
.MustBeAssignableTo<Base>();
// Queries results will be added to IServiceCollection.
baseQuery.AreNotAbstractClasses();
baseQuery.AreValueTypes();
}
Registration as type constructed from given type
Unbound generic type is a generic type that does not have all his generic parameters bound with types, nor with type parameters. It can only be obtained as a runtime type by using
typeof(IGeneric<>)
statement or through reflection.
When you populate a generic type with a type arguments or parameters, your open or closed generic type would be constructed from that unbounded generic type.
You can register types as type constructed from given type using .WouldBeRegisteredAsTypesConstructedFrom
extension method.
As well as filtering types that are based on a type that is constructed from given type using .AreBasedOnTypesConstructedFrom
extension method.
using (var scanner = collection.UseAssemblyScanner(typeof(IAssemblyMarker)))
{
scanner.EnqueueAdditionOfTypesThat()
.WouldBeRegisteredAsTypesConstructedFrom(typeof(IGeneric<>))
.WithSingletonLifetime()
.AreBasedOnTypesConstructedFrom(typeof(IGeneric<>))
.AreNotAbstractClasses()
.AreNotInterfaces();
}
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. |
.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
- FluentScanning (>= 2.0.1)
- Microsoft.Extensions.DependencyInjection.Abstractions (>= 3.0.0)
NuGet packages (2)
Showing the top 2 NuGet packages that depend on FluentScanning.DependencyInjection:
Package | Downloads |
---|---|
FluentChaining
A lightweight library for implementing responsibility chains in fluent style. |
|
Itmo.Dev.Platform.Events
Package Description |
GitHub repositories
This package is not used by any popular GitHub repositories.
Expanded scanned hierarchy for constructed-from types.