From e36dcb847740bbb041bb796e2e735bd0a7f20925 Mon Sep 17 00:00:00 2001 From: NorbiPeti Date: Sun, 16 May 2021 01:43:51 +0200 Subject: [PATCH] Separate file for localisation, remove validate button, exe detect fix --- GCMM/GCMM.csproj | 12 ++++ GCMM/Localization.Designer.cs | 130 ++++++++++++++++++++++++++++++++++ GCMM/Localization.resx | 45 ++++++++++++ GCMM/MainForm.Designer.cs | 92 ++++++++---------------- GCMM/MainForm.cs | 27 ++----- GCMM/MainForm.resx | 25 ------- GCMM/MainUtils.cs | 8 ++- 7 files changed, 226 insertions(+), 113 deletions(-) create mode 100644 GCMM/Localization.Designer.cs create mode 100644 GCMM/Localization.resx diff --git a/GCMM/GCMM.csproj b/GCMM/GCMM.csproj index 9bf00d3..9f0e30d 100644 --- a/GCMM/GCMM.csproj +++ b/GCMM/GCMM.csproj @@ -38,6 +38,18 @@ Form + + True + True + Localization.resx + + + + + + ResXFileCodeGenerator + Localization.Designer.cs + \ No newline at end of file diff --git a/GCMM/Localization.Designer.cs b/GCMM/Localization.Designer.cs new file mode 100644 index 0000000..5dcac93 --- /dev/null +++ b/GCMM/Localization.Designer.cs @@ -0,0 +1,130 @@ +//------------------------------------------------------------------------------ +// +// This code was generated by a tool. +// Runtime Version:4.0.30319.42000 +// +// Changes to this file may cause incorrect behavior and will be lost if +// the code is regenerated. +// +//------------------------------------------------------------------------------ + +namespace GCMM { + using System; + + + /// + /// A strongly-typed resource class, for looking up localized strings, etc. + /// + // This class was auto-generated by the StronglyTypedResourceBuilder + // class via a tool like ResGen or Visual Studio. + // To add or remove a member, edit your .ResX file then rerun ResGen + // with the /str option, or rebuild your VS project. + [global::System.CodeDom.Compiler.GeneratedCodeAttribute("System.Resources.Tools.StronglyTypedResourceBuilder", "4.0.0.0")] + [global::System.Diagnostics.DebuggerNonUserCodeAttribute()] + [global::System.Runtime.CompilerServices.CompilerGeneratedAttribute()] + internal class Localization { + + private static global::System.Resources.ResourceManager resourceMan; + + private static global::System.Globalization.CultureInfo resourceCulture; + + [global::System.Diagnostics.CodeAnalysis.SuppressMessageAttribute("Microsoft.Performance", "CA1811:AvoidUncalledPrivateCode")] + internal Localization() { + } + + /// + /// Returns the cached ResourceManager instance used by this class. + /// + [global::System.ComponentModel.EditorBrowsableAttribute(global::System.ComponentModel.EditorBrowsableState.Advanced)] + internal static global::System.Resources.ResourceManager ResourceManager { + get { + if (object.ReferenceEquals(resourceMan, null)) { + global::System.Resources.ResourceManager temp = new global::System.Resources.ResourceManager("GCMM.Localization", typeof(Localization).Assembly); + resourceMan = temp; + } + return resourceMan; + } + } + + /// + /// Overrides the current thread's CurrentUICulture property for all + /// resource lookups using this strongly typed resource class. + /// + [global::System.ComponentModel.EditorBrowsableAttribute(global::System.ComponentModel.EditorBrowsableState.Advanced)] + internal static global::System.Globalization.CultureInfo Culture { + get { + return resourceCulture; + } + set { + resourceCulture = value; + } + } + + /// + /// Looks up a localized string similar to Launcher settings updated.. + /// + internal static string Change_launch_settings_done { + get { + return ResourceManager.GetString("Change_launch_settings_done", resourceCulture); + } + } + + /// + /// Looks up a localized string similar to Failed to update launcher settings! You can still run TBMM manually or retry in settings.. + /// + internal static string Change_launch_settings_error { + get { + return ResourceManager.GetString("Change_launch_settings_error", resourceCulture); + } + } + + /// + /// Looks up a localized string similar to Do you want TBMM to change the game's launch settings so it can ensure the game is patched? + /// + ///If you say yes, TBMM will do a quick check before the game is launched and patches if necessary. This way you (hopefully) won't see crashes after a Techblox update. + /// + ///Note that this also means that if you (re)move TBMM without disabling this in the settings then you won't be able to launch Techblox until you reinstall TBMM or fix the launcher configuration.. + /// + internal static string Change_launch_settings_question { + get { + return ResourceManager.GetString("Change_launch_settings_question", resourceCulture); + } + } + + /// + /// Looks up a localized string similar to TBMM auto-patching. + /// + internal static string Change_launch_settings_title { + get { + return ResourceManager.GetString("Change_launch_settings_title", resourceCulture); + } + } + + /// + /// Looks up a localized string similar to Found game at {0}. + /// + internal static string Found_game_at { + get { + return ResourceManager.GetString("Found_game_at", resourceCulture); + } + } + + /// + /// Looks up a localized string similar to Game not found. Is it installed correctly? Anyway, please locate the game.. + /// + internal static string Game_not_found { + get { + return ResourceManager.GetString("Game_not_found", resourceCulture); + } + } + + /// + /// Looks up a localized string similar to Status: Game not found. + /// + internal static string Status_Game_not_found { + get { + return ResourceManager.GetString("Status_Game_not_found", resourceCulture); + } + } + } +} diff --git a/GCMM/Localization.resx b/GCMM/Localization.resx new file mode 100644 index 0000000..cd47306 --- /dev/null +++ b/GCMM/Localization.resx @@ -0,0 +1,45 @@ + + + + + + + + + text/microsoft-resx + + + 1.3 + + + System.Resources.ResXResourceReader, System.Windows.Forms, Version=2.0.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089 + + + System.Resources.ResXResourceWriter, System.Windows.Forms, Version=2.0.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089 + + + Found game at {0} + + + Game not found. Is it installed correctly? Anyway, please locate the game. + + + Status: Game not found + + + Do you want TBMM to change the game's launch settings so it can ensure the game is patched? + +If you say yes, TBMM will do a quick check before the game is launched and patches if necessary. This way you (hopefully) won't see crashes after a Techblox update. + +Note that this also means that if you (re)move TBMM without disabling this in the settings then you won't be able to launch Techblox until you reinstall TBMM or fix the launcher configuration. + + + TBMM auto-patching + + + Launcher settings updated. + + + Failed to update launcher settings! You can still run TBMM manually or retry in settings. + + \ No newline at end of file diff --git a/GCMM/MainForm.Designer.cs b/GCMM/MainForm.Designer.cs index ddd8c9d..618df9f 100644 --- a/GCMM/MainForm.Designer.cs +++ b/GCMM/MainForm.Designer.cs @@ -23,24 +23,20 @@ #region Windows Form Designer generated code /// - /// Required method for Designer support - do not modify - /// the contents of this method with the code editor. + /// Required method for Designer support - do not modify + /// the contents of this method with the code editor. /// private void InitializeComponent() { System.Windows.Forms.ListViewGroup listViewGroup1 = new System.Windows.Forms.ListViewGroup("Installed", System.Windows.Forms.HorizontalAlignment.Center); System.Windows.Forms.ListViewGroup listViewGroup2 = new System.Windows.Forms.ListViewGroup("Available", System.Windows.Forms.HorizontalAlignment.Center); - System.Windows.Forms.ListViewItem listViewItem1 = new System.Windows.Forms.ListViewItem(new string[] { - "Mod", - "modtainers", - "1.0", - "2020.06.15. 2:01:43"}, -1); + System.Windows.Forms.ListViewItem listViewItem1 = new System.Windows.Forms.ListViewItem(new string[] {"Mod", "modtainers", "1.0", "2020.06.15. 2:01:43"}, -1); System.ComponentModel.ComponentResourceManager resources = new System.ComponentModel.ComponentResourceManager(typeof(MainForm)); this.modlist = new System.Windows.Forms.ListView(); - this.modName = ((System.Windows.Forms.ColumnHeader)(new System.Windows.Forms.ColumnHeader())); - this.modAuthor = ((System.Windows.Forms.ColumnHeader)(new System.Windows.Forms.ColumnHeader())); - this.modVersion = ((System.Windows.Forms.ColumnHeader)(new System.Windows.Forms.ColumnHeader())); - this.modTimestamp = ((System.Windows.Forms.ColumnHeader)(new System.Windows.Forms.ColumnHeader())); + this.modName = new System.Windows.Forms.ColumnHeader(); + this.modAuthor = new System.Windows.Forms.ColumnHeader(); + this.modVersion = new System.Windows.Forms.ColumnHeader(); + this.modTimestamp = new System.Windows.Forms.ColumnHeader(); this.status = new System.Windows.Forms.Label(); this.installbtn = new System.Windows.Forms.Button(); this.uninstallbtn = new System.Windows.Forms.Button(); @@ -50,21 +46,14 @@ this.unpatched = new System.Windows.Forms.CheckBox(); this.modinfobox = new System.Windows.Forms.RichTextBox(); this.refreshbtn = new System.Windows.Forms.Button(); - this.validatebtn = new System.Windows.Forms.Button(); this.SuspendLayout(); // // modlist // - this.modlist.Anchor = ((System.Windows.Forms.AnchorStyles)((((System.Windows.Forms.AnchorStyles.Top | System.Windows.Forms.AnchorStyles.Bottom) - | System.Windows.Forms.AnchorStyles.Left) - | System.Windows.Forms.AnchorStyles.Right))); - this.modlist.BackColor = System.Drawing.Color.FromArgb(((int)(((byte)(216)))), ((int)(((byte)(240)))), ((int)(((byte)(216))))); + this.modlist.Anchor = ((System.Windows.Forms.AnchorStyles) ((((System.Windows.Forms.AnchorStyles.Top | System.Windows.Forms.AnchorStyles.Bottom) | System.Windows.Forms.AnchorStyles.Left) | System.Windows.Forms.AnchorStyles.Right))); + this.modlist.BackColor = System.Drawing.Color.FromArgb(((int) (((byte) (216)))), ((int) (((byte) (240)))), ((int) (((byte) (216))))); this.modlist.BorderStyle = System.Windows.Forms.BorderStyle.FixedSingle; - this.modlist.Columns.AddRange(new System.Windows.Forms.ColumnHeader[] { - this.modName, - this.modAuthor, - this.modVersion, - this.modTimestamp}); + this.modlist.Columns.AddRange(new System.Windows.Forms.ColumnHeader[] {this.modName, this.modAuthor, this.modVersion, this.modTimestamp}); this.modlist.ForeColor = System.Drawing.Color.Green; this.modlist.FullRowSelect = true; listViewGroup1.Header = "Installed"; @@ -73,14 +62,11 @@ listViewGroup2.Header = "Available"; listViewGroup2.HeaderAlignment = System.Windows.Forms.HorizontalAlignment.Center; listViewGroup2.Name = "available"; - this.modlist.Groups.AddRange(new System.Windows.Forms.ListViewGroup[] { - listViewGroup1, - listViewGroup2}); + this.modlist.Groups.AddRange(new System.Windows.Forms.ListViewGroup[] {listViewGroup1, listViewGroup2}); this.modlist.HeaderStyle = System.Windows.Forms.ColumnHeaderStyle.Nonclickable; this.modlist.HideSelection = false; listViewItem1.Group = listViewGroup1; - this.modlist.Items.AddRange(new System.Windows.Forms.ListViewItem[] { - listViewItem1}); + this.modlist.Items.AddRange(new System.Windows.Forms.ListViewItem[] {listViewItem1}); this.modlist.Location = new System.Drawing.Point(12, 47); this.modlist.Name = "modlist"; this.modlist.Size = new System.Drawing.Size(491, 433); @@ -112,10 +98,10 @@ // // status // - this.status.Anchor = ((System.Windows.Forms.AnchorStyles)((System.Windows.Forms.AnchorStyles.Bottom | System.Windows.Forms.AnchorStyles.Left))); + this.status.Anchor = ((System.Windows.Forms.AnchorStyles) ((System.Windows.Forms.AnchorStyles.Bottom | System.Windows.Forms.AnchorStyles.Left))); this.status.AutoSize = true; this.status.FlatStyle = System.Windows.Forms.FlatStyle.Flat; - this.status.Font = new System.Drawing.Font("Microsoft Sans Serif", 12F, System.Drawing.FontStyle.Regular, System.Drawing.GraphicsUnit.Point, ((byte)(238))); + this.status.Font = new System.Drawing.Font("Microsoft Sans Serif", 12F, System.Drawing.FontStyle.Regular, System.Drawing.GraphicsUnit.Point, ((byte) (238))); this.status.ForeColor = System.Drawing.Color.Lime; this.status.Location = new System.Drawing.Point(8, 487); this.status.Name = "status"; @@ -125,11 +111,11 @@ // // installbtn // - this.installbtn.Anchor = ((System.Windows.Forms.AnchorStyles)((System.Windows.Forms.AnchorStyles.Top | System.Windows.Forms.AnchorStyles.Right))); + this.installbtn.Anchor = ((System.Windows.Forms.AnchorStyles) ((System.Windows.Forms.AnchorStyles.Top | System.Windows.Forms.AnchorStyles.Right))); this.installbtn.FlatAppearance.MouseDownBackColor = System.Drawing.Color.Green; - this.installbtn.FlatAppearance.MouseOverBackColor = System.Drawing.Color.FromArgb(((int)(((byte)(0)))), ((int)(((byte)(40)))), ((int)(((byte)(0))))); + this.installbtn.FlatAppearance.MouseOverBackColor = System.Drawing.Color.FromArgb(((int) (((byte) (0)))), ((int) (((byte) (40)))), ((int) (((byte) (0))))); this.installbtn.FlatStyle = System.Windows.Forms.FlatStyle.Flat; - this.installbtn.Font = new System.Drawing.Font("Microsoft Sans Serif", 14.25F, System.Drawing.FontStyle.Regular, System.Drawing.GraphicsUnit.Point, ((byte)(238))); + this.installbtn.Font = new System.Drawing.Font("Microsoft Sans Serif", 14.25F, System.Drawing.FontStyle.Regular, System.Drawing.GraphicsUnit.Point, ((byte) (238))); this.installbtn.Location = new System.Drawing.Point(509, 12); this.installbtn.Name = "installbtn"; this.installbtn.Size = new System.Drawing.Size(263, 49); @@ -140,11 +126,11 @@ // // uninstallbtn // - this.uninstallbtn.Anchor = ((System.Windows.Forms.AnchorStyles)((System.Windows.Forms.AnchorStyles.Top | System.Windows.Forms.AnchorStyles.Right))); + this.uninstallbtn.Anchor = ((System.Windows.Forms.AnchorStyles) ((System.Windows.Forms.AnchorStyles.Top | System.Windows.Forms.AnchorStyles.Right))); this.uninstallbtn.FlatAppearance.MouseDownBackColor = System.Drawing.Color.Black; this.uninstallbtn.FlatAppearance.MouseOverBackColor = System.Drawing.Color.Black; this.uninstallbtn.FlatStyle = System.Windows.Forms.FlatStyle.Flat; - this.uninstallbtn.Font = new System.Drawing.Font("Microsoft Sans Serif", 14.25F, System.Drawing.FontStyle.Regular, System.Drawing.GraphicsUnit.Point, ((byte)(238))); + this.uninstallbtn.Font = new System.Drawing.Font("Microsoft Sans Serif", 14.25F, System.Drawing.FontStyle.Regular, System.Drawing.GraphicsUnit.Point, ((byte) (238))); this.uninstallbtn.ForeColor = System.Drawing.Color.Green; this.uninstallbtn.Location = new System.Drawing.Point(509, 67); this.uninstallbtn.Name = "uninstallbtn"; @@ -158,9 +144,9 @@ // this.playbtn.Anchor = System.Windows.Forms.AnchorStyles.Bottom; this.playbtn.FlatAppearance.MouseDownBackColor = System.Drawing.Color.Green; - this.playbtn.FlatAppearance.MouseOverBackColor = System.Drawing.Color.FromArgb(((int)(((byte)(0)))), ((int)(((byte)(40)))), ((int)(((byte)(0))))); + this.playbtn.FlatAppearance.MouseOverBackColor = System.Drawing.Color.FromArgb(((int) (((byte) (0)))), ((int) (((byte) (40)))), ((int) (((byte) (0))))); this.playbtn.FlatStyle = System.Windows.Forms.FlatStyle.Flat; - this.playbtn.Font = new System.Drawing.Font("Microsoft Sans Serif", 20.25F, System.Drawing.FontStyle.Regular, System.Drawing.GraphicsUnit.Point, ((byte)(238))); + this.playbtn.Font = new System.Drawing.Font("Microsoft Sans Serif", 20.25F, System.Drawing.FontStyle.Regular, System.Drawing.GraphicsUnit.Point, ((byte) (238))); this.playbtn.Location = new System.Drawing.Point(250, 487); this.playbtn.Name = "playbtn"; this.playbtn.Size = new System.Drawing.Size(300, 62); @@ -171,9 +157,9 @@ // // settingsbtn // - this.settingsbtn.Anchor = ((System.Windows.Forms.AnchorStyles)((System.Windows.Forms.AnchorStyles.Bottom | System.Windows.Forms.AnchorStyles.Right))); + this.settingsbtn.Anchor = ((System.Windows.Forms.AnchorStyles) ((System.Windows.Forms.AnchorStyles.Bottom | System.Windows.Forms.AnchorStyles.Right))); this.settingsbtn.FlatAppearance.MouseDownBackColor = System.Drawing.Color.Green; - this.settingsbtn.FlatAppearance.MouseOverBackColor = System.Drawing.Color.FromArgb(((int)(((byte)(0)))), ((int)(((byte)(40)))), ((int)(((byte)(0))))); + this.settingsbtn.FlatAppearance.MouseOverBackColor = System.Drawing.Color.FromArgb(((int) (((byte) (0)))), ((int) (((byte) (40)))), ((int) (((byte) (0))))); this.settingsbtn.FlatStyle = System.Windows.Forms.FlatStyle.Flat; this.settingsbtn.Location = new System.Drawing.Point(667, 487); this.settingsbtn.Name = "settingsbtn"; @@ -185,9 +171,9 @@ // // findlog // - this.findlog.Anchor = ((System.Windows.Forms.AnchorStyles)((System.Windows.Forms.AnchorStyles.Bottom | System.Windows.Forms.AnchorStyles.Right))); + this.findlog.Anchor = ((System.Windows.Forms.AnchorStyles) ((System.Windows.Forms.AnchorStyles.Bottom | System.Windows.Forms.AnchorStyles.Right))); this.findlog.FlatAppearance.MouseDownBackColor = System.Drawing.Color.Green; - this.findlog.FlatAppearance.MouseOverBackColor = System.Drawing.Color.FromArgb(((int)(((byte)(0)))), ((int)(((byte)(40)))), ((int)(((byte)(0))))); + this.findlog.FlatAppearance.MouseOverBackColor = System.Drawing.Color.FromArgb(((int) (((byte) (0)))), ((int) (((byte) (40)))), ((int) (((byte) (0))))); this.findlog.FlatStyle = System.Windows.Forms.FlatStyle.Flat; this.findlog.Location = new System.Drawing.Point(666, 522); this.findlog.Name = "findlog"; @@ -199,7 +185,7 @@ // // unpatched // - this.unpatched.Anchor = ((System.Windows.Forms.AnchorStyles)((System.Windows.Forms.AnchorStyles.Bottom | System.Windows.Forms.AnchorStyles.Left))); + this.unpatched.Anchor = ((System.Windows.Forms.AnchorStyles) ((System.Windows.Forms.AnchorStyles.Bottom | System.Windows.Forms.AnchorStyles.Left))); this.unpatched.AutoSize = true; this.unpatched.Location = new System.Drawing.Point(12, 534); this.unpatched.Name = "unpatched"; @@ -211,8 +197,7 @@ // // modinfobox // - this.modinfobox.Anchor = ((System.Windows.Forms.AnchorStyles)(((System.Windows.Forms.AnchorStyles.Top | System.Windows.Forms.AnchorStyles.Bottom) - | System.Windows.Forms.AnchorStyles.Right))); + this.modinfobox.Anchor = ((System.Windows.Forms.AnchorStyles) (((System.Windows.Forms.AnchorStyles.Top | System.Windows.Forms.AnchorStyles.Bottom) | System.Windows.Forms.AnchorStyles.Right))); this.modinfobox.BackColor = System.Drawing.Color.Black; this.modinfobox.BorderStyle = System.Windows.Forms.BorderStyle.FixedSingle; this.modinfobox.ForeColor = System.Drawing.Color.Lime; @@ -226,9 +211,9 @@ // refreshbtn // this.refreshbtn.FlatAppearance.MouseDownBackColor = System.Drawing.Color.Green; - this.refreshbtn.FlatAppearance.MouseOverBackColor = System.Drawing.Color.FromArgb(((int)(((byte)(0)))), ((int)(((byte)(40)))), ((int)(((byte)(0))))); + this.refreshbtn.FlatAppearance.MouseOverBackColor = System.Drawing.Color.FromArgb(((int) (((byte) (0)))), ((int) (((byte) (40)))), ((int) (((byte) (0))))); this.refreshbtn.FlatStyle = System.Windows.Forms.FlatStyle.Flat; - this.refreshbtn.Font = new System.Drawing.Font("Microsoft Sans Serif", 8.25F, System.Drawing.FontStyle.Regular, System.Drawing.GraphicsUnit.Point, ((byte)(238))); + this.refreshbtn.Font = new System.Drawing.Font("Microsoft Sans Serif", 8.25F, System.Drawing.FontStyle.Regular, System.Drawing.GraphicsUnit.Point, ((byte) (238))); this.refreshbtn.Location = new System.Drawing.Point(12, 12); this.refreshbtn.Name = "refreshbtn"; this.refreshbtn.Size = new System.Drawing.Size(105, 29); @@ -237,27 +222,12 @@ this.refreshbtn.UseVisualStyleBackColor = true; this.refreshbtn.Click += new System.EventHandler(this.refreshbtn_Click); // - // validatebtn - // - this.validatebtn.FlatAppearance.MouseDownBackColor = System.Drawing.Color.Green; - this.validatebtn.FlatAppearance.MouseOverBackColor = System.Drawing.Color.FromArgb(((int)(((byte)(0)))), ((int)(((byte)(40)))), ((int)(((byte)(0))))); - this.validatebtn.FlatStyle = System.Windows.Forms.FlatStyle.Flat; - this.validatebtn.Font = new System.Drawing.Font("Microsoft Sans Serif", 8.25F, System.Drawing.FontStyle.Regular, System.Drawing.GraphicsUnit.Point, ((byte)(238))); - this.validatebtn.Location = new System.Drawing.Point(398, 12); - this.validatebtn.Name = "validatebtn"; - this.validatebtn.Size = new System.Drawing.Size(105, 29); - this.validatebtn.TabIndex = 11; - this.validatebtn.Text = "Validate game"; - this.validatebtn.UseVisualStyleBackColor = true; - this.validatebtn.Click += new System.EventHandler(this.validatebtn_Click); - // // MainForm // this.AutoScaleDimensions = new System.Drawing.SizeF(6F, 13F); this.AutoScaleMode = System.Windows.Forms.AutoScaleMode.Font; this.BackColor = System.Drawing.Color.Black; this.ClientSize = new System.Drawing.Size(784, 561); - this.Controls.Add(this.validatebtn); this.Controls.Add(this.refreshbtn); this.Controls.Add(this.modinfobox); this.Controls.Add(this.unpatched); @@ -269,14 +239,13 @@ this.Controls.Add(this.status); this.Controls.Add(this.modlist); this.ForeColor = System.Drawing.Color.Lime; - this.Icon = ((System.Drawing.Icon)(resources.GetObject("$this.Icon"))); + this.Icon = ((System.Drawing.Icon) (resources.GetObject("$this.Icon"))); this.Name = "MainForm"; this.Text = "Techblox Mod Manager"; this.Load += new System.EventHandler(this.Form1_Load); this.Shown += new System.EventHandler(this.MainForm_Shown); this.ResumeLayout(false); this.PerformLayout(); - } #endregion @@ -295,7 +264,6 @@ private System.Windows.Forms.CheckBox unpatched; private System.Windows.Forms.RichTextBox modinfobox; private System.Windows.Forms.Button refreshbtn; - private System.Windows.Forms.Button validatebtn; } } diff --git a/GCMM/MainForm.cs b/GCMM/MainForm.cs index f5edf1a..86a42e0 100644 --- a/GCMM/MainForm.cs +++ b/GCMM/MainForm.cs @@ -1,10 +1,11 @@ using System; using System.Collections.Generic; -using System.ComponentModel; using System.Diagnostics; using System.Drawing; using System.IO; using System.Linq; +using System.Reflection; +using System.Resources; using System.Threading.Tasks; using System.Windows.Forms; @@ -15,13 +16,13 @@ namespace GCMM public MainForm() { InitializeComponent(); - resources = new ComponentResourceManager(typeof(MainForm)); + resources = new ResourceManager("GCMM.Localization", Assembly.GetExecutingAssembly()); Configuration = Configuration.Load(); } public Configuration Configuration { get; } - private readonly ComponentResourceManager resources; + private readonly ResourceManager resources; private readonly Dictionary mods = new Dictionary(); private readonly ModInfo gcipa = new ModInfo { Author = "modtainers", Name = "GCIPA" }; private readonly ModInfo gcmm = new ModInfo { Author = "NorbiPeti", Name = "GCMM" }; @@ -269,26 +270,6 @@ You may also want to verify the game's files in the launcher. CheckIfPatched(); //Check after getting the available mods to show GCIPA updates } - private void validatebtn_Click(object sender, EventArgs e) - { - if (CheckNoExe()) - return; - if (MessageBox.Show("Validating the game's files is useful if the game doesn't start even without mods." + - " Make sure to click Refresh once Steam finished verifying the game." + - " The Steam window that shows the progress might open in the background." + - " Note that if auto-patching isn't enabled then you will need to patch the game again using the Play button in order to use mods." + - "\n\nContinue?", "Verify game files", MessageBoxButtons.OKCancel) == DialogResult.Cancel) - return; - string exe = GetExe(); - File.Delete(GamePath($@"\{exe.Replace(".exe", "")}_Data\Managed\IllusionInjector.dll")); //Used to check if game is patched -#if USING_STEAM - if (Environment.OSVersion.Platform == PlatformID.Win32NT) - Process.Start("steam://validate/1078000/"); - else - Process.Start("xdg-open", "steam://validate/1078000/"); -#endif - } - private void MainForm_Shown(object sender, EventArgs e) { Focus(); diff --git a/GCMM/MainForm.resx b/GCMM/MainForm.resx index 5c60fc3..292cae0 100644 --- a/GCMM/MainForm.resx +++ b/GCMM/MainForm.resx @@ -1867,29 +1867,4 @@ APAIAADhCAAAw48AAMf/AAD//wAA//8AAA== - - Found game at {0} - - - Game not found. Is it installed correctly? Anyway, please locate the game. - - - Status: Game not found - - - Do you want TBMM to change the game's launch settings so it can ensure the game is patched? - -If you say yes, TBMM will do a quick check before the game is launched and patches if necessary. This way you (hopefully) won't see crashes after a Techblox update. - -Note that this also means that if you (re)move TBMM without disabling this in the settings then you won't be able to launch Techblox until you reinstall TBMM or fix the launcher configuration. - - - TBMM auto-patching - - - Launcher settings updated. - - - Failed to update launcher settings! You can still run TBMM manually or retry in settings. - \ No newline at end of file diff --git a/GCMM/MainUtils.cs b/GCMM/MainUtils.cs index 8e02a7b..bf9f474 100644 --- a/GCMM/MainUtils.cs +++ b/GCMM/MainUtils.cs @@ -70,9 +70,11 @@ namespace GCMM string launcherConfig = Path.Combine(Environment.GetFolderPath(Environment.SpecialFolder.LocalApplicationData), "Techblox Launcher", "launcher_settings.ini"); - if (File.Exists(launcherConfig)) - return File.ReadLines(launcherConfig).FirstOrDefault(line => line.StartsWith("133062..GAME_PATH=")) - ?.Substring("133062..GAME_PATH=".Length); + if (!File.Exists(launcherConfig)) return null; + string path = File.ReadLines(launcherConfig) + .FirstOrDefault(line => line.StartsWith("133062..GAME_PATH=")) + ?.Substring("133062..GAME_PATH=".Length); + if (path != null && GetExe(path) != null) return path; return null; }