1 #region MIT license 2 // 3 // MIT license 4 // 5 // Copyright (c) 2007-2008 Jiri Moudry, Pascal Craponne 6 // 7 // Permission is hereby granted, free of charge, to any person obtaining a copy 8 // of this software and associated documentation files (the "Software"), to deal 9 // in the Software without restriction, including without limitation the rights 10 // to use, copy, modify, merge, publish, distribute, sublicense, and/or sell 11 // copies of the Software, and to permit persons to whom the Software is 12 // furnished to do so, subject to the following conditions: 13 // 14 // The above copyright notice and this permission notice shall be included in 15 // all copies or substantial portions of the Software. 16 // 17 // THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR 18 // IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, 19 // FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE 20 // AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER 21 // LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, 22 // OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN 23 // THE SOFTWARE. 24 // 25 #endregion 26 namespace DbLinq.Factory 27 { 28 /// <summary> 29 /// Object factory. Main objects (most of them are stateless) are created with this class 30 /// This may allow later to inject dependencies with a third party injector (I'm a Spring.NET big fan) 31 /// </summary> 32 #if !MONO_STRICT 33 public 34 #endif 35 static class ObjectFactory 36 { 37 /// <summary> 38 /// Central object factory. If you want to use your own factory, just replace this member. 39 /// </summary> 40 public static IObjectFactory Current = new Implementation.ReflectionObjectFactory(); 41 42 /// <summary> 43 /// Gets an instance for the given type. 44 /// May be a singleton. 45 /// </summary> 46 /// <typeparam name="T"></typeparam> 47 /// <returns></returns> Get()48 public static T Get<T>() 49 { 50 return Current.Get<T>(); 51 } 52 53 /// <summary> 54 /// Creates a instance. 55 /// Must not be a singleton. 56 /// </summary> 57 /// <typeparam name="T"></typeparam> 58 /// <returns></returns> Create()59 public static T Create<T>() 60 { 61 return Current.Create<T>(); 62 } 63 } 64 } 65