public static PreferenceFactory GetInstance <T>() where T : PreferenceFactory { PreferenceFactory instance; try { instance = DoGetInstance(typeof(T)); } catch (Exception e) { Logger.GetInstance(typeof(PreferenceFactory)).Fatal("Instance initialization error: " + e); Logger.GetInstance(typeof(PreferenceFactory)).Info("Initializing " + typeof(DefaultPreferenceFactory).FullName + "..."); instance = new DefaultPreferenceFactory(); } return(instance); }
private static PreferenceFactory DoGetInstance(Type type) { if (type == null) { throw new ArgumentException("Invalid arguments to get " + typeof(PreferenceFactory).Name + " instance"); } var key = type.FullName + "_"; PreferenceFactory instance = null; if (Instances.ContainsKey(key)) { instance = Instances[key]; } if (instance == null) { Logger.GetInstance(typeof(PreferenceFactory)).Info("Initializing " + key + "..."); var constructor = type.GetConstructor(new Type[] { }); if (constructor != null) { instance = (PreferenceFactory)constructor.Invoke(new object[] { }); } } if (instance == null) { Logger.GetInstance(typeof(PreferenceFactory)).Info("Initializing " + typeof(DefaultPreferenceFactory).FullName + "..."); instance = new DefaultPreferenceFactory(); } lock (InstancesLock) { if (!Instances.ContainsKey(key)) { Instances.Add(key, instance); } } return(instance); }