|
|
using System;
|
|
|
using System.Collections.Generic;
|
|
|
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 void AddRange(Foo[] items) {
|
|
|
Console.WriteLine($"AddRange: Foo[]");
|
|
|
}
|
|
|
|
|
|
}
|
|
|
|
|
|
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 void AddRange(List<T> items) {
|
|
|
Console.WriteLine($"AddRange: {typeof(List<T>)}");
|
|
|
}
|
|
|
|
|
|
public void AddRange(T[] items) {
|
|
|
Console.WriteLine($"AddRange: T[] ofType {typeof(T[])}");
|
|
|
}
|
|
|
}
|
|
|
|
|
|
public class Program {
|
|
|
|
|
|
static void Main(string[] args) {
|
|
|
var listener = new SimpleTraceListener(Console.Out);
|
|
|
var source = Trace<TypeResolver>.TraceSource;
|
|
|
source.Switch.Level = SourceLevels.All;
|
|
|
source.Listeners.Add(listener);
|
|
|
|
|
|
var stopwatch = new Stopwatch();
|
|
|
stopwatch.Start();
|
|
|
|
|
|
var ctx = new ContainerBuilder();
|
|
|
|
|
|
Console.WriteLine($"Created: {stopwatch.ElapsedMilliseconds}");
|
|
|
stopwatch.Restart();
|
|
|
|
|
|
ctx.LoadConfig("data/sample.xml");
|
|
|
|
|
|
Console.WriteLine($"Loaded: {stopwatch.ElapsedMilliseconds}");
|
|
|
|
|
|
var container = ctx.Container;
|
|
|
|
|
|
stopwatch.Restart();
|
|
|
var instace1 = container.Resolve<IContainer<string>>();
|
|
|
Console.WriteLine($"Resolved1: {stopwatch.ElapsedMilliseconds}");
|
|
|
|
|
|
stopwatch.Restart();
|
|
|
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);
|
|
|
}
|
|
|
}
|
|
|
|
|
|
|
|
|
}
|
|
|
}
|
|
|
|