From e564aae43db9b3e7e5ee5256b824284f95965510 Mon Sep 17 00:00:00 2001 From: Minecon724 Date: Wed, 1 Jan 2025 12:10:08 +0100 Subject: [PATCH] JSON in motd --- .../java/eu/m724/tweaks/motd/MotdManager.java | 22 ++++++++++++++++--- 1 file changed, 19 insertions(+), 3 deletions(-) diff --git a/src/main/java/eu/m724/tweaks/motd/MotdManager.java b/src/main/java/eu/m724/tweaks/motd/MotdManager.java index 1748ae8..0ac9c79 100644 --- a/src/main/java/eu/m724/tweaks/motd/MotdManager.java +++ b/src/main/java/eu/m724/tweaks/motd/MotdManager.java @@ -1,5 +1,5 @@ /* - * Copyright (C) 2024 Minecon724 + * Copyright (C) 2025 Minecon724 * Tweaks724 is licensed under the GNU General Public License. See the LICENSE.md file * in the project root for the full license text. */ @@ -11,6 +11,9 @@ import com.comphenix.protocol.ProtocolLibrary; import com.comphenix.protocol.events.*; import com.comphenix.protocol.reflect.StructureModifier; import com.google.gson.JsonElement; +import com.google.gson.JsonParseException; +import com.google.gson.JsonParser; +import eu.m724.tweaks.DebugLogger; import eu.m724.tweaks.TweaksConfig; import eu.m724.tweaks.TweaksPlugin; import net.md_5.bungee.api.chat.TextComponent; @@ -64,8 +67,21 @@ public class MotdManager { // MOTDs are split with an empty line motds = Arrays.stream(fileContent.split("\n\n")) - .map(s -> { - JsonElement json = ComponentSerializer.toJson(TextComponent.fromLegacy(s.strip())); + .map(entry -> { + entry = entry.strip(); + JsonElement json = null; + + try { + json = JsonParser.parseString(entry); + DebugLogger.fine("JSON line: " + entry); + } catch (JsonParseException e) { + DebugLogger.fine("Not a JSON line: " + entry); + } + + if (json == null) { + json = ComponentSerializer.toJson(TextComponent.fromLegacy(entry)); + } + return Component.Serializer.fromJson(json, RegistryAccess.EMPTY); }) .toArray(Component[]::new);