summaryrefslogtreecommitdiff
path: root/src
diff options
context:
space:
mode:
authorJesse Plamondon-Willard <github@jplamondonw.com>2017-02-14 22:06:06 -0500
committerJesse Plamondon-Willard <github@jplamondonw.com>2017-02-14 22:06:06 -0500
commitf140e844ed1e52d1f5955e07a397f44ef9ab3233 (patch)
tree9f27a7ec7c1e0d237a3fa961e588bf22ea6efc60 /src
parente804ed5479b3fffbe060e11d31e55499cab842f9 (diff)
downloadSMAPI-f140e844ed1e52d1f5955e07a397f44ef9ab3233.tar.gz
SMAPI-f140e844ed1e52d1f5955e07a397f44ef9ab3233.tar.bz2
SMAPI-f140e844ed1e52d1f5955e07a397f44ef9ab3233.zip
streamline startup a bit
Diffstat (limited to 'src')
-rw-r--r--src/StardewModdingAPI/Framework/Monitor.cs2
-rw-r--r--src/StardewModdingAPI/Program.cs56
2 files changed, 26 insertions, 32 deletions
diff --git a/src/StardewModdingAPI/Framework/Monitor.cs b/src/StardewModdingAPI/Framework/Monitor.cs
index 3a9276a0..c1735917 100644
--- a/src/StardewModdingAPI/Framework/Monitor.cs
+++ b/src/StardewModdingAPI/Framework/Monitor.cs
@@ -82,7 +82,7 @@ namespace StardewModdingAPI.Framework
public void ExitGameImmediately(string reason)
{
Program.ExitGameImmediately(this.Source, reason);
- Program.gamePtr.Exit();
+ Program.GameInstance.Exit();
}
/// <summary>Log a fatal error message.</summary>
diff --git a/src/StardewModdingAPI/Program.cs b/src/StardewModdingAPI/Program.cs
index 58b86e8f..c3f8f8d8 100644
--- a/src/StardewModdingAPI/Program.cs
+++ b/src/StardewModdingAPI/Program.cs
@@ -59,21 +59,12 @@ namespace StardewModdingAPI
/// <summary>Whether the game is currently running.</summary>
private static bool ready;
- /// <summary>The underlying game assembly.</summary>
- private static Assembly StardewAssembly;
-
- /// <summary>The underlying <see cref="StardewValley.Program"/> type.</summary>
- private static Type StardewProgramType;
-
- /// <summary>The field containing game's main instance.</summary>
- private static FieldInfo StardewGameInfo;
-
/*********
** Accessors
*********/
/// <summary>The underlying game instance.</summary>
- internal static SGame gamePtr;
+ internal static SGame GameInstance;
/// <summary>The number of mods currently loaded by SMAPI.</summary>
internal static int ModsLoaded;
@@ -185,8 +176,8 @@ namespace StardewModdingAPI
Program.CancellationTokenSource.Cancel();
if (Program.ready)
{
- Program.gamePtr.Exiting += (sender, e) => Program.PressAnyKeyToExit();
- Program.gamePtr.Exit();
+ Program.GameInstance.Exiting += (sender, e) => Program.PressAnyKeyToExit();
+ Program.GameInstance.Exit();
}
}
@@ -226,29 +217,31 @@ namespace StardewModdingAPI
{
try
{
- // load the game assembly
- Program.Monitor.Log("Loading game...");
- Program.StardewAssembly = Assembly.UnsafeLoadFrom(Program.GameExecutablePath);
- Program.StardewProgramType = Program.StardewAssembly.GetType("StardewValley.Program", true);
- Program.StardewGameInfo = Program.StardewProgramType.GetField("gamePtr");
- Game1.version += $" | SMAPI {Constants.ApiVersion}";
-
- // add error interceptors
+ // add error handlers
#if SMAPI_FOR_WINDOWS
Application.ThreadException += (sender, e) => Program.Monitor.Log($"Critical thread exception: {e.Exception.GetLogSummary()}", LogLevel.Error);
Application.SetUnhandledExceptionMode(UnhandledExceptionMode.CatchException);
#endif
AppDomain.CurrentDomain.UnhandledException += (sender, e) => Program.Monitor.Log($"Critical app domain exception: {e.ExceptionObject}", LogLevel.Error);
- // initialise game instance
- Program.gamePtr = new SGame(Program.Monitor) { IsMouseVisible = false };
- Program.gamePtr.Exiting += (sender, e) => Program.ready = false;
- Program.gamePtr.Window.ClientSizeChanged += (sender, e) => GraphicsEvents.InvokeResize(Program.Monitor, sender, e);
- Program.gamePtr.Window.Title = $"Stardew Valley - Version {Game1.version}";
- Program.StardewGameInfo.SetValue(Program.StardewProgramType, Program.gamePtr);
-
- // patch graphics
- Game1.graphics.GraphicsProfile = GraphicsProfile.HiDef;
+ // initialise game
+ {
+ // load assembly
+ Program.Monitor.Log("Loading game...");
+ Assembly gameAssembly = Assembly.UnsafeLoadFrom(Program.GameExecutablePath);
+ Type gameProgramType = gameAssembly.GetType("StardewValley.Program", true);
+
+ // set Game1 instance
+ Program.GameInstance = new SGame(Program.Monitor);
+ Program.GameInstance.Exiting += (sender, e) => Program.ready = false;
+ Program.GameInstance.Window.ClientSizeChanged += (sender, e) => GraphicsEvents.InvokeResize(Program.Monitor, sender, e);
+ Program.GameInstance.Window.Title = $"Stardew Valley - Version {Game1.version}";
+ gameProgramType.GetField("gamePtr").SetValue(gameProgramType, Program.GameInstance);
+
+ // configure
+ Game1.version += $" | SMAPI {Constants.ApiVersion}";
+ Game1.graphics.GraphicsProfile = GraphicsProfile.HiDef;
+ }
// load mods
Program.LoadMods();
@@ -262,7 +255,8 @@ namespace StardewModdingAPI
new Thread(() =>
{
// wait for the game to load up
- while (!Program.ready) Thread.Sleep(1000);
+ while (!Program.ready)
+ Thread.Sleep(1000);
// register help command
Program.CommandManager.Add("SMAPI", "help", "Lists all commands | 'help <cmd>' returns command description", Program.HandleHelpCommand);
@@ -290,7 +284,7 @@ namespace StardewModdingAPI
try
{
Program.ready = true;
- Program.gamePtr.Run();
+ Program.GameInstance.Run();
}
finally
{