From a8667931f2381e3ca7513f2009d609f801571db0 Mon Sep 17 00:00:00 2001 From: "Wesley Pyburn (TechNobo)" <10319195+TcNobo@users.noreply.github.com> Date: Thu, 1 Jul 2021 15:39:12 +0200 Subject: [PATCH] Fixed (or now notifies user of) errors in stylesheets - Stylesheet errors are now saved to a file, the user is notified and the default file is loaded. Some poor soul has tried to star the program hundreds of times to no avail, due to a single quotation mark missing in their StyleSettings.yaml file. --- TcNo-Acc-Switcher-Client/App.xaml.cs | 26 ++++++++- TcNo-Acc-Switcher-Server/Data/AppSettings.cs | 60 ++++++++++++++++---- 2 files changed, 74 insertions(+), 12 deletions(-) diff --git a/TcNo-Acc-Switcher-Client/App.xaml.cs b/TcNo-Acc-Switcher-Client/App.xaml.cs index 413cdb722..550293ce3 100644 --- a/TcNo-Acc-Switcher-Client/App.xaml.cs +++ b/TcNo-Acc-Switcher-Client/App.xaml.cs @@ -199,7 +199,31 @@ protected override async void OnStartup(StartupEventArgs e) private static void IsRunningAlready() { - AppSettings.Instance.LoadFromFile(); + if (!AppSettings.Instance.LoadFromFile()) + { + if (File.Exists("StyleSettings_ErrorInfo.txt")) + { + var errorText = File.ReadAllText("StyleSettings_ErrorInfo.txt").Split("\n"); + MessageBox.Show( + "Could not load StyleSettings.json! Error details: " + Environment.NewLine + + errorText[0] + Environment.NewLine + Environment.NewLine + + "The default file will be loaded." + Environment.NewLine + + "See \"StyleSettings_broken.yaml\" for the broken style settings." + Environment.NewLine + + "See \"StyleSettings_ErrorInfo.txt\" for the full error message. Above is only the first line.", "Failed to load Styles", MessageBoxButton.OK, + MessageBoxImage.Error); + try + { + AppSettings.Instance.LoadFromFile(); + } + catch (Exception e) + { + MessageBox.Show( + "Another unexpected error occurred! Error details: " + Environment.NewLine + + e, "Failed to load Styles (2)", MessageBoxButton.OK, MessageBoxImage.Error); + throw; + } + } + } try { // Check if program is running, if not: return. diff --git a/TcNo-Acc-Switcher-Server/Data/AppSettings.cs b/TcNo-Acc-Switcher-Server/Data/AppSettings.cs index 757726917..0e3fdd1c4 100644 --- a/TcNo-Acc-Switcher-Server/Data/AppSettings.cs +++ b/TcNo-Acc-Switcher-Server/Data/AppSettings.cs @@ -417,14 +417,14 @@ public void SetFromJObject(JObject j) CheckShortcuts(); } - public void LoadFromFile() + public bool LoadFromFile() { Globals.DebugWriteLine(@"[Func:Data\AppSettings.LoadFromFile]"); // Main settings if (!File.Exists(SettingsFile)) SaveSettings(); else SetFromJObject(GeneralFuncs.LoadSettings(SettingsFile, GetJObject())); // Stylesheet - LoadStylesheetFromFile(); + return LoadStylesheetFromFile(); } #region STYLESHEET @@ -435,14 +435,22 @@ public void LoadFromFile() public async System.Threading.Tasks.Task SwapStylesheet(string swapTo) { File.Copy($"themes\\{swapTo.Replace(' ', '_')}.yaml", StylesheetFile, true); - LoadStylesheetFromFile(); - await AppData.ReloadPage(); - } + try + { + if (LoadStylesheetFromFile()) await AppData.ReloadPage(); + else throw new Exception(); // Jump to the error display + } + catch (Exception) + { + GeneralInvocableFuncs.ShowToast("error", "Failed to load stylesheet! See documents folder for details.", + "Stylesheet error", "toastarea"); + } + } /// /// Load stylesheet settings from stylesheet file. /// - public void LoadStylesheetFromFile() + public bool LoadStylesheetFromFile() { if (!File.Exists(StylesheetFile)) { @@ -457,6 +465,41 @@ public void LoadStylesheetFromFile() "You can run the Updater in the \"updater\" folder to verify files, and restore these missing files."); } } + + try + { + LoadStylesheet(); + } + catch (YamlDotNet.Core.SyntaxErrorException e) + { + File.Copy(StylesheetFile, "StyleSettings_broken.yaml", true); + if (File.Exists("StyleSettings_ErrorInfo.txt")) File.Delete("StyleSettings_ErrorInfo.txt"); + File.WriteAllText("StyleSettings_ErrorInfo.txt", e.ToString()); + + if (File.Exists("themes\\Default.yaml")) + File.Copy("themes\\Default.yaml", StylesheetFile, true); + else if (File.Exists(Path.Join(Globals.AppDataFolder, "themes\\Default.yaml"))) + File.Copy(Path.Join(Globals.AppDataFolder, "themes\\Default.yaml"), StylesheetFile, true); + else + { + throw new Exception( + "A syntax error was encountered (more details below)! AND:" + Environment.NewLine + + "Could not find \"themes\" folder in TcNo Account Switcher's directory. This (especially Default.yaml) is required for this software to run." + Environment.NewLine + + "You can run the Updater in the \"updater\" folder to verify files, and restore these missing files." + Environment.NewLine + Environment.NewLine + e); + } + return false; + } + + // Get name of current stylesheet + GetCurrentStylesheet(); + if (WindowsAccent) + SetAccentColor(); + + return true; + } + + private void LoadStylesheet() + { // Load new stylesheet var desc = new DeserializerBuilder().WithNamingConvention(HyphenatedNamingConvention.Instance).Build(); var attempts = 0; @@ -544,11 +587,6 @@ public void LoadStylesheetFromFile() } } } - - // Get name of current stylesheet - GetCurrentStylesheet(); - if (WindowsAccent) - SetAccentColor(); } ///