annotate api/AbstractWarFoundryLoader.cs @ 268:d8e4eeb761c7

* Delete rogue Console.WriteLine statements from testing no-open-ticket
author IBBoard <dev@ibboard.co.uk>
date Sat, 12 Jun 2010 20:09:56 +0000
parents a36a0e9cc05d
children c035afa4a42c
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
233
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
1 // This file (AbstractWarFoundryLoader.cs) is a part of the IBBoard.WarFoundry.API project and is copyright 2009 IBBoard
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
2 //
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
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.
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
4
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
5 using System;
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
6 using System.Collections.Generic;
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
7 using System.IO;
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
8 using IBBoard.Collections;
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
9 using IBBoard.IO;
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
10 using IBBoard.Logging;
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
11 using IBBoard.WarFoundry.API.Factories;
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
12 using IBBoard.WarFoundry.API.Objects;
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
13
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
14 namespace IBBoard.WarFoundry.API
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
15 {
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
16 /// <summary>
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
17 /// The base abstract implementation of a WarFoundry file loader
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
18 /// </summary>
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
19 public abstract class AbstractWarFoundryLoader
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
20 {
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
21 private ICollection<DirectoryInfo> directories;
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
22 private ICollection<INativeWarFoundryFactory> factories;
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
23 private ICollection<INonNativeWarFoundryFactory> nonNativeFactories;
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
24 private Dictionary<IWarFoundryFactory, SimpleSet<IWarFoundryObject>> loadedObjects;
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
25 public delegate void FileLoadingCompleteDelegate(List<FileLoadFailure> failures);
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
26 public event MethodInvoker FileLoadingStarted;
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
27 public event FileLoadingCompleteDelegate FileLoadingFinished;
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
28
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
29 protected AbstractWarFoundryLoader()
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
30 {
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
31 directories = new List<DirectoryInfo>();
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
32 factories = new List<INativeWarFoundryFactory>();
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
33 nonNativeFactories = new List<INonNativeWarFoundryFactory>();
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
34 loadedObjects = new Dictionary<IWarFoundryFactory,SimpleSet<IWarFoundryObject>>();
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
35 }
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
36
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
37 /// <summary>
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
38 /// Adds a directory to the collection of directories that will be searched for WarFoundry data files.
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
39 /// </summary>
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
40 /// <param name="directory">
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
41 /// The <see cref="DirectoryInfo"/> to add to the list for searching for data files
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
42 /// </param>
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
43 public void AddLoadDirectory(DirectoryInfo directory)
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
44 {
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
45 if (!directories.Contains(directory))
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
46 {
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
47 directories.Add(directory);
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
48 }
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
49 }
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
50
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
51 /// <summary>
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
52 /// Removes a directory from the collection of directories that will be searched for WarFoundry data files.
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
53 /// </summary>
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
54 /// <param name="directory">
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
55 /// A <see cref="DirectoryInfo"/>
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
56 /// </param>
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
57 public void RemoveLoadDirectory(DirectoryInfo directory)
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
58 {
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
59 if (directories.Contains(directory))
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
60 {
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
61 directories.Remove(directory);
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
62 }
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
63 }
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
64
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
65 /// <summary>
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
66 /// Registers a <see cref="INativeWarFoundryFactory"/> as a factory that can parse native data files.
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
67 /// </summary>
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
68 /// <param name="factory">
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
69 /// The <see cref="INativeWarFoundryFactory"/> to register to parse native data files.
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
70 /// </param>
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
71 public void RegisterFactory(INativeWarFoundryFactory factory)
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
72 {
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
73 if (!factories.Contains(factory))
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
74 {
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
75 factories.Add(factory);
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
76 }
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
77 }
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
78
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
79 /// <summary>
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
80 /// Unregisters a <see cref="INativeWarFoundryFactory"/> so that it will no longer be used to try to parse native data files.
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
81 /// </summary>
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
82 /// <param name="factory">
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
83 /// The <see cref="INativeWarFoundryFactory"/> to remove from the collection of factories that are used to try to parse native data files.
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
84 /// </param>
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
85 public void UnregisterFactory(INativeWarFoundryFactory factory)
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
86 {
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
87 if (factories.Contains(factory))
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
88 {
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
89 factories.Remove(factory);
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
90 }
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
91 }
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
92
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
93 /// <summary>
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
94 /// Registers a <see cref="INonNativeWarFoundryFactory"/> so that it will be used to try to parse non-native data files from other applications.
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
95 /// </summary>
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
96 /// <param name="factory">
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
97 /// The <see cref="INonNativeWarFoundryFactory"/> to register to parse non-native data files.
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
98 /// </param>
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
99 public void RegisterNonNativeFactory(INonNativeWarFoundryFactory factory)
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
100 {
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
101 if (!nonNativeFactories.Contains(factory))
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
102 {
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
103 nonNativeFactories.Add(factory);
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
104 }
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
105 }
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
106
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
107 /// <summary>
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
108 /// Unregisters a <see cref="INonNativeWarFoundryFactory"/> so that it will no longer be used to try to parse non-native data files from other applications.
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
109 /// </summary>
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
110 /// <param name="factory">
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
111 /// The <see cref="INonNativeWarFoundryFactory"/> to remove from the collection of factories that are used to try to parse non-native data files.
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
112 /// </param>
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
113 public void UnregisterNonNativeFactory(INonNativeWarFoundryFactory factory)
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
114 {
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
115 if (nonNativeFactories.Contains(factory))
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
116 {
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
117 nonNativeFactories.Remove(factory);
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
118 }
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
119 }
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
120
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
121 /// <summary>
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
122 /// Loads all of the data files in the registered directories.
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
123 /// </summary>
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
124 /// <returns>
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
125 /// A <see cref="List"/> of <see cref="FileLoadFailure"/> for files that failed to load
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
126 /// </returns>
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
127 public List<FileLoadFailure> LoadFiles()
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
128 {
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
129 PrepareForFileLoad();
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
130 Dictionary<FileInfo, IWarFoundryFactory> loadableRaces = new Dictionary<FileInfo, IWarFoundryFactory>();
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
131 Dictionary<FileInfo, IWarFoundryFactory> loadableGameSystems = new Dictionary<FileInfo, IWarFoundryFactory>();
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
132 List<FileLoadFailure> failedLoads = FillLoadableFiles(loadableRaces, loadableGameSystems);
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
133 failedLoads.AddRange(LoadGameSystems(loadableGameSystems));
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
134 failedLoads.AddRange(LoadRaces(loadableRaces));
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
135 OnFileLoadingFinished(failedLoads);
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
136 return failedLoads;
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
137 }
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
138
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
139 private void OnFileLoadingFinished(List<FileLoadFailure> failures)
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
140 {
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
141 if (FileLoadingFinished!=null)
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
142 {
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
143 FileLoadingFinished(failures);
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
144 }
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
145 }
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
146
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
147 protected abstract void PrepareForFileLoad();
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
148
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
149 private List<FileLoadFailure> FillLoadableFiles(Dictionary<FileInfo, IWarFoundryFactory> loadableRaces, Dictionary<FileInfo, IWarFoundryFactory> loadableGameSystems)
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
150 {
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
151 List<FileLoadFailure> fails = new List<FileLoadFailure>();
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
152
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
153 foreach (DirectoryInfo directory in directories)
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
154 {
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
155 if (directory.Exists)
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
156 {
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
157 List<FileLoadFailure> directoryFails = FillLoadableFilesForDirectory(loadableRaces, loadableGameSystems, directory);
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
158 fails.AddRange(directoryFails);
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
159 }
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
160 else
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
161 {
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
162 LogNotifier.WarnFormat(GetType(), "Load for {0} failed because directory didn't exist", directory.FullName);
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
163 }
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
164 }
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
165
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
166 return fails;
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
167 }
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
168
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
169 private List<FileLoadFailure> FillLoadableFilesForDirectory(Dictionary<FileInfo, IWarFoundryFactory> loadableRaces, Dictionary<FileInfo, IWarFoundryFactory> loadableGameSystems, DirectoryInfo directory)
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
170 {
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
171 List<FileLoadFailure> fails = new List<FileLoadFailure>();
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
172 LogNotifier.Debug(GetType(), "Load from "+directory.FullName);
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
173
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
174 foreach (FileInfo file in directory.GetFiles())
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
175 {
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
176 IWarFoundryFactory factory = GetGameSystemLoadingFactoryForFile(file);
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
177
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
178 if (factory != null)
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
179 {
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
180 loadableGameSystems.Add(file, factory);
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
181 }
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
182 else
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
183 {
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
184 factory = GetRaceLoadingFactoryForFile(file);
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
185
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
186 if (factory!=null)
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
187 {
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
188 loadableRaces.Add(file, factory);
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
189 }
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
190 else
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
191 {
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
192 FileLoadFailure failure = new FileLoadFailure(file, "File not handled as a Race or Game System definition: {0}", "FileNotHandled");
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
193 fails.Add(failure);
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
194 LogNotifier.Info(GetType(), failure.Message);
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
195 }
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
196 }
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
197 }
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
198
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
199 return fails;
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
200 }
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
201
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
202 private IWarFoundryFactory GetGameSystemLoadingFactoryForFile(FileInfo file)
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
203 {
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
204 IWarFoundryFactory loadingFactory = null;
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
205
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
206 foreach (INonNativeWarFoundryFactory factory in nonNativeFactories)
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
207 {
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
208 if (factory.CanHandleFileAsGameSystem(file))
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
209 {
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
210 loadingFactory = factory;
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
211 break;
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
212 }
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
213 }
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
214
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
215 if (loadingFactory == null)
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
216 {
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
217 foreach (INativeWarFoundryFactory factory in factories)
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
218 {
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
219 if (factory.CanHandleFileAsGameSystem(file))
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
220 {
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
221 loadingFactory = factory;
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
222 break;
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
223 }
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
224 }
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
225 }
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
226
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
227 return loadingFactory;
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
228 }
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
229
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
230 private IWarFoundryFactory GetRaceLoadingFactoryForFile(FileInfo file)
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
231 {
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
232 IWarFoundryFactory loadingFactory = null;
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
233
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
234 foreach (INonNativeWarFoundryFactory factory in nonNativeFactories)
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
235 {
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
236 if (factory.CanHandleFileAsRace(file))
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
237 {
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
238 loadingFactory = factory;
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
239 break;
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
240 }
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
241 }
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
242
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
243 if (loadingFactory == null)
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
244 {
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
245 foreach (INativeWarFoundryFactory factory in factories)
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
246 {
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
247 if (factory.CanHandleFileAsRace(file))
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
248 {
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
249 loadingFactory = factory;
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
250 break;
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
251 }
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
252 }
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
253 }
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
254
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
255 return loadingFactory;
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
256 }
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
257
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
258 private List<FileLoadFailure> LoadGameSystems(Dictionary<FileInfo, IWarFoundryFactory> gameSystemFiles)
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
259 {
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
260 List<FileLoadFailure> fails = new List<FileLoadFailure>();
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
261
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
262
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
263 foreach (FileInfo file in gameSystemFiles.Keys)
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
264 {
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
265 FileLoadFailure failure = null;
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
266
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
267 try
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
268 {
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
269 bool loaded = LoadObject(file, gameSystemFiles[file]);
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
270
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
271 if (!loaded)
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
272 {
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
273 failure = new FileLoadFailure(file, "FileLoadFailed", "Failed to load {0} as GameSystem using {1}");
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
274 }
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
275 }
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
276 catch (Exception ex)
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
277 {
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
278 failure = new FileLoadFailure(file, null, ex.Message, null, ex);
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
279 }
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
280
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
281 if (failure!=null)
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
282 {
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
283 fails.Add(failure);
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
284 LogNotifier.Warn(GetType(), failure.Message, failure.Exception);
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
285 }
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
286 }
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
287
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
288 return fails;
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
289 }
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
290
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
291 private List<FileLoadFailure> LoadRaces(Dictionary<FileInfo, IWarFoundryFactory> raceFiles)
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
292 {
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
293 List<FileLoadFailure> fails = new List<FileLoadFailure>();
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
294
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
295 foreach (FileInfo file in raceFiles.Keys)
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
296 {
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
297 FileLoadFailure failure = null;
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
298
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
299 try
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
300 {
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
301 bool loaded = LoadObject(file, raceFiles[file]);
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
302
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
303 if (!loaded)
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
304 {
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
305 failure = new FileLoadFailure(file, "FileLoadFailed", "Failed to load {0} as Race using {1}");
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
306 }
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
307 }
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
308 catch (Exception ex)
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
309 {
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
310 failure = new FileLoadFailure(file, null, ex.Message, null, ex);
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
311 }
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
312
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
313 if (failure!=null)
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
314 {
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
315 fails.Add(failure);
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
316 LogNotifier.Warn(GetType(), failure.Message, failure.Exception);
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
317 }
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
318 }
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
319
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
320 return fails;
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
321 }
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
322
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
323 private bool LoadObject(FileInfo file, IWarFoundryFactory factory)
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
324 {
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
325 bool loaded = false;
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
326
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
327 LogNotifier.DebugFormat(GetType(), "Loading {0} using {1}", file.FullName, factory.GetType().Name);
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
328 ICollection<IWarFoundryObject> objects = factory.CreateObjectsFromFile(file);
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
329
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
330 if (objects.Count > 0)
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
331 {
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
332 AddLoadedObjects(objects, factory);
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
333 loaded = true;
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
334 }
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
335
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
336 return loaded;
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
337 }
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
338
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
339
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
340 /// <summary>
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
341 /// Loads a single file through the registered WarFoundryFactories, if a factory exists that supports the file format.
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
342 /// </summary>
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
343 /// <param name="file">
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
344 /// A <see cref="FileInfo"/> for the file to attempt to load
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
345 /// </param>
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
346 /// <returns>
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
347 /// An ICollection of IWarFoundryObjects loaded from <code>file</code>
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
348 /// </returns>
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
349 public ICollection<IWarFoundryObject> LoadFile(FileInfo file)
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
350 {
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
351 ICollection<IWarFoundryObject> objs = null;
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
352 IWarFoundryFactory loadFactory = null;
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
353
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
354 try
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
355 {
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
356 objs = LoadFileWithNonNativeFactories(file, out loadFactory);
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
357
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
358 if (objs == null)
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
359 {
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
360 objs = LoadFileWithNativeFactories(file, out loadFactory);
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
361 }
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
362 }
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
363 catch (InvalidFileException ex)
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
364 {
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
365 LogNotifier.Error(GetType(), file.FullName+" failed to load", ex);
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
366 }
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
367
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
368 if (objs!=null)
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
369 {
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
370 AddLoadedObjects(objs, loadFactory);
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
371 }
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
372 else
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
373 {
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
374 objs = new List<IWarFoundryObject>();
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
375 }
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
376
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
377 return objs;
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
378 }
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
379
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
380 private ICollection<IWarFoundryObject> LoadFileWithNonNativeFactories(FileInfo file, out IWarFoundryFactory loadFactory)
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
381 {
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
382 ICollection<IWarFoundryObject> objs = null;
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
383 loadFactory = null;
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
384
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
385 if (nonNativeFactories.Count > 0)
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
386 {
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
387 LogNotifier.Debug(GetType(), "Attempting to load "+file.FullName+" as a non-native file");
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
388
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
389 foreach (INonNativeWarFoundryFactory factory in nonNativeFactories)
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
390 {
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
391 bool canLoad = factory.CanHandleFileFormat(file);
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
392 LogNotifier.Debug(GetType(), "Load using "+factory.GetType().FullName+"? " + (canLoad ? "yes" : "no"));
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
393
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
394 if (canLoad)
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
395 {
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
396 objs = factory.CreateObjectsFromFile(file);
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
397
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
398 if (objs!=null)
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
399 {
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
400 loadFactory = factory;
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
401 break;
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
402 }
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
403 }
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
404 }
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
405 }
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
406
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
407 return objs;
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
408 }
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
409
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
410 private ICollection<IWarFoundryObject> LoadFileWithNativeFactories(FileInfo file, out IWarFoundryFactory loadFactory)
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
411 {
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
412 ICollection<IWarFoundryObject> objs = null;
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
413 loadFactory = null;
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
414
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
415 if (factories.Count > 0)
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
416 {
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
417 LogNotifier.Debug(GetType(), "Attempting to load "+file.FullName+" as native file");
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
418
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
419 foreach (INativeWarFoundryFactory factory in factories)
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
420 {
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
421 if (factory.CanHandleFileFormat(file))
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
422 {
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
423 objs = factory.CreateObjectsFromFile(file);
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
424
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
425 if (objs!=null)
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
426 {
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
427 loadFactory = factory;
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
428 break;
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
429 }
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
430 }
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
431 }
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
432 }
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
433
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
434 return objs;
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
435 }
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
436
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
437 private void AddLoadedObjects(ICollection<IWarFoundryObject> loadedObjs, IWarFoundryFactory factory)
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
438 {
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
439 SimpleSet<IWarFoundryObject> objs;
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
440 loadedObjects.TryGetValue(factory, out objs);
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
441
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
442 if (objs == null)
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
443 {
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
444 objs = new SimpleSet<IWarFoundryObject>();
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
445 loadedObjects.Add(factory, objs);
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
446 }
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
447
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
448 objs.AddRange(loadedObjs);
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
449 StoreObjects(loadedObjs);
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
450 }
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
451
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
452 private void StoreObjects(ICollection<IWarFoundryObject> loadedObjects)
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
453 {
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
454 foreach (IWarFoundryObject loadedObject in loadedObjects)
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
455 {
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
456 if (loadedObject is GameSystem)
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
457 {
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
458 StoreGameSystem((GameSystem)loadedObject);
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
459 }
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
460 else if (loadedObject is Race)
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
461 {
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
462 StoreRace((Race)loadedObject);
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
463 }
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
464 }
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
465 }
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
466
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
467 protected void StoreGameSystem(GameSystem system)
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
468 {
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
469 GameSystem existingSystem = GetExistingSystemForSystem(system);
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
470
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
471 if (existingSystem!=null)
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
472 {
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
473 if (!system.Equals(existingSystem))
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
474 {
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
475 //TODO: Raise an event to say we got a different duplicate
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
476 //We can't just fail, because failing is for completely unhandled files, not for objects in a file
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
477 }
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
478 }
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
479 else
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
480 {
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
481 DoStoreGameSystem(system);
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
482 }
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
483 }
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
484
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
485 /// <summary>
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
486 /// Gets a game system that has already been loaded that duplicates the supplied game system's ID, if one exists.
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
487 /// </summary>
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
488 /// <param name="system">
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
489 /// The <see cref="GameSystem"/> to find pre-existing duplicates of
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
490 /// </param>
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
491 /// <returns>
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
492 /// <code>null</code> if no existing duplicate exists, else the duplicate <see cref="GameSystem"/>
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
493 /// </returns>
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
494 protected abstract GameSystem GetExistingSystemForSystem(GameSystem system);
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
495
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
496 /// <summary>
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
497 /// Stores a GameSystem in the loader's relevant storage structure
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
498 /// </summary>
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
499 /// <param name="system">
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
500 /// The loaded <see cref="GameSystem"/> to store
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
501 /// </param>
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
502 protected abstract void DoStoreGameSystem(GameSystem system);
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
503
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
504 protected void StoreRace(Race race)
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
505 {
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
506 if (race.GameSystem == null)
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
507 {
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
508 throw new InvalidOperationException("Race cannot have null game system. Game system should be loaded before race.");
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
509 }
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
510
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
511 DoStoreRace(race);
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
512 }
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
513
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
514 /// <summary>
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
515 /// Performs the implementation specific storage of a race
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
516 /// </summary>
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
517 /// <param name="race">
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
518 /// The <see cref="Race"/> to store
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
519 /// </param>
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
520 protected abstract void DoStoreRace(Race race);
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
521
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
522 /// <summary>
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
523 /// Gets all <see cref="GameSystem"/>s that are currently available, determined by those that can be loaded with the current <see cref="IWarFoundryFactory"/>s.
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
524 /// </summary>
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
525 /// <returns>
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
526 /// An array of <see cref="GameSystem"/>s that are currently available.
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
527 /// </returns>
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
528 public abstract GameSystem[] GetGameSystems();
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
529
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
530 /// <summary>
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
531 /// Gets a single <see cref="GameSystem"/> with a given ID.
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
532 /// </summary>
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
533 /// <param name="systemID">
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
534 /// The ID of the <see cref="GameSystem"/> to get, as a <see cref="System.String"/>.
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
535 /// </param>
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
536 /// <returns>
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
537 /// The <see cref="GameSystem"/> with the given ID, or <code>null</code> if one doesn't exist.
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
538 /// </returns>
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
539 public abstract GameSystem GetGameSystem(string systemID);
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
540
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
541 /// <summary>
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
542 /// Removes a loaded <see cref="GameSystem"/>. Used when a GameSystem fails to complete loading
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
543 /// </summary>
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
544 /// <param name="system">The GameSystem to remove</param>
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
545 protected internal abstract void RemoveGameSystem(GameSystem system);
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
546
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
547 /// <summary>
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
548 /// Gets an array of the races for the specified <see cref="GameSystem"/>.
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
549 /// </summary>
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
550 /// <param name="system">
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
551 /// The <see cref="GameSystem"/> to get the available races for.
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
552 /// </param>
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
553 /// <returns>
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
554 /// An array of <see cref="Race"/>s for the <see cref="GameSystem"/>
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
555 /// </returns>
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
556 public abstract Race[] GetRaces(GameSystem system);
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
557
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
558 /// <summary>
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
559 /// Gets a single race for a given <see cref="GameSystem"/> by ID of the race.
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
560 /// </summary>
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
561 /// <param name="system">
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
562 /// The <see cref="GameSystem"/> that the race is part of.
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
563 /// </param>
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
564 /// <param name="raceID">
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
565 /// A <see cref="System.String"/> ID for the race to load.
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
566 /// </param>
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
567 /// <returns>
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
568 /// A <see cref="Race"/> with the specified ID from the <see cref="GameSystem"/>, or <code>null</code> if one doesn't exist.
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
569 /// </returns>
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
570 public abstract Race GetRace(GameSystem system, string raceID);
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
571
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
572 /// <summary>
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
573 /// Gets a single race for a given <see cref="GameSystem"/> by the race's ID and sub-race ID.
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
574 /// </summary>
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
575 /// <param name="system">
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
576 /// The <see cref="GameSystem"/> that the race is part of.
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
577 /// </param>
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
578 /// <param name="raceID">
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
579 /// The <see cref="System.String"/> ID for the race to load.
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
580 /// </param>
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
581 /// <param name="raceSubID">
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
582 /// A <see cref="System.String"/>
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
583 /// </param>
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
584 /// <returns>
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
585 /// A <see cref="Race"/>
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
586 /// </returns>
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
587 public abstract Race GetRace(GameSystem system, string raceID, string raceSubID);
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
588
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
589 protected internal abstract void RemoveRace(Race race);
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
590
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
591 /// <summary>
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
592 /// Gets the IDs of all of the game systems currently available.
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
593 /// </summary>
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
594 /// <returns>
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
595 /// An array of <see cref="System.String"/>s representing the IDs of the game systems.
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
596 /// </returns>
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
597 public virtual string[] GetGameSystemIDs()
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
598 {
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
599 GameSystem[] systems = GetGameSystems();
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
600 return GetWarFoundryObjectIDs(systems);
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
601 }
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
602
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
603 protected string[] GetWarFoundryObjectIDs(WarFoundryObject[] objs)
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
604 {
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
605 int objCount = objs.Length;
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
606 string[] keys = new string[objCount];
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
607
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
608 for (int i = 0; i < objCount; i++)
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
609 {
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
610 keys[i] = objs[i].ID;
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
611 }
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
612
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
613 return keys;
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
614 }
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
615
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
616 /// <summary>
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
617 /// Gets the IDs of all of the races of a specified game system.
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
618 /// </summary>
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
619 /// <param name="system">
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
620 /// The <see cref="GameSystem"/> to get the available races for.
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
621 /// </param>
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
622 /// <returns>
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
623 /// An array of <see cref="System.String"/>s representing the IDs of the races of the specified game system.
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
624 /// </returns>
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
625 public virtual string[] GetSystemRaceIDs(GameSystem system)
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
626 {
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
627 Race[] races = GetRaces(system);
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
628 return GetWarFoundryObjectIDs(races);
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
629 }
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
630
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
631 public Army LoadArmy(FileInfo file)
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
632 {
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
633 IWarFoundryFactory factory = GetArmyLoadingFactoryForFile(file);
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
634 Army loadedArmy = null;
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
635
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
636 if (factory != null)
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
637 {
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
638 ICollection<IWarFoundryObject> objs = factory.CreateObjectsFromFile(file);
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
639
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
640 if (objs.Count == 1)
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
641 {
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
642 foreach (IWarFoundryObject systemCount in objs)
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
643 {
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
644 if (systemCount is Army)
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
645 {
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
646 loadedArmy = (Army) systemCount;
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
647 }
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
648 }
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
649 }
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
650 }
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
651
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
652 return loadedArmy;
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
653 }
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
654
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
655 private IWarFoundryFactory GetArmyLoadingFactoryForFile(FileInfo file)
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
656 {
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
657 IWarFoundryFactory loadingFactory = null;
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
658
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
659 foreach (INonNativeWarFoundryFactory factory in nonNativeFactories)
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
660 {
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
661 if (factory.CanHandleFileAsArmy(file))
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
662 {
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
663 loadingFactory = factory;
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
664 break;
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
665 }
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
666 }
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
667
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
668 if (loadingFactory == null)
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
669 {
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
670 foreach (INativeWarFoundryFactory factory in factories)
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
671 {
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
672 if (factory.CanHandleFileAsArmy(file))
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
673 {
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
674 loadingFactory = factory;
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
675 break;
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
676 }
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
677 }
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
678 }
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
679
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
680 return loadingFactory;
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
681 }
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
682 }
a36a0e9cc05d Re #228: Crash with missing abilityID
IBBoard <dev@ibboard.co.uk>
parents:
diff changeset
683 }