mirror of
https://github.com/farcasclaudiu/myfriendsaround.git
synced 2026-06-29 03:01:46 +03:00
105 lines
5.7 KiB
C#
105 lines
5.7 KiB
C#
using System;
|
|
using System.Collections.Generic;
|
|
|
|
namespace MicroIoc
|
|
{
|
|
public interface IMicroIocContainer
|
|
{
|
|
/// <summary>
|
|
/// Register a type within the container. Useful when registering a type by key, so calls to Resolve(null, key) will work
|
|
/// </summary>
|
|
/// <typeparam name="T">The type of class being registered</typeparam>
|
|
/// <param name="key">If specified, will associate a specific instance for this type</param>
|
|
/// <param name="isSingleton">Indicates if the registration should yield a singleton object when resolved</param>
|
|
/// <returns>The container, complete with new registration</returns>
|
|
IMicroIocContainer Register<T>(string key = null, bool isSingleton = false);
|
|
|
|
/// <summary>
|
|
/// Register an implementation type against an interface or class
|
|
/// </summary>
|
|
/// <typeparam name="TFrom">The type of interface or class to be registered</typeparam>
|
|
/// <typeparam name="TTo">The type of concrete class to be instantiated when <see cref="TFrom" /> is resolved from the container.</typeparam>
|
|
/// <param name="key">If specified, will associate a specific instance for this type</param>
|
|
/// <param name="isSingleton">Indicates if the registration should yield a singleton object when resolved</param>
|
|
/// <returns>The container, complete with new registration</returns>
|
|
IMicroIocContainer Register<TFrom, TTo>(string key = null, bool isSingleton = false) where TTo : TFrom;
|
|
|
|
/// <summary>
|
|
/// Register a specific instance of a concrete implementation for an interface or class
|
|
/// </summary>
|
|
/// <typeparam name="TInterface">The type of interface or class to be registered</typeparam>
|
|
/// <param name="instance">The instance to register in the container</param>
|
|
/// <param name="key">(Optional) a key to specify the instance within the container</param>
|
|
/// <returns>The container, complete with new registration</returns>
|
|
IMicroIocContainer RegisterInstance<TInterface>(TInterface instance, string key = null);
|
|
|
|
/// <summary>
|
|
/// Register a specific instance of a concrete implementation for an interface or class
|
|
/// </summary>
|
|
/// <param name="type">The type of interface or class to be registered</param>
|
|
/// <param name="instance">The instance to register in the container</param>
|
|
/// <param name="key">(Optional) a key to specify the instance within the container</param>
|
|
/// <returns>The container, complete with new registration</returns>
|
|
IMicroIocContainer RegisterInstance(Type type, object instance, string key = null);
|
|
|
|
/// <summary>
|
|
/// Resolve an instance of the specified interface (or class) Type
|
|
/// </summary>
|
|
/// <typeparam name="T">The type of interface or class to be resolved</typeparam>
|
|
/// <param name="key">(Optional) a key to specify the instance within the container</param>
|
|
/// <returns>The registered instance if key is specified, or a dynamically instantiated instance, if not</returns>
|
|
T Resolve<T>(string key = null);
|
|
|
|
/// <summary>
|
|
/// Try to resolve an instance of the specified interface (or class) Type
|
|
/// </summary>
|
|
/// <typeparam name="T">The type of interface or class to be resolved</typeparam>
|
|
/// <param name="key">(Optional) a key to specify the instance within the container</param>
|
|
/// <returns>An instance of <typeparamref name="T"/> if registered, or null</returns>
|
|
T TryResolve<T>(string key = null) where T : class;
|
|
|
|
/// <summary>
|
|
/// Resolve an instance of the specified interface (or class) Type
|
|
/// </summary>
|
|
/// <param name="type">The type of interface or class to be resolved</param>
|
|
/// <param name="key">(Optional) a key to specify the instance within the container</param>
|
|
/// <returns>The registered instance if key is specified, or a dynamically instantiated instance, if not</returns>
|
|
object Resolve(Type type, string key = null);
|
|
|
|
/// <summary>
|
|
/// Try to resolve an instance of the specified interface (or class) Type
|
|
/// </summary>
|
|
/// <param name="type">The type of interface or class to be resolved</param>
|
|
/// <param name="key">(Optional) a key to specify the instance within the container</param>
|
|
/// <returns>An instance of if registered, or null</returns>
|
|
object TryResolve(Type type, string key = null);
|
|
|
|
/// <summary>
|
|
/// Resolve all registered instances of a specified type
|
|
/// </summary>
|
|
/// <typeparam name="T">The type of interface or class to be resolved</typeparam>
|
|
/// <returns>A collection of registered instances. If no instances are registered, returns empty collection, not null</returns>
|
|
IEnumerable<T> ResolveAll<T>();
|
|
|
|
/// <summary>
|
|
/// Resolve all registered instances of a specified type
|
|
/// </summary>
|
|
/// <param name="type">The type of interface or class to be resolved</param>
|
|
/// <returns>A collection of registered instances. If no instances are registered, returns empty collection, not null</returns>
|
|
IEnumerable<object> ResolveAll(Type type);
|
|
|
|
/// <summary>
|
|
///
|
|
/// </summary>
|
|
/// <returns></returns>
|
|
IConfiguration GetConfiguration();
|
|
|
|
/// <summary>
|
|
/// Create an instance with properties from the container.
|
|
/// Only properties attributed [Inject] will be set.
|
|
/// </summary>
|
|
/// <param name="instance"></param>
|
|
void BuildUp(object instance);
|
|
}
|
|
}
|