Tor.ServiceLocation 1.0.1

Install-Package Tor.ServiceLocation -Version 1.0.1
dotnet add package Tor.ServiceLocation --version 1.0.1
<PackageReference Include="Tor.ServiceLocation" Version="1.0.1" />
For projects that support PackageReference, copy this XML node into the project file to reference the package.
paket add Tor.ServiceLocation --version 1.0.1
The NuGet Team does not provide support for this client. Please contact its maintainers for support.
#r "nuget: Tor.ServiceLocation, 1.0.1"
#r directive can be used in F# Interactive, C# scripting and .NET Interactive. Copy this into the interactive tool or source code of the script to reference the package.
// Install Tor.ServiceLocation as a Cake Addin
#addin nuget:?package=Tor.ServiceLocation&version=1.0.1

// Install Tor.ServiceLocation as a Cake Tool
#tool nuget:?package=Tor.ServiceLocation&version=1.0.1
The NuGet Team does not provide support for this client. Please contact its maintainers for support.

Usage: Register a class what you want to create all time:

CommonServiceLocator.RegisterService<ClassA>();

Register a class what you want to create at once (singleton):

CommonServiceLocator.RegisterSingleton<ClassA>();

Register a class with other base types and/or interfaces:

CommonServiceLocator.RegisterSingleton<ClassA>();
			.WithExportType<IClassA>();

This will means, that if you gets ClassA or IClassA from the contaner, this ClassA will be retrieved.

If your class has just one constructor (empty or parameterized), you are ready, but if your class has more constructor, you have to tell the servicelocator what parameters needed:

CommonServiceLocator.RegisterService<ClassE>()
            .WithConstructorParameter<ClassA>()
            .WithConstructorParameter<IClassB>();

This means, the servicelocator will create the ClassE class with this constructor: ClassE(ClassA, IClassB). The ClassA and the IClassB will be created by the servicelocator.

Check the registered classes dependencies:

CommonServiceLocator.CheckServices();

Clear the container:

CommonServiceLocator.Clear();

Gets an object from the container:

var classA = CommonServiceLocator.GetInstance<ClassA>();

Gets a list of objects from the container:

var classAList = CommonServiceLocator.GetInstances<IClassA>();

Thread safety: The servicelocator is thread safe by default.

  • .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
1.0.1 797 5/16/2018
1.0.0 730 5/13/2018

If the registered class has just one parameterized constructor, you don't need to list the constructor parameters.