Jinget.Core.DiScanner 6.2.18

The ID prefix of this package has been reserved for one of the owners of this package by NuGet.org. Prefix Reserved
There is a newer prerelease version of this package available.
See the version list below for details.
dotnet add package Jinget.Core.DiScanner --version 6.2.18
NuGet\Install-Package Jinget.Core.DiScanner -Version 6.2.18
This command is intended to be used within the Package Manager Console in Visual Studio, as it uses the NuGet module's version of Install-Package.
<PackageReference Include="Jinget.Core.DiScanner" Version="6.2.18" />
For projects that support PackageReference, copy this XML node into the project file to reference the package.
paket add Jinget.Core.DiScanner --version 6.2.18
#r "nuget: Jinget.Core.DiScanner, 6.2.18"
#r directive can be used in F# Interactive and Polyglot Notebooks. Copy this into the interactive tool or source code of the script to reference the package.
// Install Jinget.Core.DiScanner as a Cake Addin
#addin nuget:?package=Jinget.Core.DiScanner&version=6.2.18

// Install Jinget.Core.DiScanner as a Cake Tool
#tool nuget:?package=Jinget.Core.DiScanner&version=6.2.18

Jinget.Core.DiScanner

Using this library, you can easily register your source code dependencies automatically without the need to write repetitive and annoying codes.

Attention: This package is build based on Autofac assembly scanning.

How to Use:

Download the package from NuGet using Package Manager: Install-Package Jinget.Core.DiScanner You can also use other methods supported by NuGet. Check Here for more information.

Methods

Assembly Selector

Name Description
FromCallingAssembly Will scan for types from the calling assembly
FromExecutingAssembly Will scan for types from the currently executing assembly
FromEntryAssembly Will scan for types from the entry assembly
FromApplicationDependencies Will load and scan all runtime libraries referenced by the currently executing application
FromAssemblyDependencies Will load and scan all runtime libraries referenced by the currently specified assembly
FromDependencyContext Will load and scan all runtime libraries in the given context
FromAssemblyOf Will scan for types from the assembly of type T
FromAssemblies Will scan for types in each Assembly in assemblies

Service Type Selector

Name Description
AsSelf Registers each matching concrete type as itself
FromExecutingAssembly Will scan for types from the currently executing assembly
As Registers each matching concrete type
AsImplementedInterfaces Registers each matching concrete type as all of its implemented interfaces
AsSelfWithInterfaces Registers each matching concrete type as all of its implemented interfaces, by returning an instance of the main type
AsMatchingInterface Registers the type with the first found matching interface name. (e.g. ClassName is matched to IClassName)
UsingAttributes Registers each matching concrete type according to their ServiceDescriptorAttribute

Implementation Type Selector

Name Description
AddClasses Adds all non-abstract classes from the selected assemblies to the Microsoft.Extensions.DependencyInjection.IServiceCollection

Lifetime Selector

Name Description
WithSingletonLifetime Registers each matching concrete type with ServiceLifetime.Singleton lifetime
WithScopedLifetime Registers each matching concrete type with ServiceLifetime.Scoped lifetime
WithTransientLifetime Registers each matching concrete type with ServiceLifetime.Transient lifetime
WithLifetime Registers each matching concrete type with the specified lifetime

Samples

You can view more detailed sample by referring to Jinget.CoreDiScanner.Test project. View UnitTests

Sample 1:

Will scan for types from the calling assembly.

_services.Scan(
    s => s.FromCallingAssembly()
        .AddClasses()
        .AsImplementedInterfaces()
        .WithTransientLifetime());

The above code will scan the calling assembly and registers each matching concrete type as all of its implemented interfaces. WithTransientLifetime indicates that the services should have Transient lifetime.

Sample 2:

Will scan for types from the calling assembly.

_services.Scan(
    s => s.FromExecutingAssembly()
        .AddClasses()
        .AsImplementedInterfaces()
        .WithTransientLifetime());

The above code will scan for types from the currently executing assembly, and registers each matching concrete type as all of its implemented interfaces.

Sample 3:

_services.Scan(
    s => s.FromAssembliesOf(typeof(Sample))
        .AddClasses()
        .AsSelfWithInterfaces()
        .WithSingletonLifetime());

The above code will scan the assembly containing the Sample type and registers each matching concrete type as all of its implemented interfaces, by returning an instance of the main type

Sample 4:

_services.Scan(
    s => s.FromAssemblies(typeof(ICustomInterface).Assembly, typeof(ISelector).Assembly)
        .AddClasses()
        .AsImplementedInterfaces()
        .WithTransientLifetime());

The above code will scan for types in each assembly in assemblies, and registers each matching concrete type as all of its implemented interfaces, by returning an instance of the main type


How to install

In order to install Jinget.Core.DiScanner please refer to nuget.org

Contact Me

👨‍💻 Twitter: https://twitter.com/_jinget

📧 Email: farahmandian2011@gmail.com

📣 Instagram: https://www.instagram.com/vahidfarahmandian

Product Compatible and additional computed target framework versions.
.NET net6.0 is compatible.  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. 
Compatible target framework(s)
Included target framework(s) (in package)
Learn more about Target Frameworks and .NET Standard.

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
6.2.19-preview011 70 6/15/2024
6.2.19-preview010 65 6/14/2024
6.2.19-preview009 56 6/14/2024
6.2.19-preview008 67 6/13/2024
6.2.19-preview007 60 6/13/2024
6.2.19-preview006 55 6/13/2024
6.2.19-preview005 64 6/13/2024
6.2.19-preview004 59 6/13/2024
6.2.19-preview003 57 6/11/2024
6.2.19-preview002 59 6/8/2024
6.2.19-preview001 57 6/8/2024
6.2.18 78 6/6/2024
6.2.18-preview020 62 6/6/2024
6.2.18-preview019 62 6/6/2024
6.2.18-preview018 62 6/6/2024
6.2.18-preview017 63 6/2/2024
6.2.18-preview016 62 6/1/2024
6.2.18-preview015 76 5/28/2024
6.2.18-preview014 64 5/28/2024
6.2.18-preview013 64 5/28/2024
6.2.18-preview012 66 5/28/2024
6.2.18-preview011 70 5/26/2024
6.2.18-preview010 68 5/26/2024
6.2.18-preview009 71 5/26/2024
6.2.18-preview008 75 5/26/2024
6.2.18-preview007 96 5/22/2024
6.2.18-preview006 74 5/22/2024
6.2.18-preview005 79 5/19/2024
6.2.18-preview004 72 5/19/2024
6.2.18-preview003 67 5/19/2024
6.2.18-preview002 67 5/19/2024
6.2.17 84 5/19/2024
6.2.16 78 5/18/2024
6.2.15 84 5/18/2024
6.2.14 80 5/18/2024
6.2.13 89 5/17/2024
6.2.12 96 5/17/2024
6.2.11 94 5/17/2024
6.2.10 90 5/17/2024
6.2.9 69 5/12/2024
6.2.8 72 5/9/2024
6.2.7 63 5/9/2024
6.2.6 100 5/7/2024
6.2.5 91 4/24/2024
6.2.4 108 2/1/2024
6.2.3 81 2/1/2024
6.2.2 80 1/31/2024
6.2.1 90 1/23/2024
6.2.0 79 1/23/2024
6.2.0-preview013 77 1/19/2024