Table of Contents

Class ServiceCollectionDescriptorExtensions

Namespace
Microsoft.Extensions.DependencyInjection
Assembly
nanoFramework.DependencyInjection.dll

Extension methods for adding and removing services to an IServiceCollection.

public static class ServiceCollectionDescriptorExtensions
Inheritance
ServiceCollectionDescriptorExtensions
Inherited Members

Methods

Add(IServiceCollection, ServiceDescriptor)

Adds the specified descriptor to the collection.

public static IServiceCollection Add(this IServiceCollection collection, ServiceDescriptor descriptor)

Parameters

collection IServiceCollection

The IServiceCollection.

descriptor ServiceDescriptor

The ServiceDescriptor to add.

Returns

IServiceCollection

A reference to the current instance of IServiceCollection.

Add(IServiceCollection, IEnumerable)

Adds a sequence of ServiceDescriptor to the collection.

public static IServiceCollection Add(this IServiceCollection collection, IEnumerable descriptors)

Parameters

collection IServiceCollection

The IServiceCollection.

descriptors IEnumerable

The ServiceDescriptors to add.

Returns

IServiceCollection

A reference to the current instance of IServiceCollection.

RemoveAll(IServiceCollection, Type)

Removes all services of type serviceType in IServiceCollection.

public static IServiceCollection RemoveAll(this IServiceCollection collection, Type serviceType)

Parameters

collection IServiceCollection

The IServiceCollection.

serviceType Type

The service type to remove.

Returns

IServiceCollection

The IServiceCollection for chaining.

Replace(IServiceCollection, ServiceDescriptor)

Removes the first service in IServiceCollection with the same service type as descriptor and adds descriptor to the collection.

public static IServiceCollection Replace(this IServiceCollection collection, ServiceDescriptor descriptor)

Parameters

collection IServiceCollection

The IServiceCollection.

descriptor ServiceDescriptor

The ServiceDescriptor to replace with.

Returns

IServiceCollection

The IServiceCollection for chaining.

TryAdd(IServiceCollection, ServiceDescriptor)

Adds the specified descriptor to the collection if the service type hasn't already been registered.

public static void TryAdd(this IServiceCollection collection, ServiceDescriptor descriptor)

Parameters

collection IServiceCollection

The IServiceCollection.

descriptor ServiceDescriptor

The ServiceDescriptor to add.

TryAdd(IServiceCollection, IEnumerable)

Adds the specified descriptors to the collection if the service type hasn't already been registered.

public static void TryAdd(this IServiceCollection collection, IEnumerable descriptors)

Parameters

collection IServiceCollection

The IServiceCollection.

descriptors IEnumerable

The ServiceDescriptors to add.

TryAddEnumerable(IServiceCollection, ServiceDescriptor)

Adds a ServiceDescriptor if an existing descriptor with the same ServiceType and an implementation that does not already exist in services...

public static void TryAddEnumerable(this IServiceCollection services, ServiceDescriptor descriptor)

Parameters

services IServiceCollection

The IServiceCollection.

descriptor ServiceDescriptor

The ServiceDescriptor.

Remarks

Use TryAddEnumerable(IServiceCollection, ServiceDescriptor) when registering a service implementation of a service type that supports multiple registrations of the same service type. Using Add(IServiceCollection, ServiceDescriptor) is not idempotent and can add duplicate ServiceDescriptor instances if called twice. Using TryAddEnumerable(IServiceCollection, ServiceDescriptor) will prevent registration of multiple implementation types.

TryAddEnumerable(IServiceCollection, IEnumerable)

Adds the specified ServiceDescriptors if an existing descriptor with the same ServiceType and an implementation that does not already exist in services...

public static void TryAddEnumerable(this IServiceCollection services, IEnumerable descriptors)

Parameters

services IServiceCollection

The IServiceCollection.

descriptors IEnumerable

The ServiceDescriptors.

Remarks

Use TryAddEnumerable(IServiceCollection, IEnumerable) when registering a service implementation of a service type that supports multiple registrations of the same service type. Using Add(IServiceCollection, IEnumerable) is not idempotent and can add duplicate ServiceDescriptor instances if called twice. Using TryAddEnumerable(IServiceCollection, IEnumerable) will prevent registration of multiple implementation types.

TryAddScoped(IServiceCollection, Type)

Adds the specified service as a Scoped service to the collection if the service type hasn't already been registered.

public static void TryAddScoped(this IServiceCollection collection, Type service)

Parameters

collection IServiceCollection

The IServiceCollection.

service Type

The type of the service to register.

TryAddScoped(IServiceCollection, Type, Type)

Adds the specified service as a Scoped service with the implementationType implementation to the collection if the service type hasn't already been registered.

public static void TryAddScoped(this IServiceCollection collection, Type service, Type implementationType)

Parameters

collection IServiceCollection

The IServiceCollection.

service Type

The type of the service to register.

implementationType Type

The implementation type of the service.

TryAddSingleton(IServiceCollection, Type)

Adds the specified service as a Singleton service to the collection if the service type hasn't already been registered.

public static void TryAddSingleton(this IServiceCollection collection, Type service)

Parameters

collection IServiceCollection

The IServiceCollection.

service Type

The type of the service to register.

TryAddSingleton(IServiceCollection, Type, Type)

Adds the specified service as a Singleton service with the implementationType implementation to the collection if the service type hasn't already been registered.

public static void TryAddSingleton(this IServiceCollection collection, Type service, Type implementationType)

Parameters

collection IServiceCollection

The IServiceCollection.

service Type

The type of the service to register.

implementationType Type

The implementation type of the service.

TryAddTransient(IServiceCollection, Type)

Adds the specified service as a Transient service to the collection if the service type hasn't already been registered.

public static void TryAddTransient(this IServiceCollection collection, Type service)

Parameters

collection IServiceCollection

The IServiceCollection.

service Type

The type of the service to register.

TryAddTransient(IServiceCollection, Type, Type)

Adds the specified service as a Transient service with the implementationType implementation to the collection if the service type hasn't already been registered.

public static void TryAddTransient(this IServiceCollection collection, Type service, Type implementationType)

Parameters

collection IServiceCollection

The IServiceCollection.

service Type

The type of the service to register.

implementationType Type

The implementation type of the service.