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);
            }
        }


    }
}