From 9251b9291c2f9ec7cc457c9b1b2b70ea1e0103a1 Mon Sep 17 00:00:00 2001 From: Shatyuka <958182453@qq.com> Date: Fri, 27 Oct 2023 20:43:51 +0800 Subject: [PATCH] Throw an exception if registry key could not be found --- .../Genshin/RegistryClass/GeneralData.cs | 41 ++++++++----------- 1 file changed, 17 insertions(+), 24 deletions(-) diff --git a/CollapseLauncher/Classes/GameManagement/GameSettings/Genshin/RegistryClass/GeneralData.cs b/CollapseLauncher/Classes/GameManagement/GameSettings/Genshin/RegistryClass/GeneralData.cs index d58cc9aa4..f753340be 100644 --- a/CollapseLauncher/Classes/GameManagement/GameSettings/Genshin/RegistryClass/GeneralData.cs +++ b/CollapseLauncher/Classes/GameManagement/GameSettings/Genshin/RegistryClass/GeneralData.cs @@ -320,36 +320,29 @@ public static GeneralData Load() { try { - if (RegistryRoot == null) throw new NullReferenceException($"Cannot load {_ValueName} RegistryKey is unexpectedly not initialized!"); - object? value = RegistryRoot.GetValue(_ValueName, null); + if (RegistryRoot == null) throw new NullReferenceException($"Cannot load {_ValueName} since RegistryKey is unexpectedly not initialized!"); + object value = RegistryRoot.GetValue(_ValueName) ?? throw new ArgumentNullException($"Cannot find registry key {_ValueName}"); - if (value != null) - { - ReadOnlySpan byteStr = (byte[])value; + ReadOnlySpan byteStr = (byte[])value; #if DUMPGIJSON - // Dump GeneralData as raw string - LogWriteLine($"RAW Genshin Settings: {_ValueName}\r\n" + - $"{Encoding.UTF8.GetString(byteStr.TrimEnd((byte)0))}", LogType.Debug, true); - - // Dump GeneralData as indented JSON output using GeneralData properties - LogWriteLine($"Deserialized Genshin Settings: {_ValueName}\r\n{byteStr - .Deserialize(GenshinSettingsJSONContext.Default) - .Serialize(GenshinSettingsJSONContext.Default, false, true)}", LogType.Debug, true); + // Dump GeneralData as raw string + LogWriteLine($"RAW Genshin Settings: {_ValueName}\r\n" + + $"{Encoding.UTF8.GetString(byteStr.TrimEnd((byte)0))}", LogType.Debug, true); + + // Dump GeneralData as indented JSON output using GeneralData properties + LogWriteLine($"Deserialized Genshin Settings: {_ValueName}\r\n{byteStr + .Deserialize(GenshinSettingsJSONContext.Default) + .Serialize(GenshinSettingsJSONContext.Default, false, true)}", LogType.Debug, true); #endif #if DEBUG - LogWriteLine($"Loaded Genshin Settings: {_ValueName}", LogType.Debug, true); + LogWriteLine($"Loaded Genshin Settings: {_ValueName}", LogType.Debug, true); #else - LogWriteLine($"Loaded Genshin Settings", LogType.Default, true); + LogWriteLine($"Loaded Genshin Settings", LogType.Default, true); #endif - GeneralData data = byteStr.Deserialize(GenshinSettingsJSONContext.Default) ?? new GeneralData(); - data.graphicsData = GraphicsData.Load(data._graphicsData); - data.globalPerfData = GlobalPerfData.Load(data._globalPerfData, data.graphicsData); - return data; - } -#pragma warning disable CS8625 // Cannot convert null literal to non-nullable reference type. - GlobalPerfData.Load(null, null); -#pragma warning restore CS8625 // Cannot convert null literal to non-nullable reference type. - return new GeneralData(); + GeneralData data = byteStr.Deserialize(GenshinSettingsJSONContext.Default) ?? new GeneralData(); + data.graphicsData = GraphicsData.Load(data._graphicsData); + data.globalPerfData = GlobalPerfData.Load(data._globalPerfData, data.graphicsData); + return data; } catch (Exception ex) {