Mercurial > repos > IBDev-IBBoard.WarFoundry.API
view API/WarFoundryLoader.cs @ 496:00d6cf940c3c
Re #420: Saved army does not save "contained" structure
* Add loading of nesting from .army files
author | IBBoard <dev@ibboard.co.uk> |
---|---|
date | Sat, 01 Sep 2012 15:28:26 +0100 |
parents | 1a632b133606 |
children |
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 System.IO; 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 { public static readonly string DEFAULT_USER_DATA_DIR = Path.Combine(Constants.UserDataPath, "data"); 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); } /// <summary> /// Adds the new data file to the default data directory. Once added, the loader will need to be refreshed to /// force it to load the new file. /// </summary> /// <param name='filePath'> /// The path of the file to copy to the default data directory /// </param> public static void AddNewDataFile(string filePath) { string newFilePath = System.IO.Path.Combine(WarFoundryLoader.DEFAULT_USER_DATA_DIR, System.IO.Path.GetFileName(filePath)); if (!Directory.Exists(WarFoundryLoader.DEFAULT_USER_DATA_DIR)) { Directory.CreateDirectory(WarFoundryLoader.DEFAULT_USER_DATA_DIR); } File.Copy(filePath, newFilePath); } } }