Mercurial > pub > ImplabNet
view Implab.Playground/Program.cs @ 273:79110a16cab7 v3
Working on Unity xml configuration: Refactoring in progress
author | cin |
---|---|
date | Thu, 26 Apr 2018 19:35:01 +0300 |
parents | 9d1cca834b05 |
children | 22629bf26121 |
line wrap: on
line source
using System; using System.Diagnostics; using System.Linq; using Implab.Diagnostics; using Implab.ServiceHost.Unity; using Implab.Xml; using Unity; using Unity.Injection; using Unity.Registration; namespace Implab.Playground { public class Foo { public class Bar { } public string Name { get; set; } public int IntValue { get; set; } public string StringValue { get; set; } } public interface IContainer<T> { T Instance { get; set; } } public class Container<T> : IContainer<T> { public Container() { } public Container(T instance) { Instance = instance; } public T Instance { get; set; } public void SetInstance(T value) { Instance = value; } } public class Program { static void Main(string[] args) { var stopwatch = new Stopwatch(); stopwatch.Start(); var ctx = new ContainerContext(); Console.WriteLine($"Created: {stopwatch.ElapsedMilliseconds}"); ctx.LoadConfig("data/sample.xml"); Console.WriteLine($"Loaded: {stopwatch.ElapsedMilliseconds}"); var container = ctx.Container; var instace1 = container.Resolve<IContainer<string>>(); Console.WriteLine($"Resolved1: {stopwatch.ElapsedMilliseconds}"); var instace2 = container.Resolve<IContainer<Foo>>(); Console.WriteLine($"Resolved2: {stopwatch.ElapsedMilliseconds}"); DisplayContainerRegistrations(container); } static void DisplayContainerRegistrations(IUnityContainer theContainer) { string regName, regType, mapTo, lifetime; Console.WriteLine("Container has {0} Registrations:", theContainer.Registrations.Count()); foreach (ContainerRegistration item in theContainer.Registrations) { regType = item.RegisteredType.FullName; mapTo = item.MappedToType.FullName; regName = item.Name ?? "[default]"; lifetime = item.LifetimeManager.LifetimeType.Name; if (mapTo != regType) { mapTo = " -> " + mapTo; } else { mapTo = string.Empty; } lifetime = lifetime.Substring(0, lifetime.Length - "LifetimeManager".Length); Console.WriteLine("+ {0}{1} '{2}' {3}", regType, mapTo, regName, lifetime); } } } }