From c92581d0dc57840de2a09a8c0cab9fa7773a4d80 Mon Sep 17 00:00:00 2001 From: md_5 Date: Sun, 29 Oct 2023 11:30:54 +1100 Subject: [PATCH] #3556: Deserialize arrays to single components --- .../md_5/bungee/chat/ComponentSerializer.java | 22 +++++++++---------- 1 file changed, 10 insertions(+), 12 deletions(-) diff --git a/chat/src/main/java/net/md_5/bungee/chat/ComponentSerializer.java b/chat/src/main/java/net/md_5/bungee/chat/ComponentSerializer.java index 699678b7d3..d4de81c36b 100644 --- a/chat/src/main/java/net/md_5/bungee/chat/ComponentSerializer.java +++ b/chat/src/main/java/net/md_5/bungee/chat/ComponentSerializer.java @@ -2,6 +2,7 @@ import com.google.gson.Gson; import com.google.gson.GsonBuilder; +import com.google.gson.JsonArray; import com.google.gson.JsonDeserializationContext; import com.google.gson.JsonDeserializer; import com.google.gson.JsonElement; @@ -77,13 +78,12 @@ public static BaseComponent[] parse(String json) } /** - * Deserialize a JSON-compliant String as a single component. The input is - * expected to be a JSON object that represents only one component. + * Deserialize a JSON-compliant String as a single component. * * @param json the component json to parse * @return the deserialized component - * @throws IllegalArgumentException if anything other than a JSON object is - * passed as input + * @throws IllegalArgumentException if anything other than a valid JSON + * component string is passed as input */ public static BaseComponent deserialize(String json) { @@ -93,13 +93,12 @@ public static BaseComponent deserialize(String json) } /** - * Deserialize a JSON element as a single component. The input is expected - * to be a JSON object that represents only one component. + * Deserialize a JSON element as a single component. * * @param jsonElement the component json to parse * @return the deserialized component - * @throws IllegalArgumentException if anything other than a JSON object is - * passed as input + * @throws IllegalArgumentException if anything other than a valid JSON + * component is passed as input */ public static BaseComponent deserialize(JsonElement jsonElement) { @@ -110,11 +109,10 @@ public static BaseComponent deserialize(JsonElement jsonElement) { return new TextComponent( primitive.getAsString() ); } - } - - if ( !jsonElement.isJsonObject() ) + } else if ( jsonElement instanceof JsonArray ) { - throw new IllegalArgumentException( "Malformatted JSON. Expected object, got array for input \"" + jsonElement + "\"." ); + BaseComponent[] array = gson.fromJson( jsonElement, BaseComponent[].class ); + return TextComponent.fromArray( array ); } return gson.fromJson( jsonElement, BaseComponent.class );