Mercurial > repos > snowblizz-super-API-ideas
annotate api/WarFoundryLoader.cs @ 226:c931684f9024
Re #234: Invalid data file doesn't stop load
* Add internal methods to remove game systems or races that fail to load
* Add error handling on XML CompleteLoading so that game system or race is removed, but make sure not to affect error
author | IBBoard <dev@ibboard.co.uk> |
---|---|
date | Sat, 19 Dec 2009 15:40:50 +0000 |
parents | 721891008b5c |
children | a36a0e9cc05d |
rev | line source |
---|---|
104
2f3cafb69799
Re #121: Migrate to AGPL license
IBBoard <dev@ibboard.co.uk>
parents:
102
diff
changeset
|
1 // This file (WarFoundryLoader.cs) is a part of the IBBoard.WarFoundry.API project and is copyright 2007, 2008, 2009 IBBoard. |
0 | 2 // |
104
2f3cafb69799
Re #121: Migrate to AGPL license
IBBoard <dev@ibboard.co.uk>
parents:
102
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 | 4 |
5 using System; | |
6 using System.Collections.Generic; | |
7 using System.IO; | |
8 using IBBoard.Collections; | |
9 using IBBoard.IO; | |
10 using IBBoard.Logging; | |
11 using IBBoard.WarFoundry.API.Factories; | |
12 using IBBoard.WarFoundry.API.Objects; | |
13 using ICSharpCode.SharpZipLib.Zip; | |
14 | |
15 namespace IBBoard.WarFoundry.API | |
16 { | |
17 public class WarFoundryLoader | |
18 { | |
19 private static WarFoundryLoader loader; | |
20 | |
21 /// <summary> | |
22 /// Gets the default <see cref="WarFoundryLoader"/> used to load WarFoundry data files. | |
23 /// </summary> | |
24 /// <returns> | |
25 /// The default <see cref="WarFoundryLoader"/> | |
26 /// </returns> | |
27 public static WarFoundryLoader GetDefault() | |
28 { | |
29 if (loader == null) | |
30 { | |
31 loader = new WarFoundryLoader(); | |
32 } | |
33 | |
34 return loader; | |
35 } | |
36 | |
37 private ICollection<DirectoryInfo> directories; | |
38 private ICollection<INativeWarFoundryFactory> factories; | |
39 private ICollection<INonNativeWarFoundryFactory> nonNativeFactories; | |
40 private Dictionary<string, GameSystem> systemsTable; | |
41 private Dictionary<string, Dictionary<string, Dictionary<string, Race>>> racesTable; //Keys are: System, Race, SubRace | |
42 private Dictionary<IWarFoundryFactory, SimpleSet<IWarFoundryObject>> loadedObjects; | |
144
721891008b5c
Fixes #22: Add functionality to get failed file loads and reason
IBBoard <dev@ibboard.co.uk>
parents:
141
diff
changeset
|
43 public delegate void FileLoadingCompleteDelegate(List<FileLoadFailure> failures); |
721891008b5c
Fixes #22: Add functionality to get failed file loads and reason
IBBoard <dev@ibboard.co.uk>
parents:
141
diff
changeset
|
44 public event MethodInvoker FileLoadingStarted; |
721891008b5c
Fixes #22: Add functionality to get failed file loads and reason
IBBoard <dev@ibboard.co.uk>
parents:
141
diff
changeset
|
45 public event FileLoadingCompleteDelegate FileLoadingFinished; |
0 | 46 |
144
721891008b5c
Fixes #22: Add functionality to get failed file loads and reason
IBBoard <dev@ibboard.co.uk>
parents:
141
diff
changeset
|
47 private WarFoundryLoader() |
0 | 48 { |
49 directories = new List<DirectoryInfo>(); | |
50 factories = new List<INativeWarFoundryFactory>(); | |
51 nonNativeFactories = new List<INonNativeWarFoundryFactory>(); | |
52 loadedObjects = new Dictionary<IWarFoundryFactory,SimpleSet<IWarFoundryObject>>(); | |
53 } | |
54 | |
55 /// <summary> | |
56 /// Adds a directory to the collection of directories that will be searched for WarFoundry data files. | |
57 /// </summary> | |
58 /// <param name="directory"> | |
59 /// The <see cref="DirectoryInfo"/> to add to the list for searching for data files | |
60 /// </param> | |
61 public void AddLoadDirectory(DirectoryInfo directory) | |
62 { | |
63 if (!directories.Contains(directory)) | |
64 { | |
65 directories.Add(directory); | |
66 } | |
67 } | |
68 | |
69 /// <summary> | |
70 /// Removes a directory from the collection of directories that will be searched for WarFoundry data files. | |
71 /// </summary> | |
72 /// <param name="directory"> | |
73 /// A <see cref="DirectoryInfo"/> | |
74 /// </param> | |
75 public void RemoveLoadDirectory(DirectoryInfo directory) | |
76 { | |
77 if (directories.Contains(directory)) | |
78 { | |
79 directories.Remove(directory); | |
80 } | |
81 } | |
82 | |
83 /// <summary> | |
84 /// Registers a <see cref="INativeWarFoundryFactory"/> as a factory that can parse native data files. | |
85 /// </summary> | |
86 /// <param name="factory"> | |
87 /// The <see cref="INativeWarFoundryFactory"/> to register to parse native data files. | |
88 /// </param> | |
89 public void RegisterFactory(INativeWarFoundryFactory factory) | |
90 { | |
91 if (!factories.Contains(factory)) | |
92 { | |
93 factories.Add(factory); | |
94 } | |
95 } | |
96 | |
97 /// <summary> | |
98 /// Unregisters a <see cref="INativeWarFoundryFactory"/> so that it will no longer be used to try to parse native data files. | |
99 /// </summary> | |
100 /// <param name="factory"> | |
101 /// The <see cref="INativeWarFoundryFactory"/> to remove from the collection of factories that are used to try to parse native data files. | |
102 /// </param> | |
103 public void UnregisterFactory(INativeWarFoundryFactory factory) | |
104 { | |
105 if (factories.Contains(factory)) | |
106 { | |
107 factories.Remove(factory); | |
108 } | |
109 } | |
110 | |
111 /// <summary> | |
112 /// Registers a <see cref="INonNativeWarFoundryFactory"/> so that it will be used to try to parse non-native data files from other applications. | |
113 /// </summary> | |
114 /// <param name="factory"> | |
115 /// The <see cref="INonNativeWarFoundryFactory"/> to register to parse non-native data files. | |
116 /// </param> | |
117 public void RegisterNonNativeFactory(INonNativeWarFoundryFactory factory) | |
118 { | |
119 if (!nonNativeFactories.Contains(factory)) | |
120 { | |
121 nonNativeFactories.Add(factory); | |
122 } | |
123 } | |
124 | |
125 /// <summary> | |
126 /// Unregisters a <see cref="INonNativeWarFoundryFactory"/> so that it will no longer be used to try to parse non-native data files from other applications. | |
127 /// </summary> | |
128 /// <param name="factory"> | |
129 /// The <see cref="INonNativeWarFoundryFactory"/> to remove from the collection of factories that are used to try to parse non-native data files. | |
130 /// </param> | |
131 public void UnregisterNonNativeFactory(INonNativeWarFoundryFactory factory) | |
132 { | |
133 if (nonNativeFactories.Contains(factory)) | |
134 { | |
135 nonNativeFactories.Remove(factory); | |
136 } | |
137 } | |
138 | |
139 /// <summary> | |
140 /// Loads all of the data files in the registered directories. | |
141 /// </summary> | |
14
0770e5cbba7c
Closes #21 - File loading in order
IBBoard <dev@ibboard.co.uk>
parents:
8
diff
changeset
|
142 /// <returns> |
141
32b774f24017
Re #22 - Get errored file loading
IBBoard <dev@ibboard.co.uk>
parents:
114
diff
changeset
|
143 /// A <see cref="List"/> of <see cref="FileLoadFailure"/> for files that failed to load |
14
0770e5cbba7c
Closes #21 - File loading in order
IBBoard <dev@ibboard.co.uk>
parents:
8
diff
changeset
|
144 /// </returns> |
0770e5cbba7c
Closes #21 - File loading in order
IBBoard <dev@ibboard.co.uk>
parents:
8
diff
changeset
|
145 public List<FileLoadFailure> LoadFiles() |
0 | 146 { |
147 LogNotifier.Debug(GetType(), "Load files"); | |
148 PrepareForFileLoad(); | |
14
0770e5cbba7c
Closes #21 - File loading in order
IBBoard <dev@ibboard.co.uk>
parents:
8
diff
changeset
|
149 Dictionary<FileInfo, IWarFoundryFactory> loadableRaces = new Dictionary<FileInfo, IWarFoundryFactory>(); |
0770e5cbba7c
Closes #21 - File loading in order
IBBoard <dev@ibboard.co.uk>
parents:
8
diff
changeset
|
150 Dictionary<FileInfo, IWarFoundryFactory> loadableGameSystems = new Dictionary<FileInfo, IWarFoundryFactory>(); |
0770e5cbba7c
Closes #21 - File loading in order
IBBoard <dev@ibboard.co.uk>
parents:
8
diff
changeset
|
151 List<FileLoadFailure> failedLoads = FillLoadableFiles(loadableRaces, loadableGameSystems); |
0770e5cbba7c
Closes #21 - File loading in order
IBBoard <dev@ibboard.co.uk>
parents:
8
diff
changeset
|
152 failedLoads.AddRange(LoadGameSystems(loadableGameSystems)); |
0770e5cbba7c
Closes #21 - File loading in order
IBBoard <dev@ibboard.co.uk>
parents:
8
diff
changeset
|
153 failedLoads.AddRange(LoadRaces(loadableRaces)); |
144
721891008b5c
Fixes #22: Add functionality to get failed file loads and reason
IBBoard <dev@ibboard.co.uk>
parents:
141
diff
changeset
|
154 OnFileLoadingFinished(failedLoads); |
14
0770e5cbba7c
Closes #21 - File loading in order
IBBoard <dev@ibboard.co.uk>
parents:
8
diff
changeset
|
155 return failedLoads; |
0 | 156 } |
157 | |
144
721891008b5c
Fixes #22: Add functionality to get failed file loads and reason
IBBoard <dev@ibboard.co.uk>
parents:
141
diff
changeset
|
158 private void OnFileLoadingFinished(List<FileLoadFailure> failures) |
721891008b5c
Fixes #22: Add functionality to get failed file loads and reason
IBBoard <dev@ibboard.co.uk>
parents:
141
diff
changeset
|
159 { |
721891008b5c
Fixes #22: Add functionality to get failed file loads and reason
IBBoard <dev@ibboard.co.uk>
parents:
141
diff
changeset
|
160 if (FileLoadingFinished!=null) |
721891008b5c
Fixes #22: Add functionality to get failed file loads and reason
IBBoard <dev@ibboard.co.uk>
parents:
141
diff
changeset
|
161 { |
721891008b5c
Fixes #22: Add functionality to get failed file loads and reason
IBBoard <dev@ibboard.co.uk>
parents:
141
diff
changeset
|
162 FileLoadingFinished(failures); |
721891008b5c
Fixes #22: Add functionality to get failed file loads and reason
IBBoard <dev@ibboard.co.uk>
parents:
141
diff
changeset
|
163 } |
721891008b5c
Fixes #22: Add functionality to get failed file loads and reason
IBBoard <dev@ibboard.co.uk>
parents:
141
diff
changeset
|
164 } |
721891008b5c
Fixes #22: Add functionality to get failed file loads and reason
IBBoard <dev@ibboard.co.uk>
parents:
141
diff
changeset
|
165 |
0 | 166 protected void PrepareForFileLoad() |
167 { | |
168 //Just set up blank dictionaries for now - may try different and more complex handling in future | |
169 systemsTable = new Dictionary<string,GameSystem>(); | |
170 racesTable = new Dictionary<string,Dictionary<string,Dictionary<string,Race>>>(); | |
171 } | |
14
0770e5cbba7c
Closes #21 - File loading in order
IBBoard <dev@ibboard.co.uk>
parents:
8
diff
changeset
|
172 |
0770e5cbba7c
Closes #21 - File loading in order
IBBoard <dev@ibboard.co.uk>
parents:
8
diff
changeset
|
173 private List<FileLoadFailure> FillLoadableFiles(Dictionary<FileInfo, IWarFoundryFactory> loadableRaces, Dictionary<FileInfo, IWarFoundryFactory> loadableGameSystems) |
0770e5cbba7c
Closes #21 - File loading in order
IBBoard <dev@ibboard.co.uk>
parents:
8
diff
changeset
|
174 { |
0770e5cbba7c
Closes #21 - File loading in order
IBBoard <dev@ibboard.co.uk>
parents:
8
diff
changeset
|
175 List<FileLoadFailure> fails = new List<FileLoadFailure>(); |
0770e5cbba7c
Closes #21 - File loading in order
IBBoard <dev@ibboard.co.uk>
parents:
8
diff
changeset
|
176 |
0770e5cbba7c
Closes #21 - File loading in order
IBBoard <dev@ibboard.co.uk>
parents:
8
diff
changeset
|
177 foreach (DirectoryInfo directory in directories) |
0770e5cbba7c
Closes #21 - File loading in order
IBBoard <dev@ibboard.co.uk>
parents:
8
diff
changeset
|
178 { |
0770e5cbba7c
Closes #21 - File loading in order
IBBoard <dev@ibboard.co.uk>
parents:
8
diff
changeset
|
179 if (directory.Exists) |
0770e5cbba7c
Closes #21 - File loading in order
IBBoard <dev@ibboard.co.uk>
parents:
8
diff
changeset
|
180 { |
0770e5cbba7c
Closes #21 - File loading in order
IBBoard <dev@ibboard.co.uk>
parents:
8
diff
changeset
|
181 List<FileLoadFailure> directoryFails = FillLoadableFilesForDirectory(loadableRaces, loadableGameSystems, directory); |
0770e5cbba7c
Closes #21 - File loading in order
IBBoard <dev@ibboard.co.uk>
parents:
8
diff
changeset
|
182 fails.AddRange(directoryFails); |
0770e5cbba7c
Closes #21 - File loading in order
IBBoard <dev@ibboard.co.uk>
parents:
8
diff
changeset
|
183 } |
0770e5cbba7c
Closes #21 - File loading in order
IBBoard <dev@ibboard.co.uk>
parents:
8
diff
changeset
|
184 else |
0770e5cbba7c
Closes #21 - File loading in order
IBBoard <dev@ibboard.co.uk>
parents:
8
diff
changeset
|
185 { |
0770e5cbba7c
Closes #21 - File loading in order
IBBoard <dev@ibboard.co.uk>
parents:
8
diff
changeset
|
186 LogNotifier.WarnFormat(GetType(), "Load for {0} failed because directory didn't exist", directory.FullName); |
0770e5cbba7c
Closes #21 - File loading in order
IBBoard <dev@ibboard.co.uk>
parents:
8
diff
changeset
|
187 } |
0770e5cbba7c
Closes #21 - File loading in order
IBBoard <dev@ibboard.co.uk>
parents:
8
diff
changeset
|
188 } |
0770e5cbba7c
Closes #21 - File loading in order
IBBoard <dev@ibboard.co.uk>
parents:
8
diff
changeset
|
189 |
0770e5cbba7c
Closes #21 - File loading in order
IBBoard <dev@ibboard.co.uk>
parents:
8
diff
changeset
|
190 return fails; |
0770e5cbba7c
Closes #21 - File loading in order
IBBoard <dev@ibboard.co.uk>
parents:
8
diff
changeset
|
191 } |
0770e5cbba7c
Closes #21 - File loading in order
IBBoard <dev@ibboard.co.uk>
parents:
8
diff
changeset
|
192 |
0770e5cbba7c
Closes #21 - File loading in order
IBBoard <dev@ibboard.co.uk>
parents:
8
diff
changeset
|
193 private List<FileLoadFailure> FillLoadableFilesForDirectory(Dictionary<FileInfo, IWarFoundryFactory> loadableRaces, Dictionary<FileInfo, IWarFoundryFactory> loadableGameSystems, DirectoryInfo directory) |
0770e5cbba7c
Closes #21 - File loading in order
IBBoard <dev@ibboard.co.uk>
parents:
8
diff
changeset
|
194 { |
0770e5cbba7c
Closes #21 - File loading in order
IBBoard <dev@ibboard.co.uk>
parents:
8
diff
changeset
|
195 List<FileLoadFailure> fails = new List<FileLoadFailure>(); |
0770e5cbba7c
Closes #21 - File loading in order
IBBoard <dev@ibboard.co.uk>
parents:
8
diff
changeset
|
196 LogNotifier.Debug(GetType(), "Load from "+directory.FullName); |
0770e5cbba7c
Closes #21 - File loading in order
IBBoard <dev@ibboard.co.uk>
parents:
8
diff
changeset
|
197 |
0770e5cbba7c
Closes #21 - File loading in order
IBBoard <dev@ibboard.co.uk>
parents:
8
diff
changeset
|
198 foreach (FileInfo file in directory.GetFiles()) |
0770e5cbba7c
Closes #21 - File loading in order
IBBoard <dev@ibboard.co.uk>
parents:
8
diff
changeset
|
199 { |
27 | 200 IWarFoundryFactory factory = GetGameSystemLoadingFactoryForFile(file); |
14
0770e5cbba7c
Closes #21 - File loading in order
IBBoard <dev@ibboard.co.uk>
parents:
8
diff
changeset
|
201 |
0770e5cbba7c
Closes #21 - File loading in order
IBBoard <dev@ibboard.co.uk>
parents:
8
diff
changeset
|
202 if (factory != null) |
0770e5cbba7c
Closes #21 - File loading in order
IBBoard <dev@ibboard.co.uk>
parents:
8
diff
changeset
|
203 { |
0770e5cbba7c
Closes #21 - File loading in order
IBBoard <dev@ibboard.co.uk>
parents:
8
diff
changeset
|
204 loadableGameSystems.Add(file, factory); |
0770e5cbba7c
Closes #21 - File loading in order
IBBoard <dev@ibboard.co.uk>
parents:
8
diff
changeset
|
205 } |
0770e5cbba7c
Closes #21 - File loading in order
IBBoard <dev@ibboard.co.uk>
parents:
8
diff
changeset
|
206 else |
0770e5cbba7c
Closes #21 - File loading in order
IBBoard <dev@ibboard.co.uk>
parents:
8
diff
changeset
|
207 { |
0770e5cbba7c
Closes #21 - File loading in order
IBBoard <dev@ibboard.co.uk>
parents:
8
diff
changeset
|
208 factory = GetRaceLoadingFactoryForFile(file); |
0770e5cbba7c
Closes #21 - File loading in order
IBBoard <dev@ibboard.co.uk>
parents:
8
diff
changeset
|
209 |
0770e5cbba7c
Closes #21 - File loading in order
IBBoard <dev@ibboard.co.uk>
parents:
8
diff
changeset
|
210 if (factory!=null) |
0770e5cbba7c
Closes #21 - File loading in order
IBBoard <dev@ibboard.co.uk>
parents:
8
diff
changeset
|
211 { |
0770e5cbba7c
Closes #21 - File loading in order
IBBoard <dev@ibboard.co.uk>
parents:
8
diff
changeset
|
212 loadableRaces.Add(file, factory); |
0770e5cbba7c
Closes #21 - File loading in order
IBBoard <dev@ibboard.co.uk>
parents:
8
diff
changeset
|
213 } |
0770e5cbba7c
Closes #21 - File loading in order
IBBoard <dev@ibboard.co.uk>
parents:
8
diff
changeset
|
214 else |
0770e5cbba7c
Closes #21 - File loading in order
IBBoard <dev@ibboard.co.uk>
parents:
8
diff
changeset
|
215 { |
30
92cf25b0493b
Re #32 - Migrate to using Schemas
IBBoard <dev@ibboard.co.uk>
parents:
27
diff
changeset
|
216 FileLoadFailure failure = new FileLoadFailure(file, "File not handled as a Race or Game System definition: {0}", "FileNotHandled"); |
92cf25b0493b
Re #32 - Migrate to using Schemas
IBBoard <dev@ibboard.co.uk>
parents:
27
diff
changeset
|
217 fails.Add(failure); |
92cf25b0493b
Re #32 - Migrate to using Schemas
IBBoard <dev@ibboard.co.uk>
parents:
27
diff
changeset
|
218 LogNotifier.Info(GetType(), failure.Message); |
14
0770e5cbba7c
Closes #21 - File loading in order
IBBoard <dev@ibboard.co.uk>
parents:
8
diff
changeset
|
219 } |
0770e5cbba7c
Closes #21 - File loading in order
IBBoard <dev@ibboard.co.uk>
parents:
8
diff
changeset
|
220 } |
0770e5cbba7c
Closes #21 - File loading in order
IBBoard <dev@ibboard.co.uk>
parents:
8
diff
changeset
|
221 } |
0770e5cbba7c
Closes #21 - File loading in order
IBBoard <dev@ibboard.co.uk>
parents:
8
diff
changeset
|
222 |
0770e5cbba7c
Closes #21 - File loading in order
IBBoard <dev@ibboard.co.uk>
parents:
8
diff
changeset
|
223 return fails; |
0770e5cbba7c
Closes #21 - File loading in order
IBBoard <dev@ibboard.co.uk>
parents:
8
diff
changeset
|
224 } |
0770e5cbba7c
Closes #21 - File loading in order
IBBoard <dev@ibboard.co.uk>
parents:
8
diff
changeset
|
225 |
27 | 226 private IWarFoundryFactory GetGameSystemLoadingFactoryForFile(FileInfo file) |
14
0770e5cbba7c
Closes #21 - File loading in order
IBBoard <dev@ibboard.co.uk>
parents:
8
diff
changeset
|
227 { |
0770e5cbba7c
Closes #21 - File loading in order
IBBoard <dev@ibboard.co.uk>
parents:
8
diff
changeset
|
228 IWarFoundryFactory loadingFactory = null; |
0770e5cbba7c
Closes #21 - File loading in order
IBBoard <dev@ibboard.co.uk>
parents:
8
diff
changeset
|
229 |
0770e5cbba7c
Closes #21 - File loading in order
IBBoard <dev@ibboard.co.uk>
parents:
8
diff
changeset
|
230 foreach (INonNativeWarFoundryFactory factory in nonNativeFactories) |
0770e5cbba7c
Closes #21 - File loading in order
IBBoard <dev@ibboard.co.uk>
parents:
8
diff
changeset
|
231 { |
0770e5cbba7c
Closes #21 - File loading in order
IBBoard <dev@ibboard.co.uk>
parents:
8
diff
changeset
|
232 if (factory.CanHandleFileAsGameSystem(file)) |
0770e5cbba7c
Closes #21 - File loading in order
IBBoard <dev@ibboard.co.uk>
parents:
8
diff
changeset
|
233 { |
0770e5cbba7c
Closes #21 - File loading in order
IBBoard <dev@ibboard.co.uk>
parents:
8
diff
changeset
|
234 loadingFactory = factory; |
0770e5cbba7c
Closes #21 - File loading in order
IBBoard <dev@ibboard.co.uk>
parents:
8
diff
changeset
|
235 break; |
0770e5cbba7c
Closes #21 - File loading in order
IBBoard <dev@ibboard.co.uk>
parents:
8
diff
changeset
|
236 } |
0770e5cbba7c
Closes #21 - File loading in order
IBBoard <dev@ibboard.co.uk>
parents:
8
diff
changeset
|
237 } |
0770e5cbba7c
Closes #21 - File loading in order
IBBoard <dev@ibboard.co.uk>
parents:
8
diff
changeset
|
238 |
0770e5cbba7c
Closes #21 - File loading in order
IBBoard <dev@ibboard.co.uk>
parents:
8
diff
changeset
|
239 if (loadingFactory == null) |
0770e5cbba7c
Closes #21 - File loading in order
IBBoard <dev@ibboard.co.uk>
parents:
8
diff
changeset
|
240 { |
0770e5cbba7c
Closes #21 - File loading in order
IBBoard <dev@ibboard.co.uk>
parents:
8
diff
changeset
|
241 foreach (INativeWarFoundryFactory factory in factories) |
0770e5cbba7c
Closes #21 - File loading in order
IBBoard <dev@ibboard.co.uk>
parents:
8
diff
changeset
|
242 { |
0770e5cbba7c
Closes #21 - File loading in order
IBBoard <dev@ibboard.co.uk>
parents:
8
diff
changeset
|
243 if (factory.CanHandleFileAsGameSystem(file)) |
0770e5cbba7c
Closes #21 - File loading in order
IBBoard <dev@ibboard.co.uk>
parents:
8
diff
changeset
|
244 { |
0770e5cbba7c
Closes #21 - File loading in order
IBBoard <dev@ibboard.co.uk>
parents:
8
diff
changeset
|
245 loadingFactory = factory; |
0770e5cbba7c
Closes #21 - File loading in order
IBBoard <dev@ibboard.co.uk>
parents:
8
diff
changeset
|
246 break; |
0770e5cbba7c
Closes #21 - File loading in order
IBBoard <dev@ibboard.co.uk>
parents:
8
diff
changeset
|
247 } |
0770e5cbba7c
Closes #21 - File loading in order
IBBoard <dev@ibboard.co.uk>
parents:
8
diff
changeset
|
248 } |
0770e5cbba7c
Closes #21 - File loading in order
IBBoard <dev@ibboard.co.uk>
parents:
8
diff
changeset
|
249 } |
0770e5cbba7c
Closes #21 - File loading in order
IBBoard <dev@ibboard.co.uk>
parents:
8
diff
changeset
|
250 |
0770e5cbba7c
Closes #21 - File loading in order
IBBoard <dev@ibboard.co.uk>
parents:
8
diff
changeset
|
251 return loadingFactory; |
0770e5cbba7c
Closes #21 - File loading in order
IBBoard <dev@ibboard.co.uk>
parents:
8
diff
changeset
|
252 } |
0770e5cbba7c
Closes #21 - File loading in order
IBBoard <dev@ibboard.co.uk>
parents:
8
diff
changeset
|
253 |
0770e5cbba7c
Closes #21 - File loading in order
IBBoard <dev@ibboard.co.uk>
parents:
8
diff
changeset
|
254 private IWarFoundryFactory GetRaceLoadingFactoryForFile(FileInfo file) |
0770e5cbba7c
Closes #21 - File loading in order
IBBoard <dev@ibboard.co.uk>
parents:
8
diff
changeset
|
255 { |
0770e5cbba7c
Closes #21 - File loading in order
IBBoard <dev@ibboard.co.uk>
parents:
8
diff
changeset
|
256 IWarFoundryFactory loadingFactory = null; |
0770e5cbba7c
Closes #21 - File loading in order
IBBoard <dev@ibboard.co.uk>
parents:
8
diff
changeset
|
257 |
0770e5cbba7c
Closes #21 - File loading in order
IBBoard <dev@ibboard.co.uk>
parents:
8
diff
changeset
|
258 foreach (INonNativeWarFoundryFactory factory in nonNativeFactories) |
0770e5cbba7c
Closes #21 - File loading in order
IBBoard <dev@ibboard.co.uk>
parents:
8
diff
changeset
|
259 { |
0770e5cbba7c
Closes #21 - File loading in order
IBBoard <dev@ibboard.co.uk>
parents:
8
diff
changeset
|
260 if (factory.CanHandleFileAsRace(file)) |
0770e5cbba7c
Closes #21 - File loading in order
IBBoard <dev@ibboard.co.uk>
parents:
8
diff
changeset
|
261 { |
0770e5cbba7c
Closes #21 - File loading in order
IBBoard <dev@ibboard.co.uk>
parents:
8
diff
changeset
|
262 loadingFactory = factory; |
0770e5cbba7c
Closes #21 - File loading in order
IBBoard <dev@ibboard.co.uk>
parents:
8
diff
changeset
|
263 break; |
0770e5cbba7c
Closes #21 - File loading in order
IBBoard <dev@ibboard.co.uk>
parents:
8
diff
changeset
|
264 } |
0770e5cbba7c
Closes #21 - File loading in order
IBBoard <dev@ibboard.co.uk>
parents:
8
diff
changeset
|
265 } |
0770e5cbba7c
Closes #21 - File loading in order
IBBoard <dev@ibboard.co.uk>
parents:
8
diff
changeset
|
266 |
0770e5cbba7c
Closes #21 - File loading in order
IBBoard <dev@ibboard.co.uk>
parents:
8
diff
changeset
|
267 if (loadingFactory == null) |
0770e5cbba7c
Closes #21 - File loading in order
IBBoard <dev@ibboard.co.uk>
parents:
8
diff
changeset
|
268 { |
0770e5cbba7c
Closes #21 - File loading in order
IBBoard <dev@ibboard.co.uk>
parents:
8
diff
changeset
|
269 foreach (INativeWarFoundryFactory factory in factories) |
0770e5cbba7c
Closes #21 - File loading in order
IBBoard <dev@ibboard.co.uk>
parents:
8
diff
changeset
|
270 { |
0770e5cbba7c
Closes #21 - File loading in order
IBBoard <dev@ibboard.co.uk>
parents:
8
diff
changeset
|
271 if (factory.CanHandleFileAsRace(file)) |
0770e5cbba7c
Closes #21 - File loading in order
IBBoard <dev@ibboard.co.uk>
parents:
8
diff
changeset
|
272 { |
0770e5cbba7c
Closes #21 - File loading in order
IBBoard <dev@ibboard.co.uk>
parents:
8
diff
changeset
|
273 loadingFactory = factory; |
0770e5cbba7c
Closes #21 - File loading in order
IBBoard <dev@ibboard.co.uk>
parents:
8
diff
changeset
|
274 break; |
0770e5cbba7c
Closes #21 - File loading in order
IBBoard <dev@ibboard.co.uk>
parents:
8
diff
changeset
|
275 } |
0770e5cbba7c
Closes #21 - File loading in order
IBBoard <dev@ibboard.co.uk>
parents:
8
diff
changeset
|
276 } |
0770e5cbba7c
Closes #21 - File loading in order
IBBoard <dev@ibboard.co.uk>
parents:
8
diff
changeset
|
277 } |
0770e5cbba7c
Closes #21 - File loading in order
IBBoard <dev@ibboard.co.uk>
parents:
8
diff
changeset
|
278 |
0770e5cbba7c
Closes #21 - File loading in order
IBBoard <dev@ibboard.co.uk>
parents:
8
diff
changeset
|
279 return loadingFactory; |
0770e5cbba7c
Closes #21 - File loading in order
IBBoard <dev@ibboard.co.uk>
parents:
8
diff
changeset
|
280 } |
0770e5cbba7c
Closes #21 - File loading in order
IBBoard <dev@ibboard.co.uk>
parents:
8
diff
changeset
|
281 |
0770e5cbba7c
Closes #21 - File loading in order
IBBoard <dev@ibboard.co.uk>
parents:
8
diff
changeset
|
282 private List<FileLoadFailure> LoadGameSystems(Dictionary<FileInfo, IWarFoundryFactory> gameSystemFiles) |
0770e5cbba7c
Closes #21 - File loading in order
IBBoard <dev@ibboard.co.uk>
parents:
8
diff
changeset
|
283 { |
0770e5cbba7c
Closes #21 - File loading in order
IBBoard <dev@ibboard.co.uk>
parents:
8
diff
changeset
|
284 List<FileLoadFailure> fails = new List<FileLoadFailure>(); |
0770e5cbba7c
Closes #21 - File loading in order
IBBoard <dev@ibboard.co.uk>
parents:
8
diff
changeset
|
285 |
0770e5cbba7c
Closes #21 - File loading in order
IBBoard <dev@ibboard.co.uk>
parents:
8
diff
changeset
|
286 |
0770e5cbba7c
Closes #21 - File loading in order
IBBoard <dev@ibboard.co.uk>
parents:
8
diff
changeset
|
287 foreach (FileInfo file in gameSystemFiles.Keys) |
0770e5cbba7c
Closes #21 - File loading in order
IBBoard <dev@ibboard.co.uk>
parents:
8
diff
changeset
|
288 { |
23
f9846f896df3
Re #32 - Migrate WarFoundry files to using Schemas
IBBoard <dev@ibboard.co.uk>
parents:
20
diff
changeset
|
289 FileLoadFailure failure = null; |
f9846f896df3
Re #32 - Migrate WarFoundry files to using Schemas
IBBoard <dev@ibboard.co.uk>
parents:
20
diff
changeset
|
290 |
14
0770e5cbba7c
Closes #21 - File loading in order
IBBoard <dev@ibboard.co.uk>
parents:
8
diff
changeset
|
291 try |
0770e5cbba7c
Closes #21 - File loading in order
IBBoard <dev@ibboard.co.uk>
parents:
8
diff
changeset
|
292 { |
0770e5cbba7c
Closes #21 - File loading in order
IBBoard <dev@ibboard.co.uk>
parents:
8
diff
changeset
|
293 bool loaded = LoadObject(file, gameSystemFiles[file]); |
0770e5cbba7c
Closes #21 - File loading in order
IBBoard <dev@ibboard.co.uk>
parents:
8
diff
changeset
|
294 |
0770e5cbba7c
Closes #21 - File loading in order
IBBoard <dev@ibboard.co.uk>
parents:
8
diff
changeset
|
295 if (!loaded) |
0770e5cbba7c
Closes #21 - File loading in order
IBBoard <dev@ibboard.co.uk>
parents:
8
diff
changeset
|
296 { |
41
422ddd5fedd1
Re #48 - Require schemas to validate
IBBoard <dev@ibboard.co.uk>
parents:
30
diff
changeset
|
297 failure = new FileLoadFailure(file, "FileLoadFailed", "Failed to load {0} as GameSystem using {1}"); |
14
0770e5cbba7c
Closes #21 - File loading in order
IBBoard <dev@ibboard.co.uk>
parents:
8
diff
changeset
|
298 } |
0770e5cbba7c
Closes #21 - File loading in order
IBBoard <dev@ibboard.co.uk>
parents:
8
diff
changeset
|
299 } |
0770e5cbba7c
Closes #21 - File loading in order
IBBoard <dev@ibboard.co.uk>
parents:
8
diff
changeset
|
300 catch (Exception ex) |
0770e5cbba7c
Closes #21 - File loading in order
IBBoard <dev@ibboard.co.uk>
parents:
8
diff
changeset
|
301 { |
30
92cf25b0493b
Re #32 - Migrate to using Schemas
IBBoard <dev@ibboard.co.uk>
parents:
27
diff
changeset
|
302 failure = new FileLoadFailure(file, null, ex.Message, null, ex); |
23
f9846f896df3
Re #32 - Migrate WarFoundry files to using Schemas
IBBoard <dev@ibboard.co.uk>
parents:
20
diff
changeset
|
303 } |
f9846f896df3
Re #32 - Migrate WarFoundry files to using Schemas
IBBoard <dev@ibboard.co.uk>
parents:
20
diff
changeset
|
304 |
f9846f896df3
Re #32 - Migrate WarFoundry files to using Schemas
IBBoard <dev@ibboard.co.uk>
parents:
20
diff
changeset
|
305 if (failure!=null) |
f9846f896df3
Re #32 - Migrate WarFoundry files to using Schemas
IBBoard <dev@ibboard.co.uk>
parents:
20
diff
changeset
|
306 { |
f9846f896df3
Re #32 - Migrate WarFoundry files to using Schemas
IBBoard <dev@ibboard.co.uk>
parents:
20
diff
changeset
|
307 fails.Add(failure); |
41
422ddd5fedd1
Re #48 - Require schemas to validate
IBBoard <dev@ibboard.co.uk>
parents:
30
diff
changeset
|
308 LogNotifier.Warn(GetType(), failure.Message, failure.Exception); |
14
0770e5cbba7c
Closes #21 - File loading in order
IBBoard <dev@ibboard.co.uk>
parents:
8
diff
changeset
|
309 } |
0770e5cbba7c
Closes #21 - File loading in order
IBBoard <dev@ibboard.co.uk>
parents:
8
diff
changeset
|
310 } |
0770e5cbba7c
Closes #21 - File loading in order
IBBoard <dev@ibboard.co.uk>
parents:
8
diff
changeset
|
311 |
0770e5cbba7c
Closes #21 - File loading in order
IBBoard <dev@ibboard.co.uk>
parents:
8
diff
changeset
|
312 return fails; |
0770e5cbba7c
Closes #21 - File loading in order
IBBoard <dev@ibboard.co.uk>
parents:
8
diff
changeset
|
313 } |
0770e5cbba7c
Closes #21 - File loading in order
IBBoard <dev@ibboard.co.uk>
parents:
8
diff
changeset
|
314 |
0770e5cbba7c
Closes #21 - File loading in order
IBBoard <dev@ibboard.co.uk>
parents:
8
diff
changeset
|
315 private List<FileLoadFailure> LoadRaces(Dictionary<FileInfo, IWarFoundryFactory> raceFiles) |
0770e5cbba7c
Closes #21 - File loading in order
IBBoard <dev@ibboard.co.uk>
parents:
8
diff
changeset
|
316 { |
0770e5cbba7c
Closes #21 - File loading in order
IBBoard <dev@ibboard.co.uk>
parents:
8
diff
changeset
|
317 List<FileLoadFailure> fails = new List<FileLoadFailure>(); |
0770e5cbba7c
Closes #21 - File loading in order
IBBoard <dev@ibboard.co.uk>
parents:
8
diff
changeset
|
318 |
0770e5cbba7c
Closes #21 - File loading in order
IBBoard <dev@ibboard.co.uk>
parents:
8
diff
changeset
|
319 foreach (FileInfo file in raceFiles.Keys) |
0770e5cbba7c
Closes #21 - File loading in order
IBBoard <dev@ibboard.co.uk>
parents:
8
diff
changeset
|
320 { |
23
f9846f896df3
Re #32 - Migrate WarFoundry files to using Schemas
IBBoard <dev@ibboard.co.uk>
parents:
20
diff
changeset
|
321 FileLoadFailure failure = null; |
f9846f896df3
Re #32 - Migrate WarFoundry files to using Schemas
IBBoard <dev@ibboard.co.uk>
parents:
20
diff
changeset
|
322 |
14
0770e5cbba7c
Closes #21 - File loading in order
IBBoard <dev@ibboard.co.uk>
parents:
8
diff
changeset
|
323 try |
0770e5cbba7c
Closes #21 - File loading in order
IBBoard <dev@ibboard.co.uk>
parents:
8
diff
changeset
|
324 { |
0770e5cbba7c
Closes #21 - File loading in order
IBBoard <dev@ibboard.co.uk>
parents:
8
diff
changeset
|
325 bool loaded = LoadObject(file, raceFiles[file]); |
0770e5cbba7c
Closes #21 - File loading in order
IBBoard <dev@ibboard.co.uk>
parents:
8
diff
changeset
|
326 |
0770e5cbba7c
Closes #21 - File loading in order
IBBoard <dev@ibboard.co.uk>
parents:
8
diff
changeset
|
327 if (!loaded) |
0770e5cbba7c
Closes #21 - File loading in order
IBBoard <dev@ibboard.co.uk>
parents:
8
diff
changeset
|
328 { |
23
f9846f896df3
Re #32 - Migrate WarFoundry files to using Schemas
IBBoard <dev@ibboard.co.uk>
parents:
20
diff
changeset
|
329 failure = new FileLoadFailure(file, "FileLoadFailed", "Failed to load {0} as Race using {1}"); |
14
0770e5cbba7c
Closes #21 - File loading in order
IBBoard <dev@ibboard.co.uk>
parents:
8
diff
changeset
|
330 } |
0770e5cbba7c
Closes #21 - File loading in order
IBBoard <dev@ibboard.co.uk>
parents:
8
diff
changeset
|
331 } |
0770e5cbba7c
Closes #21 - File loading in order
IBBoard <dev@ibboard.co.uk>
parents:
8
diff
changeset
|
332 catch (Exception ex) |
0770e5cbba7c
Closes #21 - File loading in order
IBBoard <dev@ibboard.co.uk>
parents:
8
diff
changeset
|
333 { |
30
92cf25b0493b
Re #32 - Migrate to using Schemas
IBBoard <dev@ibboard.co.uk>
parents:
27
diff
changeset
|
334 failure = new FileLoadFailure(file, null, ex.Message, null, ex); |
23
f9846f896df3
Re #32 - Migrate WarFoundry files to using Schemas
IBBoard <dev@ibboard.co.uk>
parents:
20
diff
changeset
|
335 } |
f9846f896df3
Re #32 - Migrate WarFoundry files to using Schemas
IBBoard <dev@ibboard.co.uk>
parents:
20
diff
changeset
|
336 |
f9846f896df3
Re #32 - Migrate WarFoundry files to using Schemas
IBBoard <dev@ibboard.co.uk>
parents:
20
diff
changeset
|
337 if (failure!=null) |
f9846f896df3
Re #32 - Migrate WarFoundry files to using Schemas
IBBoard <dev@ibboard.co.uk>
parents:
20
diff
changeset
|
338 { |
f9846f896df3
Re #32 - Migrate WarFoundry files to using Schemas
IBBoard <dev@ibboard.co.uk>
parents:
20
diff
changeset
|
339 fails.Add(failure); |
30
92cf25b0493b
Re #32 - Migrate to using Schemas
IBBoard <dev@ibboard.co.uk>
parents:
27
diff
changeset
|
340 LogNotifier.Warn(GetType(), failure.Message, failure.Exception); |
14
0770e5cbba7c
Closes #21 - File loading in order
IBBoard <dev@ibboard.co.uk>
parents:
8
diff
changeset
|
341 } |
0770e5cbba7c
Closes #21 - File loading in order
IBBoard <dev@ibboard.co.uk>
parents:
8
diff
changeset
|
342 } |
0770e5cbba7c
Closes #21 - File loading in order
IBBoard <dev@ibboard.co.uk>
parents:
8
diff
changeset
|
343 |
0770e5cbba7c
Closes #21 - File loading in order
IBBoard <dev@ibboard.co.uk>
parents:
8
diff
changeset
|
344 return fails; |
0770e5cbba7c
Closes #21 - File loading in order
IBBoard <dev@ibboard.co.uk>
parents:
8
diff
changeset
|
345 } |
0770e5cbba7c
Closes #21 - File loading in order
IBBoard <dev@ibboard.co.uk>
parents:
8
diff
changeset
|
346 |
0770e5cbba7c
Closes #21 - File loading in order
IBBoard <dev@ibboard.co.uk>
parents:
8
diff
changeset
|
347 private bool LoadObject(FileInfo file, IWarFoundryFactory factory) |
0770e5cbba7c
Closes #21 - File loading in order
IBBoard <dev@ibboard.co.uk>
parents:
8
diff
changeset
|
348 { |
0770e5cbba7c
Closes #21 - File loading in order
IBBoard <dev@ibboard.co.uk>
parents:
8
diff
changeset
|
349 bool loaded = false; |
0770e5cbba7c
Closes #21 - File loading in order
IBBoard <dev@ibboard.co.uk>
parents:
8
diff
changeset
|
350 |
0770e5cbba7c
Closes #21 - File loading in order
IBBoard <dev@ibboard.co.uk>
parents:
8
diff
changeset
|
351 LogNotifier.DebugFormat(GetType(), "Loading {0} using {1}", file.FullName, factory.GetType().Name); |
0770e5cbba7c
Closes #21 - File loading in order
IBBoard <dev@ibboard.co.uk>
parents:
8
diff
changeset
|
352 ICollection<IWarFoundryObject> objects = factory.CreateObjectsFromFile(file); |
0770e5cbba7c
Closes #21 - File loading in order
IBBoard <dev@ibboard.co.uk>
parents:
8
diff
changeset
|
353 |
0770e5cbba7c
Closes #21 - File loading in order
IBBoard <dev@ibboard.co.uk>
parents:
8
diff
changeset
|
354 if (objects.Count > 0) |
0770e5cbba7c
Closes #21 - File loading in order
IBBoard <dev@ibboard.co.uk>
parents:
8
diff
changeset
|
355 { |
0770e5cbba7c
Closes #21 - File loading in order
IBBoard <dev@ibboard.co.uk>
parents:
8
diff
changeset
|
356 AddLoadedObjects(objects, factory); |
0770e5cbba7c
Closes #21 - File loading in order
IBBoard <dev@ibboard.co.uk>
parents:
8
diff
changeset
|
357 loaded = true; |
0770e5cbba7c
Closes #21 - File loading in order
IBBoard <dev@ibboard.co.uk>
parents:
8
diff
changeset
|
358 } |
0770e5cbba7c
Closes #21 - File loading in order
IBBoard <dev@ibboard.co.uk>
parents:
8
diff
changeset
|
359 |
0770e5cbba7c
Closes #21 - File loading in order
IBBoard <dev@ibboard.co.uk>
parents:
8
diff
changeset
|
360 return loaded; |
0770e5cbba7c
Closes #21 - File loading in order
IBBoard <dev@ibboard.co.uk>
parents:
8
diff
changeset
|
361 } |
0770e5cbba7c
Closes #21 - File loading in order
IBBoard <dev@ibboard.co.uk>
parents:
8
diff
changeset
|
362 |
0 | 363 |
364 /// <summary> | |
365 /// Loads a single file through the registered WarFoundryFactories, if a factory exists that supports the file format. | |
366 /// </summary> | |
367 /// <param name="file"> | |
368 /// A <see cref="FileInfo"/> for the file to attempt to load | |
369 /// </param> | |
14
0770e5cbba7c
Closes #21 - File loading in order
IBBoard <dev@ibboard.co.uk>
parents:
8
diff
changeset
|
370 /// <returns> |
0770e5cbba7c
Closes #21 - File loading in order
IBBoard <dev@ibboard.co.uk>
parents:
8
diff
changeset
|
371 /// An ICollection of IWarFoundryObjects loaded from <code>file</code> |
0770e5cbba7c
Closes #21 - File loading in order
IBBoard <dev@ibboard.co.uk>
parents:
8
diff
changeset
|
372 /// </returns> |
0770e5cbba7c
Closes #21 - File loading in order
IBBoard <dev@ibboard.co.uk>
parents:
8
diff
changeset
|
373 public ICollection<IWarFoundryObject> LoadFile(FileInfo file) |
0 | 374 { |
19
57451981545c
Re #10 and re #11 - Refactor code and document code
IBBoard <dev@ibboard.co.uk>
parents:
16
diff
changeset
|
375 ICollection<IWarFoundryObject> objs = null; |
14
0770e5cbba7c
Closes #21 - File loading in order
IBBoard <dev@ibboard.co.uk>
parents:
8
diff
changeset
|
376 IWarFoundryFactory loadFactory = null; |
0 | 377 |
19
57451981545c
Re #10 and re #11 - Refactor code and document code
IBBoard <dev@ibboard.co.uk>
parents:
16
diff
changeset
|
378 try |
57451981545c
Re #10 and re #11 - Refactor code and document code
IBBoard <dev@ibboard.co.uk>
parents:
16
diff
changeset
|
379 { |
57451981545c
Re #10 and re #11 - Refactor code and document code
IBBoard <dev@ibboard.co.uk>
parents:
16
diff
changeset
|
380 objs = LoadFileWithNonNativeFactories(file, out loadFactory); |
57451981545c
Re #10 and re #11 - Refactor code and document code
IBBoard <dev@ibboard.co.uk>
parents:
16
diff
changeset
|
381 |
57451981545c
Re #10 and re #11 - Refactor code and document code
IBBoard <dev@ibboard.co.uk>
parents:
16
diff
changeset
|
382 if (objs == null) |
57451981545c
Re #10 and re #11 - Refactor code and document code
IBBoard <dev@ibboard.co.uk>
parents:
16
diff
changeset
|
383 { |
57451981545c
Re #10 and re #11 - Refactor code and document code
IBBoard <dev@ibboard.co.uk>
parents:
16
diff
changeset
|
384 objs = LoadFileWithNativeFactories(file, out loadFactory); |
57451981545c
Re #10 and re #11 - Refactor code and document code
IBBoard <dev@ibboard.co.uk>
parents:
16
diff
changeset
|
385 } |
57451981545c
Re #10 and re #11 - Refactor code and document code
IBBoard <dev@ibboard.co.uk>
parents:
16
diff
changeset
|
386 } |
57451981545c
Re #10 and re #11 - Refactor code and document code
IBBoard <dev@ibboard.co.uk>
parents:
16
diff
changeset
|
387 catch (InvalidFileException ex) |
57451981545c
Re #10 and re #11 - Refactor code and document code
IBBoard <dev@ibboard.co.uk>
parents:
16
diff
changeset
|
388 { |
20
b7c93a5821cd
* Remove unnecessary project dependency
IBBoard <dev@ibboard.co.uk>
parents:
19
diff
changeset
|
389 LogNotifier.Error(GetType(), file.FullName+" failed to load", ex); |
19
57451981545c
Re #10 and re #11 - Refactor code and document code
IBBoard <dev@ibboard.co.uk>
parents:
16
diff
changeset
|
390 } |
57451981545c
Re #10 and re #11 - Refactor code and document code
IBBoard <dev@ibboard.co.uk>
parents:
16
diff
changeset
|
391 |
57451981545c
Re #10 and re #11 - Refactor code and document code
IBBoard <dev@ibboard.co.uk>
parents:
16
diff
changeset
|
392 if (objs!=null) |
57451981545c
Re #10 and re #11 - Refactor code and document code
IBBoard <dev@ibboard.co.uk>
parents:
16
diff
changeset
|
393 { |
57451981545c
Re #10 and re #11 - Refactor code and document code
IBBoard <dev@ibboard.co.uk>
parents:
16
diff
changeset
|
394 AddLoadedObjects(objs, loadFactory); |
57451981545c
Re #10 and re #11 - Refactor code and document code
IBBoard <dev@ibboard.co.uk>
parents:
16
diff
changeset
|
395 } |
57451981545c
Re #10 and re #11 - Refactor code and document code
IBBoard <dev@ibboard.co.uk>
parents:
16
diff
changeset
|
396 else |
57451981545c
Re #10 and re #11 - Refactor code and document code
IBBoard <dev@ibboard.co.uk>
parents:
16
diff
changeset
|
397 { |
57451981545c
Re #10 and re #11 - Refactor code and document code
IBBoard <dev@ibboard.co.uk>
parents:
16
diff
changeset
|
398 objs = new List<IWarFoundryObject>(); |
57451981545c
Re #10 and re #11 - Refactor code and document code
IBBoard <dev@ibboard.co.uk>
parents:
16
diff
changeset
|
399 } |
57451981545c
Re #10 and re #11 - Refactor code and document code
IBBoard <dev@ibboard.co.uk>
parents:
16
diff
changeset
|
400 |
57451981545c
Re #10 and re #11 - Refactor code and document code
IBBoard <dev@ibboard.co.uk>
parents:
16
diff
changeset
|
401 return objs; |
57451981545c
Re #10 and re #11 - Refactor code and document code
IBBoard <dev@ibboard.co.uk>
parents:
16
diff
changeset
|
402 } |
57451981545c
Re #10 and re #11 - Refactor code and document code
IBBoard <dev@ibboard.co.uk>
parents:
16
diff
changeset
|
403 |
57451981545c
Re #10 and re #11 - Refactor code and document code
IBBoard <dev@ibboard.co.uk>
parents:
16
diff
changeset
|
404 private ICollection<IWarFoundryObject> LoadFileWithNonNativeFactories(FileInfo file, out IWarFoundryFactory loadFactory) |
57451981545c
Re #10 and re #11 - Refactor code and document code
IBBoard <dev@ibboard.co.uk>
parents:
16
diff
changeset
|
405 { |
57451981545c
Re #10 and re #11 - Refactor code and document code
IBBoard <dev@ibboard.co.uk>
parents:
16
diff
changeset
|
406 ICollection<IWarFoundryObject> objs = null; |
57451981545c
Re #10 and re #11 - Refactor code and document code
IBBoard <dev@ibboard.co.uk>
parents:
16
diff
changeset
|
407 loadFactory = null; |
57451981545c
Re #10 and re #11 - Refactor code and document code
IBBoard <dev@ibboard.co.uk>
parents:
16
diff
changeset
|
408 |
14
0770e5cbba7c
Closes #21 - File loading in order
IBBoard <dev@ibboard.co.uk>
parents:
8
diff
changeset
|
409 if (nonNativeFactories.Count > 0) |
0 | 410 { |
14
0770e5cbba7c
Closes #21 - File loading in order
IBBoard <dev@ibboard.co.uk>
parents:
8
diff
changeset
|
411 LogNotifier.Debug(GetType(), "Attempting to load "+file.FullName+" as a non-native file"); |
0 | 412 |
14
0770e5cbba7c
Closes #21 - File loading in order
IBBoard <dev@ibboard.co.uk>
parents:
8
diff
changeset
|
413 foreach (INonNativeWarFoundryFactory factory in nonNativeFactories) |
0 | 414 { |
14
0770e5cbba7c
Closes #21 - File loading in order
IBBoard <dev@ibboard.co.uk>
parents:
8
diff
changeset
|
415 bool canLoad = factory.CanHandleFileFormat(file); |
0770e5cbba7c
Closes #21 - File loading in order
IBBoard <dev@ibboard.co.uk>
parents:
8
diff
changeset
|
416 LogNotifier.Debug(GetType(), "Load using "+factory.GetType().FullName+"? " + (canLoad ? "yes" : "no")); |
0 | 417 |
14
0770e5cbba7c
Closes #21 - File loading in order
IBBoard <dev@ibboard.co.uk>
parents:
8
diff
changeset
|
418 if (canLoad) |
0 | 419 { |
14
0770e5cbba7c
Closes #21 - File loading in order
IBBoard <dev@ibboard.co.uk>
parents:
8
diff
changeset
|
420 objs = factory.CreateObjectsFromFile(file); |
0 | 421 |
14
0770e5cbba7c
Closes #21 - File loading in order
IBBoard <dev@ibboard.co.uk>
parents:
8
diff
changeset
|
422 if (objs!=null) |
0 | 423 { |
14
0770e5cbba7c
Closes #21 - File loading in order
IBBoard <dev@ibboard.co.uk>
parents:
8
diff
changeset
|
424 loadFactory = factory; |
0770e5cbba7c
Closes #21 - File loading in order
IBBoard <dev@ibboard.co.uk>
parents:
8
diff
changeset
|
425 break; |
0770e5cbba7c
Closes #21 - File loading in order
IBBoard <dev@ibboard.co.uk>
parents:
8
diff
changeset
|
426 } |
0770e5cbba7c
Closes #21 - File loading in order
IBBoard <dev@ibboard.co.uk>
parents:
8
diff
changeset
|
427 } |
0 | 428 } |
14
0770e5cbba7c
Closes #21 - File loading in order
IBBoard <dev@ibboard.co.uk>
parents:
8
diff
changeset
|
429 } |
0770e5cbba7c
Closes #21 - File loading in order
IBBoard <dev@ibboard.co.uk>
parents:
8
diff
changeset
|
430 |
19
57451981545c
Re #10 and re #11 - Refactor code and document code
IBBoard <dev@ibboard.co.uk>
parents:
16
diff
changeset
|
431 return objs; |
57451981545c
Re #10 and re #11 - Refactor code and document code
IBBoard <dev@ibboard.co.uk>
parents:
16
diff
changeset
|
432 } |
57451981545c
Re #10 and re #11 - Refactor code and document code
IBBoard <dev@ibboard.co.uk>
parents:
16
diff
changeset
|
433 |
57451981545c
Re #10 and re #11 - Refactor code and document code
IBBoard <dev@ibboard.co.uk>
parents:
16
diff
changeset
|
434 private ICollection<IWarFoundryObject> LoadFileWithNativeFactories(FileInfo file, out IWarFoundryFactory loadFactory) |
57451981545c
Re #10 and re #11 - Refactor code and document code
IBBoard <dev@ibboard.co.uk>
parents:
16
diff
changeset
|
435 { |
57451981545c
Re #10 and re #11 - Refactor code and document code
IBBoard <dev@ibboard.co.uk>
parents:
16
diff
changeset
|
436 ICollection<IWarFoundryObject> objs = null; |
57451981545c
Re #10 and re #11 - Refactor code and document code
IBBoard <dev@ibboard.co.uk>
parents:
16
diff
changeset
|
437 loadFactory = null; |
57451981545c
Re #10 and re #11 - Refactor code and document code
IBBoard <dev@ibboard.co.uk>
parents:
16
diff
changeset
|
438 |
57451981545c
Re #10 and re #11 - Refactor code and document code
IBBoard <dev@ibboard.co.uk>
parents:
16
diff
changeset
|
439 if (factories.Count > 0) |
14
0770e5cbba7c
Closes #21 - File loading in order
IBBoard <dev@ibboard.co.uk>
parents:
8
diff
changeset
|
440 { |
0770e5cbba7c
Closes #21 - File loading in order
IBBoard <dev@ibboard.co.uk>
parents:
8
diff
changeset
|
441 LogNotifier.Debug(GetType(), "Attempting to load "+file.FullName+" as native file"); |
19
57451981545c
Re #10 and re #11 - Refactor code and document code
IBBoard <dev@ibboard.co.uk>
parents:
16
diff
changeset
|
442 |
14
0770e5cbba7c
Closes #21 - File loading in order
IBBoard <dev@ibboard.co.uk>
parents:
8
diff
changeset
|
443 foreach (INativeWarFoundryFactory factory in factories) |
0 | 444 { |
14
0770e5cbba7c
Closes #21 - File loading in order
IBBoard <dev@ibboard.co.uk>
parents:
8
diff
changeset
|
445 if (factory.CanHandleFileFormat(file)) |
0 | 446 { |
14
0770e5cbba7c
Closes #21 - File loading in order
IBBoard <dev@ibboard.co.uk>
parents:
8
diff
changeset
|
447 objs = factory.CreateObjectsFromFile(file); |
0770e5cbba7c
Closes #21 - File loading in order
IBBoard <dev@ibboard.co.uk>
parents:
8
diff
changeset
|
448 |
0770e5cbba7c
Closes #21 - File loading in order
IBBoard <dev@ibboard.co.uk>
parents:
8
diff
changeset
|
449 if (objs!=null) |
0 | 450 { |
14
0770e5cbba7c
Closes #21 - File loading in order
IBBoard <dev@ibboard.co.uk>
parents:
8
diff
changeset
|
451 loadFactory = factory; |
0770e5cbba7c
Closes #21 - File loading in order
IBBoard <dev@ibboard.co.uk>
parents:
8
diff
changeset
|
452 break; |
0 | 453 } |
454 } | |
455 } | |
14
0770e5cbba7c
Closes #21 - File loading in order
IBBoard <dev@ibboard.co.uk>
parents:
8
diff
changeset
|
456 } |
19
57451981545c
Re #10 and re #11 - Refactor code and document code
IBBoard <dev@ibboard.co.uk>
parents:
16
diff
changeset
|
457 |
14
0770e5cbba7c
Closes #21 - File loading in order
IBBoard <dev@ibboard.co.uk>
parents:
8
diff
changeset
|
458 return objs; |
0 | 459 } |
460 | |
461 private void AddLoadedObjects(ICollection<IWarFoundryObject> loadedObjs, IWarFoundryFactory factory) | |
462 { | |
463 SimpleSet<IWarFoundryObject> objs; | |
464 loadedObjects.TryGetValue(factory, out objs); | |
465 | |
466 if (objs == null) | |
467 { | |
468 objs = new SimpleSet<IWarFoundryObject>(); | |
469 loadedObjects.Add(factory, objs); | |
470 } | |
471 | |
472 objs.AddRange(loadedObjs); | |
14
0770e5cbba7c
Closes #21 - File loading in order
IBBoard <dev@ibboard.co.uk>
parents:
8
diff
changeset
|
473 StoreObjects(loadedObjs); |
0 | 474 } |
14
0770e5cbba7c
Closes #21 - File loading in order
IBBoard <dev@ibboard.co.uk>
parents:
8
diff
changeset
|
475 |
0770e5cbba7c
Closes #21 - File loading in order
IBBoard <dev@ibboard.co.uk>
parents:
8
diff
changeset
|
476 private void StoreObjects(ICollection<IWarFoundryObject> loadedObjects) |
0 | 477 { |
14
0770e5cbba7c
Closes #21 - File loading in order
IBBoard <dev@ibboard.co.uk>
parents:
8
diff
changeset
|
478 foreach (IWarFoundryObject loadedObject in loadedObjects) |
0 | 479 { |
14
0770e5cbba7c
Closes #21 - File loading in order
IBBoard <dev@ibboard.co.uk>
parents:
8
diff
changeset
|
480 if (loadedObject is GameSystem) |
0770e5cbba7c
Closes #21 - File loading in order
IBBoard <dev@ibboard.co.uk>
parents:
8
diff
changeset
|
481 { |
0770e5cbba7c
Closes #21 - File loading in order
IBBoard <dev@ibboard.co.uk>
parents:
8
diff
changeset
|
482 StoreGameSystem((GameSystem)loadedObject); |
0770e5cbba7c
Closes #21 - File loading in order
IBBoard <dev@ibboard.co.uk>
parents:
8
diff
changeset
|
483 } |
0770e5cbba7c
Closes #21 - File loading in order
IBBoard <dev@ibboard.co.uk>
parents:
8
diff
changeset
|
484 else if (loadedObject is Race) |
0770e5cbba7c
Closes #21 - File loading in order
IBBoard <dev@ibboard.co.uk>
parents:
8
diff
changeset
|
485 { |
0770e5cbba7c
Closes #21 - File loading in order
IBBoard <dev@ibboard.co.uk>
parents:
8
diff
changeset
|
486 StoreRace((Race)loadedObject); |
0770e5cbba7c
Closes #21 - File loading in order
IBBoard <dev@ibboard.co.uk>
parents:
8
diff
changeset
|
487 } |
0 | 488 } |
489 } | |
490 | |
491 protected void StoreGameSystem(GameSystem system) | |
492 { | |
493 string sysid = system.ID.ToLower(); | |
82 | 494 |
495 if (systemsTable.ContainsKey(sysid)) | |
0 | 496 { |
102
c85ea8988455
Re #123: Rollcall plugin won't re-add Game System on reload
IBBoard <dev@ibboard.co.uk>
parents:
82
diff
changeset
|
497 GameSystem existingSystem = systemsTable[sysid]; |
c85ea8988455
Re #123: Rollcall plugin won't re-add Game System on reload
IBBoard <dev@ibboard.co.uk>
parents:
82
diff
changeset
|
498 |
c85ea8988455
Re #123: Rollcall plugin won't re-add Game System on reload
IBBoard <dev@ibboard.co.uk>
parents:
82
diff
changeset
|
499 if (!system.Equals(existingSystem)) |
c85ea8988455
Re #123: Rollcall plugin won't re-add Game System on reload
IBBoard <dev@ibboard.co.uk>
parents:
82
diff
changeset
|
500 { |
c85ea8988455
Re #123: Rollcall plugin won't re-add Game System on reload
IBBoard <dev@ibboard.co.uk>
parents:
82
diff
changeset
|
501 //TODO: Raise an event to say we got a different duplicate |
c85ea8988455
Re #123: Rollcall plugin won't re-add Game System on reload
IBBoard <dev@ibboard.co.uk>
parents:
82
diff
changeset
|
502 //We can't just fail, because failing is for completely unhandled files, not for objects in a file |
c85ea8988455
Re #123: Rollcall plugin won't re-add Game System on reload
IBBoard <dev@ibboard.co.uk>
parents:
82
diff
changeset
|
503 } |
82 | 504 } |
505 else | |
506 { | |
507 systemsTable.Add(sysid, (GameSystem)system); | |
0 | 508 } |
509 } | |
510 | |
511 protected void StoreRace(Race race) | |
512 { | |
513 Dictionary<string, Dictionary<string, Race>> systemRaces; | |
514 | |
515 if (race.GameSystem == null) | |
516 { | |
517 throw new InvalidOperationException("Race cannot have null game system. Game system should be loaded before race."); | |
518 } | |
519 | |
520 string systemID = race.GameSystem.ID.ToLower(); | |
521 racesTable.TryGetValue(systemID, out systemRaces); | |
522 | |
523 if (systemRaces==null) | |
524 { | |
525 systemRaces = new Dictionary<string,Dictionary<string,Race>>(); | |
526 racesTable.Add(systemID, systemRaces); | |
527 } | |
528 | |
529 Dictionary<string, Race> subRaces; | |
530 systemRaces.TryGetValue(race.ID.ToLower(), out subRaces); | |
531 | |
532 if (subRaces==null) | |
533 { | |
534 subRaces = new Dictionary<string,Race>(); | |
535 systemRaces.Add(race.ID.ToLower(), subRaces); | |
536 } | |
102
c85ea8988455
Re #123: Rollcall plugin won't re-add Game System on reload
IBBoard <dev@ibboard.co.uk>
parents:
82
diff
changeset
|
537 |
c85ea8988455
Re #123: Rollcall plugin won't re-add Game System on reload
IBBoard <dev@ibboard.co.uk>
parents:
82
diff
changeset
|
538 string subID = race.SubID.ToLower(); |
0 | 539 |
102
c85ea8988455
Re #123: Rollcall plugin won't re-add Game System on reload
IBBoard <dev@ibboard.co.uk>
parents:
82
diff
changeset
|
540 if (subRaces.ContainsKey(subID)) |
0 | 541 { |
102
c85ea8988455
Re #123: Rollcall plugin won't re-add Game System on reload
IBBoard <dev@ibboard.co.uk>
parents:
82
diff
changeset
|
542 Race existingRace = subRaces[subID]; |
c85ea8988455
Re #123: Rollcall plugin won't re-add Game System on reload
IBBoard <dev@ibboard.co.uk>
parents:
82
diff
changeset
|
543 |
c85ea8988455
Re #123: Rollcall plugin won't re-add Game System on reload
IBBoard <dev@ibboard.co.uk>
parents:
82
diff
changeset
|
544 if (!race.Equals(existingRace)) |
c85ea8988455
Re #123: Rollcall plugin won't re-add Game System on reload
IBBoard <dev@ibboard.co.uk>
parents:
82
diff
changeset
|
545 { |
c85ea8988455
Re #123: Rollcall plugin won't re-add Game System on reload
IBBoard <dev@ibboard.co.uk>
parents:
82
diff
changeset
|
546 //TODO: Raise an event to say we got a different duplicate |
c85ea8988455
Re #123: Rollcall plugin won't re-add Game System on reload
IBBoard <dev@ibboard.co.uk>
parents:
82
diff
changeset
|
547 //We can't just fail, because failing is for completely unhandled files, not for objects in a file |
c85ea8988455
Re #123: Rollcall plugin won't re-add Game System on reload
IBBoard <dev@ibboard.co.uk>
parents:
82
diff
changeset
|
548 } |
0 | 549 } |
550 else | |
551 { | |
552 subRaces.Add(race.SubID.ToLower(), race); | |
553 } | |
554 } | |
555 | |
556 /// <summary> | |
557 /// Gets all <see cref="GameSystem"/>s that are currently available, determined by those that can be loaded with the current <see cref="IWarFoundryFactory"/>s. | |
558 /// </summary> | |
559 /// <returns> | |
560 /// An array of <see cref="GameSystem"/>s that are currently available. | |
561 /// </returns> | |
562 public GameSystem[] GetGameSystems() | |
82 | 563 { |
564 if (systemsTable==null) | |
565 { | |
566 LoadFiles(); | |
0 | 567 } |
568 | |
14
0770e5cbba7c
Closes #21 - File loading in order
IBBoard <dev@ibboard.co.uk>
parents:
8
diff
changeset
|
569 return DictionaryUtils.ToArray<string, GameSystem>(systemsTable); |
82 | 570 } |
0 | 571 |
572 /// <summary> | |
573 /// Gets a single <see cref="GameSystem"/> with a given ID. | |
574 /// </summary> | |
575 /// <param name="systemID"> | |
576 /// The ID of the <see cref="GameSystem"/> to get, as a <see cref="System.String"/>. | |
577 /// </param> | |
578 /// <returns> | |
579 /// The <see cref="GameSystem"/> with the given ID, or <code>null</code> if one doesn't exist. | |
82 | 580 /// </returns> |
581 public GameSystem GetGameSystem(string systemID) | |
582 { | |
583 if (systemsTable==null) | |
584 { | |
585 LoadFiles(); | |
0 | 586 } |
587 | |
588 GameSystem system; | |
82 | 589 systemsTable.TryGetValue(systemID.ToLower(), out system); |
590 return system; | |
226
c931684f9024
Re #234: Invalid data file doesn't stop load
IBBoard <dev@ibboard.co.uk>
parents:
144
diff
changeset
|
591 } |
c931684f9024
Re #234: Invalid data file doesn't stop load
IBBoard <dev@ibboard.co.uk>
parents:
144
diff
changeset
|
592 |
c931684f9024
Re #234: Invalid data file doesn't stop load
IBBoard <dev@ibboard.co.uk>
parents:
144
diff
changeset
|
593 /// <summary> |
c931684f9024
Re #234: Invalid data file doesn't stop load
IBBoard <dev@ibboard.co.uk>
parents:
144
diff
changeset
|
594 /// Removes a loaded <see cref="GameSystem"/>. Used when a GameSystem fails to complete loading |
c931684f9024
Re #234: Invalid data file doesn't stop load
IBBoard <dev@ibboard.co.uk>
parents:
144
diff
changeset
|
595 /// </summary> |
c931684f9024
Re #234: Invalid data file doesn't stop load
IBBoard <dev@ibboard.co.uk>
parents:
144
diff
changeset
|
596 /// <param name="system">The GameSystem to remove</param> |
c931684f9024
Re #234: Invalid data file doesn't stop load
IBBoard <dev@ibboard.co.uk>
parents:
144
diff
changeset
|
597 internal void RemoveGameSystem(GameSystem system) |
c931684f9024
Re #234: Invalid data file doesn't stop load
IBBoard <dev@ibboard.co.uk>
parents:
144
diff
changeset
|
598 { |
c931684f9024
Re #234: Invalid data file doesn't stop load
IBBoard <dev@ibboard.co.uk>
parents:
144
diff
changeset
|
599 systemsTable.Remove(system.ID.ToLower()); |
82 | 600 } |
0 | 601 |
602 /// <summary> | |
603 /// Gets an array of the races for the specified <see cref="GameSystem"/>. | |
604 /// </summary> | |
605 /// <param name="system"> | |
606 /// The <see cref="GameSystem"/> to get the available races for. | |
607 /// </param> | |
608 /// <returns> | |
609 /// An array of <see cref="Race"/>s for the <see cref="GameSystem"/> | |
82 | 610 /// </returns> |
611 public Race[] GetRaces(GameSystem system) | |
612 { | |
613 return GetRaces(system.ID); | |
614 } | |
0 | 615 |
616 /// <summary> | |
617 /// Gets an array of the races for a game system by ID. | |
618 /// </summary> | |
619 /// <param name="systemID"> | |
620 /// The <see cref="System.String"/> ID of the game system to get races for | |
621 /// </param> | |
622 /// <returns> | |
623 /// An array of <see cref="Race"/>s for the specified game system | |
82 | 624 /// </returns> |
625 public Race[] GetRaces(string systemID) | |
626 { | |
627 if (racesTable==null) | |
628 { | |
629 LoadFiles(); | |
0 | 630 } |
631 | |
82 | 632 systemID = systemID.ToLower(); |
0 | 633 Dictionary<string, Dictionary<string, Race>> system; |
82 | 634 racesTable.TryGetValue(systemID, out system); |
635 | |
636 if (system==null) | |
637 { | |
638 return new Race[0]; | |
639 } | |
640 | |
641 int count = 0; | |
642 | |
643 foreach (Dictionary<string, Race> racesDict in system.Values) | |
644 { | |
645 count+= racesDict.Count; | |
646 } | |
647 | |
648 Race[] races = new Race[count]; | |
649 int i = 0; | |
650 | |
651 foreach (string raceID in system.Keys) | |
652 { | |
653 foreach (string raceSubId in system[raceID].Keys) | |
654 { | |
655 races[i++] = GetRace(systemID, raceID, raceSubId); | |
656 } | |
657 } | |
658 | |
659 return races; | |
660 } | |
0 | 661 |
662 /// <summary> | |
663 /// Gets a single race for a given <see cref="GameSystem"/> by ID of the race. | |
664 /// </summary> | |
665 /// <param name="system"> | |
666 /// The <see cref="GameSystem"/> that the race is part of. | |
667 /// </param> | |
668 /// <param name="raceID"> | |
669 /// A <see cref="System.String"/> ID for the race to load. | |
670 /// </param> | |
671 /// <returns> | |
672 /// A <see cref="Race"/> with the specified ID from the <see cref="GameSystem"/>, or <code>null</code> if one doesn't exist. | |
82 | 673 /// </returns> |
674 public Race GetRace(GameSystem system, string raceID) | |
675 { | |
676 return GetRace(system.ID, raceID); | |
677 } | |
0 | 678 |
679 /// <summary> | |
680 /// Gets a single race for a given game system by ID of the game system and race. | |
681 /// </summary> | |
682 /// <param name="systemID"> | |
683 /// The <see cref="System.String"/> ID of the game system that the race is part of. | |
684 /// </param> | |
685 /// <param name="raceID"> | |
686 /// The <see cref="System.String"/> ID for the race to load. | |
687 /// </param> | |
688 /// <returns> | |
689 /// A <see cref="Race"/> with the specified ID from the game system with the specified ID, or <code>null</code> if there is no race or game system with those IDs. | |
82 | 690 /// </returns> |
691 public Race GetRace(string systemID, string raceID) | |
692 { | |
693 return GetRace(systemID, raceID, ""); | |
694 } | |
0 | 695 |
696 /// <summary> | |
697 /// Gets a single race for a given <see cref="GameSystem"/> by the race's ID and sub-race ID. | |
698 /// </summary> | |
699 /// <param name="system"> | |
700 /// The <see cref="GameSystem"/> that the race is part of. | |
701 /// </param> | |
702 /// <param name="raceID"> | |
703 /// The <see cref="System.String"/> ID for the race to load. | |
704 /// </param> | |
705 /// <param name="raceSubID"> | |
706 /// A <see cref="System.String"/> | |
707 /// </param> | |
708 /// <returns> | |
709 /// A <see cref="Race"/> | |
82 | 710 /// </returns> |
711 public Race GetRace(GameSystem system, string raceID, string raceSubID) | |
712 { | |
713 return GetRace(system.ID, raceID, raceSubID); | |
714 } | |
0 | 715 |
716 /// <summary> | |
717 /// Gets a single race for a given game system by the game system's ID and the race's ID and sub-race ID. | |
718 /// </summary> | |
719 /// <param name="systemID"> | |
720 /// The <see cref="System.String"/> ID of the game system that the race is part of. | |
721 /// </param> | |
722 /// <param name="raceID"> | |
723 /// The <see cref="System.String"/> ID for the race to load. | |
724 /// </param> | |
725 /// <param name="raceSubID"> | |
726 /// A <see cref="System.String"/> | |
727 /// </param> | |
728 /// <returns> | |
729 /// A <see cref="Race"/> | |
82 | 730 /// </returns> |
731 public Race GetRace(string systemID, string raceID, string raceSubID) | |
732 { | |
733 if (racesTable==null) | |
734 { | |
735 LoadFiles(); | |
0 | 736 } |
737 | |
738 Race race = null; | |
226
c931684f9024
Re #234: Invalid data file doesn't stop load
IBBoard <dev@ibboard.co.uk>
parents:
144
diff
changeset
|
739 |
c931684f9024
Re #234: Invalid data file doesn't stop load
IBBoard <dev@ibboard.co.uk>
parents:
144
diff
changeset
|
740 Dictionary<string, Race> subraces = GetRaceTable(systemID, raceID); |
c931684f9024
Re #234: Invalid data file doesn't stop load
IBBoard <dev@ibboard.co.uk>
parents:
144
diff
changeset
|
741 |
c931684f9024
Re #234: Invalid data file doesn't stop load
IBBoard <dev@ibboard.co.uk>
parents:
144
diff
changeset
|
742 if (subraces != null) |
c931684f9024
Re #234: Invalid data file doesn't stop load
IBBoard <dev@ibboard.co.uk>
parents:
144
diff
changeset
|
743 { |
c931684f9024
Re #234: Invalid data file doesn't stop load
IBBoard <dev@ibboard.co.uk>
parents:
144
diff
changeset
|
744 subraces.TryGetValue(raceSubID.ToLower(), out race); |
0 | 745 } |
746 | |
226
c931684f9024
Re #234: Invalid data file doesn't stop load
IBBoard <dev@ibboard.co.uk>
parents:
144
diff
changeset
|
747 return race; |
c931684f9024
Re #234: Invalid data file doesn't stop load
IBBoard <dev@ibboard.co.uk>
parents:
144
diff
changeset
|
748 } |
c931684f9024
Re #234: Invalid data file doesn't stop load
IBBoard <dev@ibboard.co.uk>
parents:
144
diff
changeset
|
749 |
c931684f9024
Re #234: Invalid data file doesn't stop load
IBBoard <dev@ibboard.co.uk>
parents:
144
diff
changeset
|
750 private Dictionary<string, Race> GetRaceTable(string systemID, string raceID) |
c931684f9024
Re #234: Invalid data file doesn't stop load
IBBoard <dev@ibboard.co.uk>
parents:
144
diff
changeset
|
751 { |
c931684f9024
Re #234: Invalid data file doesn't stop load
IBBoard <dev@ibboard.co.uk>
parents:
144
diff
changeset
|
752 Dictionary<string, Dictionary<string, Race>> races; |
c931684f9024
Re #234: Invalid data file doesn't stop load
IBBoard <dev@ibboard.co.uk>
parents:
144
diff
changeset
|
753 racesTable.TryGetValue(systemID.ToLower(), out races); |
c931684f9024
Re #234: Invalid data file doesn't stop load
IBBoard <dev@ibboard.co.uk>
parents:
144
diff
changeset
|
754 Dictionary<string, Race> subraces = null; |
c931684f9024
Re #234: Invalid data file doesn't stop load
IBBoard <dev@ibboard.co.uk>
parents:
144
diff
changeset
|
755 |
c931684f9024
Re #234: Invalid data file doesn't stop load
IBBoard <dev@ibboard.co.uk>
parents:
144
diff
changeset
|
756 if (races != null) |
c931684f9024
Re #234: Invalid data file doesn't stop load
IBBoard <dev@ibboard.co.uk>
parents:
144
diff
changeset
|
757 { |
c931684f9024
Re #234: Invalid data file doesn't stop load
IBBoard <dev@ibboard.co.uk>
parents:
144
diff
changeset
|
758 races.TryGetValue(raceID.ToLower(), out subraces); |
c931684f9024
Re #234: Invalid data file doesn't stop load
IBBoard <dev@ibboard.co.uk>
parents:
144
diff
changeset
|
759 } |
c931684f9024
Re #234: Invalid data file doesn't stop load
IBBoard <dev@ibboard.co.uk>
parents:
144
diff
changeset
|
760 |
c931684f9024
Re #234: Invalid data file doesn't stop load
IBBoard <dev@ibboard.co.uk>
parents:
144
diff
changeset
|
761 return subraces; |
c931684f9024
Re #234: Invalid data file doesn't stop load
IBBoard <dev@ibboard.co.uk>
parents:
144
diff
changeset
|
762 } |
c931684f9024
Re #234: Invalid data file doesn't stop load
IBBoard <dev@ibboard.co.uk>
parents:
144
diff
changeset
|
763 |
c931684f9024
Re #234: Invalid data file doesn't stop load
IBBoard <dev@ibboard.co.uk>
parents:
144
diff
changeset
|
764 internal void RemoveRace(Race race) |
c931684f9024
Re #234: Invalid data file doesn't stop load
IBBoard <dev@ibboard.co.uk>
parents:
144
diff
changeset
|
765 { |
c931684f9024
Re #234: Invalid data file doesn't stop load
IBBoard <dev@ibboard.co.uk>
parents:
144
diff
changeset
|
766 Dictionary<string, Race> subraces = GetRaceTable(race.GameSystem.ID, race.ID); |
c931684f9024
Re #234: Invalid data file doesn't stop load
IBBoard <dev@ibboard.co.uk>
parents:
144
diff
changeset
|
767 |
c931684f9024
Re #234: Invalid data file doesn't stop load
IBBoard <dev@ibboard.co.uk>
parents:
144
diff
changeset
|
768 if (subraces != null) |
c931684f9024
Re #234: Invalid data file doesn't stop load
IBBoard <dev@ibboard.co.uk>
parents:
144
diff
changeset
|
769 { |
c931684f9024
Re #234: Invalid data file doesn't stop load
IBBoard <dev@ibboard.co.uk>
parents:
144
diff
changeset
|
770 subraces.Remove(race.SubID.ToLower()); |
c931684f9024
Re #234: Invalid data file doesn't stop load
IBBoard <dev@ibboard.co.uk>
parents:
144
diff
changeset
|
771 } |
82 | 772 } |
0 | 773 |
774 /// <summary> | |
775 /// Gets the IDs of all of the game systems currently available. | |
776 /// </summary> | |
777 /// <returns> | |
778 /// An array of <see cref="System.String"/>s representing the IDs of the game systems. | |
82 | 779 /// </returns> |
780 public string[] GetGameSystemIDs() | |
781 { | |
782 if (systemsTable==null) | |
783 { | |
784 LoadFiles(); | |
785 } | |
786 | |
787 string[] keys = new string[systemsTable.Keys.Count]; | |
788 int i = 0; | |
789 | |
790 foreach (string key in systemsTable.Keys) | |
791 { | |
792 keys[i++] = key; | |
793 } | |
794 | |
795 return keys; | |
0 | 796 } |
797 | |
798 /// <summary> | |
799 /// Gets the IDs of all of the races of a specified game system. | |
800 /// </summary> | |
801 /// <param name="system"> | |
802 /// The <see cref="GameSystem"/> to get the available races for. | |
803 /// </param> | |
804 /// <returns> | |
805 /// An array of <see cref="System.String"/>s representing the IDs of the races of the specified game system. | |
806 /// </returns> | |
807 public string[] GetSystemRaceIDs(GameSystem system) | |
808 { | |
809 return GetSystemRaceIDs(system.ID); | |
82 | 810 } |
0 | 811 |
812 /// <summary> | |
813 /// Gets the IDs of all of the races of a specified game system. | |
814 /// </summary> | |
815 /// <param name="systemID"> | |
816 /// The <see cref="System.String"/> ID of the game system to get the available races for. | |
817 /// </param> | |
818 /// <returns> | |
819 /// An array of <see cref="System.String"/>s representing the IDs of the races of the specified game system. | |
82 | 820 /// </returns> |
821 public string[] GetSystemRaceIDs(string systemID) | |
822 { | |
823 if (racesTable == null) | |
824 { | |
825 LoadFiles(); | |
826 } | |
827 | |
828 Dictionary<string, Dictionary<string, Race>> races = racesTable[systemID.ToLower()]; | |
829 | |
830 if (races==null) | |
831 { | |
832 return new string[0]; | |
833 } | |
834 else | |
835 { | |
836 string[] keys = new string[races.Keys.Count]; | |
837 int i = 0; | |
838 | |
839 foreach (string key in races.Keys) | |
840 { | |
841 keys[i++] = key; | |
842 } | |
843 | |
844 return keys; | |
845 } | |
0 | 846 } |
111
b5ae022ce7b8
Re #54: Add army loading support
IBBoard <dev@ibboard.co.uk>
parents:
104
diff
changeset
|
847 |
b5ae022ce7b8
Re #54: Add army loading support
IBBoard <dev@ibboard.co.uk>
parents:
104
diff
changeset
|
848 public Army LoadArmy(FileInfo file) |
b5ae022ce7b8
Re #54: Add army loading support
IBBoard <dev@ibboard.co.uk>
parents:
104
diff
changeset
|
849 { |
112
863518044d38
Re #54: Add Army support to WarFoundryFactory
IBBoard <dev@ibboard.co.uk>
parents:
111
diff
changeset
|
850 IWarFoundryFactory factory = GetArmyLoadingFactoryForFile(file); |
111
b5ae022ce7b8
Re #54: Add army loading support
IBBoard <dev@ibboard.co.uk>
parents:
104
diff
changeset
|
851 Army loadedArmy = null; |
b5ae022ce7b8
Re #54: Add army loading support
IBBoard <dev@ibboard.co.uk>
parents:
104
diff
changeset
|
852 |
112
863518044d38
Re #54: Add Army support to WarFoundryFactory
IBBoard <dev@ibboard.co.uk>
parents:
111
diff
changeset
|
853 if (factory != null) |
111
b5ae022ce7b8
Re #54: Add army loading support
IBBoard <dev@ibboard.co.uk>
parents:
104
diff
changeset
|
854 { |
112
863518044d38
Re #54: Add Army support to WarFoundryFactory
IBBoard <dev@ibboard.co.uk>
parents:
111
diff
changeset
|
855 ICollection<IWarFoundryObject> objs = factory.CreateObjectsFromFile(file); |
863518044d38
Re #54: Add Army support to WarFoundryFactory
IBBoard <dev@ibboard.co.uk>
parents:
111
diff
changeset
|
856 |
863518044d38
Re #54: Add Army support to WarFoundryFactory
IBBoard <dev@ibboard.co.uk>
parents:
111
diff
changeset
|
857 if (objs.Count == 1) |
111
b5ae022ce7b8
Re #54: Add army loading support
IBBoard <dev@ibboard.co.uk>
parents:
104
diff
changeset
|
858 { |
112
863518044d38
Re #54: Add Army support to WarFoundryFactory
IBBoard <dev@ibboard.co.uk>
parents:
111
diff
changeset
|
859 foreach (IWarFoundryObject obj in objs) |
111
b5ae022ce7b8
Re #54: Add army loading support
IBBoard <dev@ibboard.co.uk>
parents:
104
diff
changeset
|
860 { |
112
863518044d38
Re #54: Add Army support to WarFoundryFactory
IBBoard <dev@ibboard.co.uk>
parents:
111
diff
changeset
|
861 if (obj is Army) |
863518044d38
Re #54: Add Army support to WarFoundryFactory
IBBoard <dev@ibboard.co.uk>
parents:
111
diff
changeset
|
862 { |
863518044d38
Re #54: Add Army support to WarFoundryFactory
IBBoard <dev@ibboard.co.uk>
parents:
111
diff
changeset
|
863 loadedArmy = (Army) obj; |
863518044d38
Re #54: Add Army support to WarFoundryFactory
IBBoard <dev@ibboard.co.uk>
parents:
111
diff
changeset
|
864 } |
111
b5ae022ce7b8
Re #54: Add army loading support
IBBoard <dev@ibboard.co.uk>
parents:
104
diff
changeset
|
865 } |
b5ae022ce7b8
Re #54: Add army loading support
IBBoard <dev@ibboard.co.uk>
parents:
104
diff
changeset
|
866 } |
b5ae022ce7b8
Re #54: Add army loading support
IBBoard <dev@ibboard.co.uk>
parents:
104
diff
changeset
|
867 } |
b5ae022ce7b8
Re #54: Add army loading support
IBBoard <dev@ibboard.co.uk>
parents:
104
diff
changeset
|
868 |
b5ae022ce7b8
Re #54: Add army loading support
IBBoard <dev@ibboard.co.uk>
parents:
104
diff
changeset
|
869 return loadedArmy; |
b5ae022ce7b8
Re #54: Add army loading support
IBBoard <dev@ibboard.co.uk>
parents:
104
diff
changeset
|
870 } |
b5ae022ce7b8
Re #54: Add army loading support
IBBoard <dev@ibboard.co.uk>
parents:
104
diff
changeset
|
871 |
b5ae022ce7b8
Re #54: Add army loading support
IBBoard <dev@ibboard.co.uk>
parents:
104
diff
changeset
|
872 private IWarFoundryFactory GetArmyLoadingFactoryForFile(FileInfo file) |
b5ae022ce7b8
Re #54: Add army loading support
IBBoard <dev@ibboard.co.uk>
parents:
104
diff
changeset
|
873 { |
b5ae022ce7b8
Re #54: Add army loading support
IBBoard <dev@ibboard.co.uk>
parents:
104
diff
changeset
|
874 IWarFoundryFactory loadingFactory = null; |
b5ae022ce7b8
Re #54: Add army loading support
IBBoard <dev@ibboard.co.uk>
parents:
104
diff
changeset
|
875 |
b5ae022ce7b8
Re #54: Add army loading support
IBBoard <dev@ibboard.co.uk>
parents:
104
diff
changeset
|
876 foreach (INonNativeWarFoundryFactory factory in nonNativeFactories) |
b5ae022ce7b8
Re #54: Add army loading support
IBBoard <dev@ibboard.co.uk>
parents:
104
diff
changeset
|
877 { |
b5ae022ce7b8
Re #54: Add army loading support
IBBoard <dev@ibboard.co.uk>
parents:
104
diff
changeset
|
878 if (factory.CanHandleFileAsArmy(file)) |
b5ae022ce7b8
Re #54: Add army loading support
IBBoard <dev@ibboard.co.uk>
parents:
104
diff
changeset
|
879 { |
b5ae022ce7b8
Re #54: Add army loading support
IBBoard <dev@ibboard.co.uk>
parents:
104
diff
changeset
|
880 loadingFactory = factory; |
b5ae022ce7b8
Re #54: Add army loading support
IBBoard <dev@ibboard.co.uk>
parents:
104
diff
changeset
|
881 break; |
b5ae022ce7b8
Re #54: Add army loading support
IBBoard <dev@ibboard.co.uk>
parents:
104
diff
changeset
|
882 } |
b5ae022ce7b8
Re #54: Add army loading support
IBBoard <dev@ibboard.co.uk>
parents:
104
diff
changeset
|
883 } |
b5ae022ce7b8
Re #54: Add army loading support
IBBoard <dev@ibboard.co.uk>
parents:
104
diff
changeset
|
884 |
b5ae022ce7b8
Re #54: Add army loading support
IBBoard <dev@ibboard.co.uk>
parents:
104
diff
changeset
|
885 if (loadingFactory == null) |
b5ae022ce7b8
Re #54: Add army loading support
IBBoard <dev@ibboard.co.uk>
parents:
104
diff
changeset
|
886 { |
b5ae022ce7b8
Re #54: Add army loading support
IBBoard <dev@ibboard.co.uk>
parents:
104
diff
changeset
|
887 foreach (INativeWarFoundryFactory factory in factories) |
b5ae022ce7b8
Re #54: Add army loading support
IBBoard <dev@ibboard.co.uk>
parents:
104
diff
changeset
|
888 { |
b5ae022ce7b8
Re #54: Add army loading support
IBBoard <dev@ibboard.co.uk>
parents:
104
diff
changeset
|
889 if (factory.CanHandleFileAsArmy(file)) |
b5ae022ce7b8
Re #54: Add army loading support
IBBoard <dev@ibboard.co.uk>
parents:
104
diff
changeset
|
890 { |
b5ae022ce7b8
Re #54: Add army loading support
IBBoard <dev@ibboard.co.uk>
parents:
104
diff
changeset
|
891 loadingFactory = factory; |
b5ae022ce7b8
Re #54: Add army loading support
IBBoard <dev@ibboard.co.uk>
parents:
104
diff
changeset
|
892 break; |
b5ae022ce7b8
Re #54: Add army loading support
IBBoard <dev@ibboard.co.uk>
parents:
104
diff
changeset
|
893 } |
b5ae022ce7b8
Re #54: Add army loading support
IBBoard <dev@ibboard.co.uk>
parents:
104
diff
changeset
|
894 } |
b5ae022ce7b8
Re #54: Add army loading support
IBBoard <dev@ibboard.co.uk>
parents:
104
diff
changeset
|
895 } |
b5ae022ce7b8
Re #54: Add army loading support
IBBoard <dev@ibboard.co.uk>
parents:
104
diff
changeset
|
896 |
b5ae022ce7b8
Re #54: Add army loading support
IBBoard <dev@ibboard.co.uk>
parents:
104
diff
changeset
|
897 return loadingFactory; |
226
c931684f9024
Re #234: Invalid data file doesn't stop load
IBBoard <dev@ibboard.co.uk>
parents:
144
diff
changeset
|
898 } |
0 | 899 } |
900 } |