From 56f56ef93841dd43db8f6d22a987d84b4589253d Mon Sep 17 00:00:00 2001 From: Terry Hearst Date: Tue, 24 Oct 2023 23:07:11 -0400 Subject: [PATCH] JSON auto formatting --- Config.cs | 12 ++++++------ JsonHelper.cs | 34 ++++++++++++++++++++++++++++++++++ 2 files changed, 40 insertions(+), 6 deletions(-) create mode 100644 JsonHelper.cs diff --git a/Config.cs b/Config.cs index 6370206..05ebdbe 100644 --- a/Config.cs +++ b/Config.cs @@ -115,13 +115,13 @@ namespace CustomCosmeticLoader { JSONNode node = new JSONClass { - { PROPERTY_ENABLED, enabled ? "true" : "false" }, + { PROPERTY_ENABLED, new JSONData(enabled) }, { PROPERTY_CURRENT_SKIN, currentSkin }, { PROPERTY_SKIN_NAME_TO_HIJACK, skinNameToHijack }, - { PROPERTY_IN_MAIN_MENU, inMainMenu ? "true" : "false" }, - { PROPERTY_IN_COSMETIC_MENU, inCosmeticMenu ? "true" : "false" }, - { PROPERTY_IN_ALL_REPLAYS, inAllReplays ? "true" : "false" }, - { PROPERTY_OVERRIDE_REPLAY_COSMETICS, overrideReplayCosmetics ? "true" : "false" }, + { PROPERTY_IN_MAIN_MENU, new JSONData(inMainMenu) }, + { PROPERTY_IN_COSMETIC_MENU, new JSONData(inCosmeticMenu) }, + { PROPERTY_IN_ALL_REPLAYS, new JSONData(inAllReplays) }, + { PROPERTY_OVERRIDE_REPLAY_COSMETICS, new JSONData(overrideReplayCosmetics) }, }; JSONNode otherPlayersData = new JSONClass(); @@ -130,7 +130,7 @@ namespace CustomCosmeticLoader node.Add(PROPERTY_OTHER_PLAYERS, otherPlayersData); - File.WriteAllText(GetConfigPath(), node.ToString()); + File.WriteAllText(GetConfigPath(), JsonHelper.FormatJson(node.ToString(), "\t")); } public static void ensureSkinSelected() diff --git a/JsonHelper.cs b/JsonHelper.cs new file mode 100644 index 0000000..b0628dd --- /dev/null +++ b/JsonHelper.cs @@ -0,0 +1,34 @@ +using System; +using System.Linq; + +namespace CustomCosmeticLoader +{ + public class JsonHelper + { + /* + * Code taken from: https://stackoverflow.com/a/57100143 + */ + public static string FormatJson(string json, string indent = " ") + { + var indentation = 0; + var quoteCount = 0; + var escapeCount = 0; + + var result = + from ch in json ?? string.Empty + let escaped = (ch == '\\' ? escapeCount++ : escapeCount > 0 ? escapeCount-- : escapeCount) > 0 + let quotes = ch == '"' && !escaped ? quoteCount++ : quoteCount + let unquoted = quotes % 2 == 0 + let colon = ch == ':' && unquoted ? ": " : null + let nospace = char.IsWhiteSpace(ch) && unquoted ? string.Empty : null + let lineBreak = ch == ',' && unquoted ? ch + Environment.NewLine + string.Concat(Enumerable.Repeat(indent, indentation)) : null + let openChar = (ch == '{' || ch == '[') && unquoted ? ch + Environment.NewLine + string.Concat(Enumerable.Repeat(indent, ++indentation)) : ch.ToString() + let closeChar = (ch == '}' || ch == ']') && unquoted ? Environment.NewLine + string.Concat(Enumerable.Repeat(indent, --indentation)) + ch : ch.ToString() + select colon ?? nospace ?? lineBreak ?? ( + openChar.Length > 1 ? openChar : closeChar + ); + + return string.Concat(result); + } + } +}