mirror of
https://github.com/PaperMC/Paper.git
synced 2025-01-04 10:11:29 +01:00
Improve Chat Component Legacy Serialization more
This brings chat componenent serialization to 100% accuracy so that any text input in the legacy format, converting to comps and then back to legacy will result in identical results. If the user explicitly sets a color as prefix to a string, it is retained, even if that color matches the default. This also helps improve dealing with the empty string wrappers Bukkit creates. A unit test has been added to verify this behavior.
This commit is contained in:
parent
c404f38837
commit
8e7099030e
1 changed files with 83 additions and 5 deletions
|
@ -17,6 +17,15 @@ diff --git a/src/main/java/org/bukkit/craftbukkit/util/CraftChatMessage.java b/s
|
||||||
index 0000000000000000000000000000000000000000..0000000000000000000000000000000000000000 100644
|
index 0000000000000000000000000000000000000000..0000000000000000000000000000000000000000 100644
|
||||||
--- a/src/main/java/org/bukkit/craftbukkit/util/CraftChatMessage.java
|
--- a/src/main/java/org/bukkit/craftbukkit/util/CraftChatMessage.java
|
||||||
+++ b/src/main/java/org/bukkit/craftbukkit/util/CraftChatMessage.java
|
+++ b/src/main/java/org/bukkit/craftbukkit/util/CraftChatMessage.java
|
||||||
|
@@ -0,0 +0,0 @@ public final class CraftChatMessage {
|
||||||
|
case 1:
|
||||||
|
EnumChatFormat format = formatMap.get(match.toLowerCase(java.util.Locale.ENGLISH).charAt(1));
|
||||||
|
if (format == EnumChatFormat.RESET) {
|
||||||
|
- modifier = new ChatModifier();
|
||||||
|
+ modifier = new ChatModifier().setColor(format); // Paper
|
||||||
|
} else if (format.isFormat()) {
|
||||||
|
switch (format) {
|
||||||
|
case BOLD:
|
||||||
@@ -0,0 +0,0 @@ public final class CraftChatMessage {
|
@@ -0,0 +0,0 @@ public final class CraftChatMessage {
|
||||||
if (component == null) return "";
|
if (component == null) return "";
|
||||||
StringBuilder out = new StringBuilder();
|
StringBuilder out = new StringBuilder();
|
||||||
|
@ -26,13 +35,20 @@ index 0000000000000000000000000000000000000000..00000000000000000000000000000000
|
||||||
for (IChatBaseComponent c : (Iterable<IChatBaseComponent>) component) {
|
for (IChatBaseComponent c : (Iterable<IChatBaseComponent>) component) {
|
||||||
ChatModifier modi = c.getChatModifier();
|
ChatModifier modi = c.getChatModifier();
|
||||||
- out.append(modi.getColor() == null ? defaultColor : modi.getColor());
|
- out.append(modi.getColor() == null ? defaultColor : modi.getColor());
|
||||||
|
+ EnumChatFormat color = modi.getColor();
|
||||||
+ if (first) {
|
+ if (first) {
|
||||||
+ if (modi.getColor() != null) {
|
+ if (color != null) {
|
||||||
+ out.append(modi.getColor());
|
+ out.append(color);
|
||||||
+ }
|
+ }
|
||||||
|
+ if (!c.getText().isEmpty() || color != null) {
|
||||||
+ first = false;
|
+ first = false;
|
||||||
+ } else {
|
+ }
|
||||||
+ out.append(modi.getColor() == null ? defaultColor : modi.getColor());
|
+ } else if (!c.getText().isEmpty() || color != null) {
|
||||||
|
+ if (color != null) {
|
||||||
|
+ out.append(color);
|
||||||
|
+ } else if (defaultColor != null) {
|
||||||
|
+ out.append(defaultColor);
|
||||||
|
+ }
|
||||||
+ }
|
+ }
|
||||||
+ // Paper end
|
+ // Paper end
|
||||||
if (modi.isBold()) {
|
if (modi.isBold()) {
|
||||||
|
@ -47,3 +63,65 @@ index 0000000000000000000000000000000000000000..00000000000000000000000000000000
|
||||||
}
|
}
|
||||||
|
|
||||||
public static IChatBaseComponent fixComponent(IChatBaseComponent component) {
|
public static IChatBaseComponent fixComponent(IChatBaseComponent component) {
|
||||||
|
diff --git a/src/test/java/org/bukkit/craftbukkit/CraftChatMessageTest.java b/src/test/java/org/bukkit/craftbukkit/CraftChatMessageTest.java
|
||||||
|
new file mode 100644
|
||||||
|
index 0000000000000000000000000000000000000000..0000000000000000000000000000000000000000
|
||||||
|
--- /dev/null
|
||||||
|
+++ b/src/test/java/org/bukkit/craftbukkit/CraftChatMessageTest.java
|
||||||
|
@@ -0,0 +0,0 @@
|
||||||
|
+package org.bukkit.craftbukkit;
|
||||||
|
+
|
||||||
|
+import net.minecraft.server.EnumChatFormat;
|
||||||
|
+import net.minecraft.server.IChatBaseComponent;
|
||||||
|
+import org.bukkit.ChatColor;
|
||||||
|
+import org.bukkit.craftbukkit.util.CraftChatMessage;
|
||||||
|
+import org.bukkit.support.AbstractTestingBase;
|
||||||
|
+import org.junit.Test;
|
||||||
|
+
|
||||||
|
+import static org.junit.Assert.assertEquals;
|
||||||
|
+
|
||||||
|
+public class CraftChatMessageTest extends AbstractTestingBase {
|
||||||
|
+ @Test
|
||||||
|
+ public void testSimpleStrings() {
|
||||||
|
+ testString("&fFoo", EnumChatFormat.WHITE);
|
||||||
|
+ testString("Foo", EnumChatFormat.WHITE);
|
||||||
|
+ testString("Foo&bBar", EnumChatFormat.WHITE);
|
||||||
|
+ testString("Foo&bBar", EnumChatFormat.AQUA);
|
||||||
|
+ testString("&fFoo&bBar", EnumChatFormat.WHITE);
|
||||||
|
+ testString("&rFoo", EnumChatFormat.WHITE);
|
||||||
|
+ }
|
||||||
|
+
|
||||||
|
+ @Test
|
||||||
|
+ public void testComponents() {
|
||||||
|
+ testComponent("Foo&bBar&fBaz", EnumChatFormat.WHITE, create("Foo", "&bBar", "Baz"));
|
||||||
|
+ testComponent("&fFoo&bBar&fBaz", EnumChatFormat.WHITE, create("", "&fFoo", "&bBar", "Baz"));
|
||||||
|
+ testComponent("Foo&bBar&fBaz", EnumChatFormat.WHITE, create("", "Foo", "&bBar", "Baz"));
|
||||||
|
+ testComponent("&fFoo&bBar&fBaz", EnumChatFormat.WHITE, create("&fFoo", "&bBar", "Baz"));
|
||||||
|
+ testComponent("F&foo&bBar&fBaz", EnumChatFormat.WHITE, create("F&foo", "&bBar", "Baz"));
|
||||||
|
+ }
|
||||||
|
+
|
||||||
|
+ private IChatBaseComponent create(String txt, String ...rest) {
|
||||||
|
+ IChatBaseComponent cmp = toComp(txt);
|
||||||
|
+ for (String s : rest) {
|
||||||
|
+ cmp.addSibling(toComp(s));
|
||||||
|
+ }
|
||||||
|
+
|
||||||
|
+ return cmp;
|
||||||
|
+ }
|
||||||
|
+
|
||||||
|
+ private IChatBaseComponent toComp(String txt) {
|
||||||
|
+ return CraftChatMessage.fromString(ChatColor.translateAlternateColorCodes('&', txt))[0];
|
||||||
|
+ }
|
||||||
|
+
|
||||||
|
+ private void testString(String expected, EnumChatFormat defColor) {
|
||||||
|
+ expected = ChatColor.translateAlternateColorCodes('&', expected);
|
||||||
|
+ IChatBaseComponent cmp = CraftChatMessage.fromStringOrNull(expected);
|
||||||
|
+ testComponent(expected, defColor, cmp);
|
||||||
|
+ }
|
||||||
|
+
|
||||||
|
+ private void testComponent(String expected, EnumChatFormat defColor, IChatBaseComponent components) {
|
||||||
|
+ expected = ChatColor.translateAlternateColorCodes('&', expected);
|
||||||
|
+ String actual = CraftChatMessage.fromComponent(components, defColor);
|
||||||
|
+ assertEquals(expected, actual);
|
||||||
|
+ }
|
||||||
|
+}
|
||||||
|
|
Loading…
Reference in a new issue