Mercurial > repos > IBDev-IBBoard.WarFoundry.API
view API/WarFoundryLoader.cs @ 415:131fb56da842
* Pull in various changes from IBB-Dev
* Merge heads (Master had merged a branch that was also merged in IBB-Dev)
author | IBBoard <dev@ibboard.co.uk> |
---|---|
date | Wed, 31 Aug 2011 13:57:27 +0100 |
parents | 04f4c2fea356 |
children | 1a632b133606 |
line wrap: on
line source
// This file (WarFoundryLoader.cs) is a part of the IBBoard.WarFoundry.API project and is copyright 2007, 2008, 2009 IBBoard. // // The file and the library/program it is in are licensed and distributed, without warranty, under the GNU Affero GPL license, either version 3 of the License or (at your option) any later version. Please see COPYING for more information and the full license. using System; using ICSharpCode.SharpZipLib.Zip; using System.Collections.Generic; using IBBoard.WarFoundry.API.Factories.Requirement; using IBBoard.WarFoundry.API.Objects.Requirement; namespace IBBoard.WarFoundry.API { public class WarFoundryLoader { private static AbstractWarFoundryLoader loader; private static Dictionary<string, IRequirementFactory> requirementFactories = new Dictionary<string, IRequirementFactory>(); /// <summary> /// Gets the default <see cref="WarFoundryLoader"/> used to load WarFoundry data files. /// </summary> /// <returns> /// The default <see cref="WarFoundryLoader"/> /// </returns> public static AbstractWarFoundryLoader GetDefault() { if (loader == null) { loader = new DefaultWarFoundryLoader(); } return loader; } public static void SetDefault(AbstractWarFoundryLoader newLoader) { loader = newLoader; } private WarFoundryLoader() { //Hide constructor } public static void RegisterRequirementFactory(IRequirementFactory factory) { requirementFactories[factory.AppliesToID] = factory; } public static IRequirementFactory GetRequirementFactory(string requirementID) { return DictionaryUtils.GetValue(requirementFactories, requirementID); } } }