Fixed bug when config is missing

This commit is contained in:
jeffman 2015-05-06 21:14:42 -04:00
parent 882e5a5b51
commit 78a2aa2969
1 changed files with 34 additions and 9 deletions

View File

@ -55,6 +55,9 @@ namespace ScriptToolGui
Stack<NavigationEntry> navigationStack = new Stack<NavigationEntry>();
MatchedGroupCollection currentCollection = null;
// Misc
bool badStart = false;
static MainForm()
{
validGames = new Game[] { Game.Eb, Game.M12, Game.M12English };
@ -75,6 +78,8 @@ namespace ScriptToolGui
{
InitializeComponent();
try
{
config = Config.Read("config.json");
previewer.M12Compiler = m12Compiler;
@ -90,6 +95,15 @@ namespace ScriptToolGui
collectionSelector.SelectedIndex = 0;
collectionSelector_SelectionChangeCommitted(null, null);
}
catch (Exception e)
{
MessageBox.Show("There was an error starting the tool." + Environment.NewLine +
"Reason: " + e.Message);
badStart = true;
this.Load += (s, ee) => this.Close();
}
}
private void PopulateCollectionSelector()
{
@ -161,6 +175,14 @@ namespace ScriptToolGui
itemHelpGroups.Groups.AddRange(itemHelpMappingGroups);
var itemNames = JsonConvert.DeserializeObject<MiscStringCollection>(File.ReadAllText(@"..\..\..\..\working\m12-itemnames.json"));
var ebItems = itemMapping.Select(p => new { Index = p.First, Name = itemNames.StringRefs[p.Second].New })
.OrderBy(o => o.Index)
.Select(m => "[" + (m.Index).ToString("X2") + "] " + m.Name.Substring(0, m.Name.Length - 7))
.ToArray();
File.WriteAllLines(@"D:\eb-itemnames.txt", ebItems);
// PSI help
var m12PsiHelpRefs = ImportStringRefs("m12-psi-help.json");
var ebPsiHelpRefs = ImportStringRefs("eb-psi-help.json");
@ -682,6 +704,9 @@ namespace ScriptToolGui
private void MainForm_FormClosing(object sender, FormClosingEventArgs e)
{
if (badStart)
return;
writeTimer.Enabled = false;
WriteChanges(true);
}