annotate api/Factories/Xml/WarFoundryXmlFactory.cs @ 312:3854c26073c4

Re #253: Allow multiple data files in a single zip * Rebuild file loading to start to allow multiple files in a native file
author IBBoard <dev@ibboard.co.uk>
date Sat, 26 Feb 2011 20:15:12 +0000
parents b9b8b0e60c31
children
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
104
2f3cafb69799 Re #121: Migrate to AGPL license
IBBoard <dev@ibboard.co.uk>
parents: 82
diff changeset
1 // This file (WarFoundryXmlFactory.cs) is a part of the IBBoard.WarFoundry.API project and is copyright 2007, 2008, 2009 IBBoard.
0
520818033bb6 Initial commit of WarFoundry code
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
2 //
104
2f3cafb69799 Re #121: Migrate to AGPL license
IBBoard <dev@ibboard.co.uk>
parents: 82
diff changeset
3 // 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.
0
520818033bb6 Initial commit of WarFoundry code
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
4
520818033bb6 Initial commit of WarFoundry code
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
5 using System;
82
3ea0ab04352b * Fix line terminators
IBBoard <dev@ibboard.co.uk>
parents: 52
diff changeset
6 using System.IO;
0
520818033bb6 Initial commit of WarFoundry code
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
7 using System.Xml;
520818033bb6 Initial commit of WarFoundry code
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
8 using System.Xml.Schema;
34
b28be912adab Re #32 - Migrate to schema
IBBoard <dev@ibboard.co.uk>
parents: 32
diff changeset
9 using System.Xml.XPath;
0
520818033bb6 Initial commit of WarFoundry code
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
10 using System.Collections.Generic;
520818033bb6 Initial commit of WarFoundry code
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
11 using System.Text;
520818033bb6 Initial commit of WarFoundry code
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
12 using IBBoard;
520818033bb6 Initial commit of WarFoundry code
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
13 using IBBoard.IO;
520818033bb6 Initial commit of WarFoundry code
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
14 using IBBoard.Lang;
520818033bb6 Initial commit of WarFoundry code
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
15 using IBBoard.Logging;
520818033bb6 Initial commit of WarFoundry code
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
16 using IBBoard.Xml;
520818033bb6 Initial commit of WarFoundry code
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
17 using IBBoard.WarFoundry.API.Requirements;
520818033bb6 Initial commit of WarFoundry code
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
18 using IBBoard.WarFoundry.API.Objects;
82
3ea0ab04352b * Fix line terminators
IBBoard <dev@ibboard.co.uk>
parents: 52
diff changeset
19 using ICSharpCode.SharpZipLib.Zip;
312
3854c26073c4 Re #253: Allow multiple data files in a single zip
IBBoard <dev@ibboard.co.uk>
parents: 261
diff changeset
20 using System.Text.RegularExpressions;
82
3ea0ab04352b * Fix line terminators
IBBoard <dev@ibboard.co.uk>
parents: 52
diff changeset
21
3ea0ab04352b * Fix line terminators
IBBoard <dev@ibboard.co.uk>
parents: 52
diff changeset
22 namespace IBBoard.WarFoundry.API.Factories.Xml
3ea0ab04352b * Fix line terminators
IBBoard <dev@ibboard.co.uk>
parents: 52
diff changeset
23 {
3ea0ab04352b * Fix line terminators
IBBoard <dev@ibboard.co.uk>
parents: 52
diff changeset
24 /// <summary>
3ea0ab04352b * Fix line terminators
IBBoard <dev@ibboard.co.uk>
parents: 52
diff changeset
25 /// The WarFoundryXmlFactory loads WarFoundry classes from the native "XML in a zip" file format. Files are validated using the schema for the file type, so structurally invalid files should be identified at initial load.
3ea0ab04352b * Fix line terminators
IBBoard <dev@ibboard.co.uk>
parents: 52
diff changeset
26 /// </summary>
3ea0ab04352b * Fix line terminators
IBBoard <dev@ibboard.co.uk>
parents: 52
diff changeset
27 public class WarFoundryXmlFactory : AbstractNativeWarFoundryFactory
0
520818033bb6 Initial commit of WarFoundry code
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
28 {
17
a99d3b8466ba Change "CreateFactory" method to "GetFactory" method to allow for caching
IBBoard <dev@ibboard.co.uk>
parents: 15
diff changeset
29 private static WarFoundryXmlFactory factory;
52
64ef178c18aa Re #10 - Refactor for readability
IBBoard <dev@ibboard.co.uk>
parents: 51
diff changeset
30 private WarFoundryXmlGameSystemFactory gameSystemFactory;
64ef178c18aa Re #10 - Refactor for readability
IBBoard <dev@ibboard.co.uk>
parents: 51
diff changeset
31 private WarFoundryXmlRaceFactory raceFactory;
64ef178c18aa Re #10 - Refactor for readability
IBBoard <dev@ibboard.co.uk>
parents: 51
diff changeset
32 private WarFoundryXmlArmyFactory armyFactory;
0
520818033bb6 Initial commit of WarFoundry code
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
33
234
06b4beb3e156 Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents: 226
diff changeset
34 public static WarFoundryXmlFactory GetFactory()
0
520818033bb6 Initial commit of WarFoundry code
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
35 {
17
a99d3b8466ba Change "CreateFactory" method to "GetFactory" method to allow for caching
IBBoard <dev@ibboard.co.uk>
parents: 15
diff changeset
36 if (factory == null)
a99d3b8466ba Change "CreateFactory" method to "GetFactory" method to allow for caching
IBBoard <dev@ibboard.co.uk>
parents: 15
diff changeset
37 {
a99d3b8466ba Change "CreateFactory" method to "GetFactory" method to allow for caching
IBBoard <dev@ibboard.co.uk>
parents: 15
diff changeset
38 factory = new WarFoundryXmlFactory();
a99d3b8466ba Change "CreateFactory" method to "GetFactory" method to allow for caching
IBBoard <dev@ibboard.co.uk>
parents: 15
diff changeset
39 }
a99d3b8466ba Change "CreateFactory" method to "GetFactory" method to allow for caching
IBBoard <dev@ibboard.co.uk>
parents: 15
diff changeset
40
a99d3b8466ba Change "CreateFactory" method to "GetFactory" method to allow for caching
IBBoard <dev@ibboard.co.uk>
parents: 15
diff changeset
41 return factory;
0
520818033bb6 Initial commit of WarFoundry code
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
42 }
520818033bb6 Initial commit of WarFoundry code
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
43
82
3ea0ab04352b * Fix line terminators
IBBoard <dev@ibboard.co.uk>
parents: 52
diff changeset
44 private WarFoundryXmlFactory() : base()
0
520818033bb6 Initial commit of WarFoundry code
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
45 {
52
64ef178c18aa Re #10 - Refactor for readability
IBBoard <dev@ibboard.co.uk>
parents: 51
diff changeset
46 gameSystemFactory = new WarFoundryXmlGameSystemFactory(this);
64ef178c18aa Re #10 - Refactor for readability
IBBoard <dev@ibboard.co.uk>
parents: 51
diff changeset
47 raceFactory = new WarFoundryXmlRaceFactory(this);
82
3ea0ab04352b * Fix line terminators
IBBoard <dev@ibboard.co.uk>
parents: 52
diff changeset
48 armyFactory = new WarFoundryXmlArmyFactory();
0
520818033bb6 Initial commit of WarFoundry code
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
49 }
520818033bb6 Initial commit of WarFoundry code
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
50
234
06b4beb3e156 Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents: 226
diff changeset
51 public WarFoundryXmlGameSystemFactory GetSystemFactory()
06b4beb3e156 Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents: 226
diff changeset
52 {
06b4beb3e156 Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents: 226
diff changeset
53 return gameSystemFactory;
06b4beb3e156 Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents: 226
diff changeset
54 }
06b4beb3e156 Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents: 226
diff changeset
55
06b4beb3e156 Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents: 226
diff changeset
56 public WarFoundryXmlRaceFactory GetRaceFactory()
06b4beb3e156 Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents: 226
diff changeset
57 {
06b4beb3e156 Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents: 226
diff changeset
58 return raceFactory;
06b4beb3e156 Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents: 226
diff changeset
59 }
06b4beb3e156 Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents: 226
diff changeset
60
06b4beb3e156 Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents: 226
diff changeset
61 public WarFoundryXmlArmyFactory GetArmyFactory()
06b4beb3e156 Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents: 226
diff changeset
62 {
06b4beb3e156 Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents: 226
diff changeset
63 return armyFactory;
06b4beb3e156 Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents: 226
diff changeset
64 }
06b4beb3e156 Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents: 226
diff changeset
65
0
520818033bb6 Initial commit of WarFoundry code
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
66 protected override bool CheckCanFindArmyFileContent(ZipFile file)
520818033bb6 Initial commit of WarFoundry code
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
67 {
312
3854c26073c4 Re #253: Allow multiple data files in a single zip
IBBoard <dev@ibboard.co.uk>
parents: 261
diff changeset
68 return FindEntries(file, "*.armyx").Count > 0;
0
520818033bb6 Initial commit of WarFoundry code
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
69 }
520818033bb6 Initial commit of WarFoundry code
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
70
520818033bb6 Initial commit of WarFoundry code
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
71 protected override bool CheckCanFindSystemFileContent(ZipFile file)
520818033bb6 Initial commit of WarFoundry code
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
72 {
312
3854c26073c4 Re #253: Allow multiple data files in a single zip
IBBoard <dev@ibboard.co.uk>
parents: 261
diff changeset
73 return FindEntries(file, "*.systemx").Count > 0;
0
520818033bb6 Initial commit of WarFoundry code
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
74 }
520818033bb6 Initial commit of WarFoundry code
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
75
520818033bb6 Initial commit of WarFoundry code
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
76 protected override bool CheckCanFindRaceFileContent(ZipFile file)
520818033bb6 Initial commit of WarFoundry code
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
77 {
312
3854c26073c4 Re #253: Allow multiple data files in a single zip
IBBoard <dev@ibboard.co.uk>
parents: 261
diff changeset
78 return FindEntries(file, "*.racex").Count > 0;
3854c26073c4 Re #253: Allow multiple data files in a single zip
IBBoard <dev@ibboard.co.uk>
parents: 261
diff changeset
79 }
3854c26073c4 Re #253: Allow multiple data files in a single zip
IBBoard <dev@ibboard.co.uk>
parents: 261
diff changeset
80
3854c26073c4 Re #253: Allow multiple data files in a single zip
IBBoard <dev@ibboard.co.uk>
parents: 261
diff changeset
81 protected override ICollection<ZipEntry> GetArmyZipEntries(ZipFile file)
3854c26073c4 Re #253: Allow multiple data files in a single zip
IBBoard <dev@ibboard.co.uk>
parents: 261
diff changeset
82 {
3854c26073c4 Re #253: Allow multiple data files in a single zip
IBBoard <dev@ibboard.co.uk>
parents: 261
diff changeset
83 return FindEntries(file, "*.armyx");
0
520818033bb6 Initial commit of WarFoundry code
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
84 }
520818033bb6 Initial commit of WarFoundry code
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
85
312
3854c26073c4 Re #253: Allow multiple data files in a single zip
IBBoard <dev@ibboard.co.uk>
parents: 261
diff changeset
86 private ICollection<ZipEntry> FindEntries(ZipFile file, string wildcardPattern)
50
bb6b993b98bf Re #10 - Refactor for readability
IBBoard <dev@ibboard.co.uk>
parents: 49
diff changeset
87 {
312
3854c26073c4 Re #253: Allow multiple data files in a single zip
IBBoard <dev@ibboard.co.uk>
parents: 261
diff changeset
88 Regex re = new Regex("^" + Regex.Escape(wildcardPattern).Replace(@"\*", ".*").Replace(@"\?", ".") + "$", RegexOptions.IgnoreCase | RegexOptions.Singleline);
3854c26073c4 Re #253: Allow multiple data files in a single zip
IBBoard <dev@ibboard.co.uk>
parents: 261
diff changeset
89 ICollection<ZipEntry> entries = new List<ZipEntry>();
3854c26073c4 Re #253: Allow multiple data files in a single zip
IBBoard <dev@ibboard.co.uk>
parents: 261
diff changeset
90
3854c26073c4 Re #253: Allow multiple data files in a single zip
IBBoard <dev@ibboard.co.uk>
parents: 261
diff changeset
91 foreach (ZipEntry entry in file)
3854c26073c4 Re #253: Allow multiple data files in a single zip
IBBoard <dev@ibboard.co.uk>
parents: 261
diff changeset
92 {
3854c26073c4 Re #253: Allow multiple data files in a single zip
IBBoard <dev@ibboard.co.uk>
parents: 261
diff changeset
93 if (re.IsMatch(entry.Name))
3854c26073c4 Re #253: Allow multiple data files in a single zip
IBBoard <dev@ibboard.co.uk>
parents: 261
diff changeset
94 {
3854c26073c4 Re #253: Allow multiple data files in a single zip
IBBoard <dev@ibboard.co.uk>
parents: 261
diff changeset
95 entries.Add(entry);
3854c26073c4 Re #253: Allow multiple data files in a single zip
IBBoard <dev@ibboard.co.uk>
parents: 261
diff changeset
96 }
3854c26073c4 Re #253: Allow multiple data files in a single zip
IBBoard <dev@ibboard.co.uk>
parents: 261
diff changeset
97 }
3854c26073c4 Re #253: Allow multiple data files in a single zip
IBBoard <dev@ibboard.co.uk>
parents: 261
diff changeset
98
3854c26073c4 Re #253: Allow multiple data files in a single zip
IBBoard <dev@ibboard.co.uk>
parents: 261
diff changeset
99 return entries;
50
bb6b993b98bf Re #10 - Refactor for readability
IBBoard <dev@ibboard.co.uk>
parents: 49
diff changeset
100 }
bb6b993b98bf Re #10 - Refactor for readability
IBBoard <dev@ibboard.co.uk>
parents: 49
diff changeset
101
bb6b993b98bf Re #10 - Refactor for readability
IBBoard <dev@ibboard.co.uk>
parents: 49
diff changeset
102 protected override Army CreateArmyFromStream (ZipFile file, Stream dataStream)
bb6b993b98bf Re #10 - Refactor for readability
IBBoard <dev@ibboard.co.uk>
parents: 49
diff changeset
103 {
bb6b993b98bf Re #10 - Refactor for readability
IBBoard <dev@ibboard.co.uk>
parents: 49
diff changeset
104 XmlElement elem = GetRootElementFromStream(dataStream, WarFoundryXmlElementName.ARMY_ELEMENT);
52
64ef178c18aa Re #10 - Refactor for readability
IBBoard <dev@ibboard.co.uk>
parents: 51
diff changeset
105 return armyFactory.CreateArmyFromElement(file, elem);
50
bb6b993b98bf Re #10 - Refactor for readability
IBBoard <dev@ibboard.co.uk>
parents: 49
diff changeset
106 }
bb6b993b98bf Re #10 - Refactor for readability
IBBoard <dev@ibboard.co.uk>
parents: 49
diff changeset
107
bb6b993b98bf Re #10 - Refactor for readability
IBBoard <dev@ibboard.co.uk>
parents: 49
diff changeset
108 private XmlElement GetRootElementFromStream(Stream stream, WarFoundryXmlElementName elementName)
0
520818033bb6 Initial commit of WarFoundry code
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
109 {
135
a37cdcbcad14 * Line ending change
IBBoard <dev@ibboard.co.uk>
parents: 126
diff changeset
110 XmlDocument doc = WarFoundryXmlFactoryUtils.CreateXmlDocumentFromStream(stream);
199
70ba3bee0c2e Fixes #207: WarFoundry still keeps file handles on failure
IBBoard <dev@ibboard.co.uk>
parents: 151
diff changeset
111
0
520818033bb6 Initial commit of WarFoundry code
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
112 XmlElement elem = (XmlElement)doc.LastChild;
520818033bb6 Initial commit of WarFoundry code
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
113
43
d0812d7de39d Re #49 - Resolve namespace issues
IBBoard <dev@ibboard.co.uk>
parents: 42
diff changeset
114 if (!elem.LocalName.Equals(elementName.Value))
0
520818033bb6 Initial commit of WarFoundry code
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
115 {
520818033bb6 Initial commit of WarFoundry code
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
116 throw new InvalidFileException(String.Format("Root element of XML was not valid. Expected {0} but got {1}", elementName.Value, elem.Name));
520818033bb6 Initial commit of WarFoundry code
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
117 }
520818033bb6 Initial commit of WarFoundry code
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
118
520818033bb6 Initial commit of WarFoundry code
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
119 return elem;
520818033bb6 Initial commit of WarFoundry code
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
120 }
50
bb6b993b98bf Re #10 - Refactor for readability
IBBoard <dev@ibboard.co.uk>
parents: 49
diff changeset
121
312
3854c26073c4 Re #253: Allow multiple data files in a single zip
IBBoard <dev@ibboard.co.uk>
parents: 261
diff changeset
122 protected override ICollection<ZipEntry> GetGameSystemZipEntries(ZipFile file)
50
bb6b993b98bf Re #10 - Refactor for readability
IBBoard <dev@ibboard.co.uk>
parents: 49
diff changeset
123 {
312
3854c26073c4 Re #253: Allow multiple data files in a single zip
IBBoard <dev@ibboard.co.uk>
parents: 261
diff changeset
124 return FindEntries(file, "*.systemx");
50
bb6b993b98bf Re #10 - Refactor for readability
IBBoard <dev@ibboard.co.uk>
parents: 49
diff changeset
125 }
bb6b993b98bf Re #10 - Refactor for readability
IBBoard <dev@ibboard.co.uk>
parents: 49
diff changeset
126
bb6b993b98bf Re #10 - Refactor for readability
IBBoard <dev@ibboard.co.uk>
parents: 49
diff changeset
127 protected override GameSystem CreateGameSystemFromStream (ZipFile file, Stream dataStream)
bb6b993b98bf Re #10 - Refactor for readability
IBBoard <dev@ibboard.co.uk>
parents: 49
diff changeset
128 {
bb6b993b98bf Re #10 - Refactor for readability
IBBoard <dev@ibboard.co.uk>
parents: 49
diff changeset
129 XmlElement elem = GetRootElementFromStream(dataStream, WarFoundryXmlElementName.SYSTEM_ELEMENT);
bb6b993b98bf Re #10 - Refactor for readability
IBBoard <dev@ibboard.co.uk>
parents: 49
diff changeset
130 LogNotifier.Debug(GetType(), "Create GameSystem");
52
64ef178c18aa Re #10 - Refactor for readability
IBBoard <dev@ibboard.co.uk>
parents: 51
diff changeset
131 return gameSystemFactory.CreateSystemFromElement(file, elem);
50
bb6b993b98bf Re #10 - Refactor for readability
IBBoard <dev@ibboard.co.uk>
parents: 49
diff changeset
132 }
bb6b993b98bf Re #10 - Refactor for readability
IBBoard <dev@ibboard.co.uk>
parents: 49
diff changeset
133
312
3854c26073c4 Re #253: Allow multiple data files in a single zip
IBBoard <dev@ibboard.co.uk>
parents: 261
diff changeset
134 protected override ICollection<ZipEntry> GetRaceZipEntries(ZipFile file)
50
bb6b993b98bf Re #10 - Refactor for readability
IBBoard <dev@ibboard.co.uk>
parents: 49
diff changeset
135 {
312
3854c26073c4 Re #253: Allow multiple data files in a single zip
IBBoard <dev@ibboard.co.uk>
parents: 261
diff changeset
136 return FindEntries(file, "*.racex");
50
bb6b993b98bf Re #10 - Refactor for readability
IBBoard <dev@ibboard.co.uk>
parents: 49
diff changeset
137 }
bb6b993b98bf Re #10 - Refactor for readability
IBBoard <dev@ibboard.co.uk>
parents: 49
diff changeset
138
bb6b993b98bf Re #10 - Refactor for readability
IBBoard <dev@ibboard.co.uk>
parents: 49
diff changeset
139 protected override Race CreateRaceFromStream (ZipFile file, Stream dataStream)
bb6b993b98bf Re #10 - Refactor for readability
IBBoard <dev@ibboard.co.uk>
parents: 49
diff changeset
140 {
bb6b993b98bf Re #10 - Refactor for readability
IBBoard <dev@ibboard.co.uk>
parents: 49
diff changeset
141 XmlElement elem = GetRootElementFromStream(dataStream, WarFoundryXmlElementName.RACE_ELEMENT);
bb6b993b98bf Re #10 - Refactor for readability
IBBoard <dev@ibboard.co.uk>
parents: 49
diff changeset
142 LogNotifier.Debug(GetType(), "Create Race");
199
70ba3bee0c2e Fixes #207: WarFoundry still keeps file handles on failure
IBBoard <dev@ibboard.co.uk>
parents: 151
diff changeset
143 return raceFactory.CreateRaceFromElement(file, elem);
70ba3bee0c2e Fixes #207: WarFoundry still keeps file handles on failure
IBBoard <dev@ibboard.co.uk>
parents: 151
diff changeset
144 }
70ba3bee0c2e Fixes #207: WarFoundry still keeps file handles on failure
IBBoard <dev@ibboard.co.uk>
parents: 151
diff changeset
145
70ba3bee0c2e Fixes #207: WarFoundry still keeps file handles on failure
IBBoard <dev@ibboard.co.uk>
parents: 151
diff changeset
146 protected override void CleanUpFileAsSupportedType(ZipFile typedFile)
70ba3bee0c2e Fixes #207: WarFoundry still keeps file handles on failure
IBBoard <dev@ibboard.co.uk>
parents: 151
diff changeset
147 {
70ba3bee0c2e Fixes #207: WarFoundry still keeps file handles on failure
IBBoard <dev@ibboard.co.uk>
parents: 151
diff changeset
148 typedFile.Close();
49
9d31d063b194 Re #10 - Refactor source code for readability
IBBoard <dev@ibboard.co.uk>
parents: 48
diff changeset
149 }
48
b49372dd8afa Re #50 - Complete loading of XML files
IBBoard <dev@ibboard.co.uk>
parents: 47
diff changeset
150
b49372dd8afa Re #50 - Complete loading of XML files
IBBoard <dev@ibboard.co.uk>
parents: 47
diff changeset
151 public override void CompleteLoading(IWarFoundryStagedLoadObject obj)
b49372dd8afa Re #50 - Complete loading of XML files
IBBoard <dev@ibboard.co.uk>
parents: 47
diff changeset
152 {
261
b9b8b0e60c31 Re #281: Export multiple stat lines in HTML
IBBoard <dev@ibboard.co.uk>
parents: 238
diff changeset
153 LogNotifier.DebugFormat(GetType(), "Complete loading of {0} with ID {1}", obj.GetType().Name, obj.ID);
b9b8b0e60c31 Re #281: Export multiple stat lines in HTML
IBBoard <dev@ibboard.co.uk>
parents: 238
diff changeset
154
b9b8b0e60c31 Re #281: Export multiple stat lines in HTML
IBBoard <dev@ibboard.co.uk>
parents: 238
diff changeset
155 if (obj is GameSystem)
b9b8b0e60c31 Re #281: Export multiple stat lines in HTML
IBBoard <dev@ibboard.co.uk>
parents: 238
diff changeset
156 {
b9b8b0e60c31 Re #281: Export multiple stat lines in HTML
IBBoard <dev@ibboard.co.uk>
parents: 238
diff changeset
157 CompleteLoadingGameSystem((GameSystem) obj);
b9b8b0e60c31 Re #281: Export multiple stat lines in HTML
IBBoard <dev@ibboard.co.uk>
parents: 238
diff changeset
158 }
b9b8b0e60c31 Re #281: Export multiple stat lines in HTML
IBBoard <dev@ibboard.co.uk>
parents: 238
diff changeset
159 else if (obj is Race)
b9b8b0e60c31 Re #281: Export multiple stat lines in HTML
IBBoard <dev@ibboard.co.uk>
parents: 238
diff changeset
160 {
b9b8b0e60c31 Re #281: Export multiple stat lines in HTML
IBBoard <dev@ibboard.co.uk>
parents: 238
diff changeset
161 CompleteLoadingRace((Race) obj);
b9b8b0e60c31 Re #281: Export multiple stat lines in HTML
IBBoard <dev@ibboard.co.uk>
parents: 238
diff changeset
162 }
b9b8b0e60c31 Re #281: Export multiple stat lines in HTML
IBBoard <dev@ibboard.co.uk>
parents: 238
diff changeset
163 }
b9b8b0e60c31 Re #281: Export multiple stat lines in HTML
IBBoard <dev@ibboard.co.uk>
parents: 238
diff changeset
164
b9b8b0e60c31 Re #281: Export multiple stat lines in HTML
IBBoard <dev@ibboard.co.uk>
parents: 238
diff changeset
165 private void CompleteLoadingRace(Race race)
b9b8b0e60c31 Re #281: Export multiple stat lines in HTML
IBBoard <dev@ibboard.co.uk>
parents: 238
diff changeset
166 {
b9b8b0e60c31 Re #281: Export multiple stat lines in HTML
IBBoard <dev@ibboard.co.uk>
parents: 238
diff changeset
167 try
b9b8b0e60c31 Re #281: Export multiple stat lines in HTML
IBBoard <dev@ibboard.co.uk>
parents: 238
diff changeset
168 {
b9b8b0e60c31 Re #281: Export multiple stat lines in HTML
IBBoard <dev@ibboard.co.uk>
parents: 238
diff changeset
169 raceFactory.CompleteLoading(race);
238
d1068f4b6d1c Fixes #141: Check IDs of units on loading army
IBBoard <dev@ibboard.co.uk>
parents: 234
diff changeset
170 }
261
b9b8b0e60c31 Re #281: Export multiple stat lines in HTML
IBBoard <dev@ibboard.co.uk>
parents: 238
diff changeset
171 catch (InvalidFileException ex)
b9b8b0e60c31 Re #281: Export multiple stat lines in HTML
IBBoard <dev@ibboard.co.uk>
parents: 238
diff changeset
172 {
b9b8b0e60c31 Re #281: Export multiple stat lines in HTML
IBBoard <dev@ibboard.co.uk>
parents: 238
diff changeset
173 WarFoundryLoader.GetDefault().RemoveRace(race);
b9b8b0e60c31 Re #281: Export multiple stat lines in HTML
IBBoard <dev@ibboard.co.uk>
parents: 238
diff changeset
174 throw;
b9b8b0e60c31 Re #281: Export multiple stat lines in HTML
IBBoard <dev@ibboard.co.uk>
parents: 238
diff changeset
175 }
b9b8b0e60c31 Re #281: Export multiple stat lines in HTML
IBBoard <dev@ibboard.co.uk>
parents: 238
diff changeset
176 }
b9b8b0e60c31 Re #281: Export multiple stat lines in HTML
IBBoard <dev@ibboard.co.uk>
parents: 238
diff changeset
177
b9b8b0e60c31 Re #281: Export multiple stat lines in HTML
IBBoard <dev@ibboard.co.uk>
parents: 238
diff changeset
178 private void CompleteLoadingGameSystem(GameSystem system)
b9b8b0e60c31 Re #281: Export multiple stat lines in HTML
IBBoard <dev@ibboard.co.uk>
parents: 238
diff changeset
179 {
b9b8b0e60c31 Re #281: Export multiple stat lines in HTML
IBBoard <dev@ibboard.co.uk>
parents: 238
diff changeset
180 try
b9b8b0e60c31 Re #281: Export multiple stat lines in HTML
IBBoard <dev@ibboard.co.uk>
parents: 238
diff changeset
181 {
b9b8b0e60c31 Re #281: Export multiple stat lines in HTML
IBBoard <dev@ibboard.co.uk>
parents: 238
diff changeset
182 gameSystemFactory.CompleteLoading(system);
b9b8b0e60c31 Re #281: Export multiple stat lines in HTML
IBBoard <dev@ibboard.co.uk>
parents: 238
diff changeset
183 }
b9b8b0e60c31 Re #281: Export multiple stat lines in HTML
IBBoard <dev@ibboard.co.uk>
parents: 238
diff changeset
184 catch (InvalidFileException ex)
b9b8b0e60c31 Re #281: Export multiple stat lines in HTML
IBBoard <dev@ibboard.co.uk>
parents: 238
diff changeset
185 {
b9b8b0e60c31 Re #281: Export multiple stat lines in HTML
IBBoard <dev@ibboard.co.uk>
parents: 238
diff changeset
186 WarFoundryLoader.GetDefault().RemoveGameSystem(system);
b9b8b0e60c31 Re #281: Export multiple stat lines in HTML
IBBoard <dev@ibboard.co.uk>
parents: 238
diff changeset
187 throw;
b9b8b0e60c31 Re #281: Export multiple stat lines in HTML
IBBoard <dev@ibboard.co.uk>
parents: 238
diff changeset
188 }
47
85f2b9c3609c Re #13 - Use XPath for file loading
IBBoard <dev@ibboard.co.uk>
parents: 45
diff changeset
189 }
82
3ea0ab04352b * Fix line terminators
IBBoard <dev@ibboard.co.uk>
parents: 52
diff changeset
190 }
0
520818033bb6 Initial commit of WarFoundry code
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
191 }