2020-01-28 00:16:53 +00:00
|
|
|
From 53100d2c99d2a53b62adb36f41a95f7ff63cbb42 Mon Sep 17 00:00:00 2001
|
2018-09-24 00:10:24 +00:00
|
|
|
From: Zach Brown <zach.brown@destroystokyo.com>
|
|
|
|
Date: Sat, 22 Sep 2018 15:56:59 -0400
|
|
|
|
Subject: [PATCH] Catch JsonParseException in Entity and TE names
|
|
|
|
|
|
|
|
As a result, data that no longer parses correctly will not crash the server
|
|
|
|
instead just logging the exception and continuing (and in most cases should
|
|
|
|
fix the data)
|
|
|
|
|
|
|
|
Player data is fixed pretty much immediately but some block data (like
|
|
|
|
Shulkers) may need to be changed in order for it to re-save properly
|
|
|
|
|
|
|
|
No more crashing though.
|
|
|
|
|
|
|
|
diff --git a/src/main/java/net/minecraft/server/CommandBlockListenerAbstract.java b/src/main/java/net/minecraft/server/CommandBlockListenerAbstract.java
|
2020-01-28 00:16:53 +00:00
|
|
|
index 7867122974..ef2a496eda 100644
|
2018-09-24 00:10:24 +00:00
|
|
|
--- a/src/main/java/net/minecraft/server/CommandBlockListenerAbstract.java
|
|
|
|
+++ b/src/main/java/net/minecraft/server/CommandBlockListenerAbstract.java
|
2019-12-12 16:20:43 +00:00
|
|
|
@@ -59,7 +59,7 @@ public abstract class CommandBlockListenerAbstract implements ICommandListener {
|
2019-05-05 08:33:44 +00:00
|
|
|
this.command = nbttagcompound.getString("Command");
|
|
|
|
this.successCount = nbttagcompound.getInt("SuccessCount");
|
2018-09-24 00:10:24 +00:00
|
|
|
if (nbttagcompound.hasKeyOfType("CustomName", 8)) {
|
2019-12-12 16:20:43 +00:00
|
|
|
- this.setName(IChatBaseComponent.ChatSerializer.a(nbttagcompound.getString("CustomName")));
|
|
|
|
+ this.setName(MCUtil.getBaseComponentFromNbt("CustomName", nbttagcompound)); // Paper - Catch ParseException
|
2018-09-24 00:10:24 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
if (nbttagcompound.hasKeyOfType("TrackOutput", 1)) {
|
|
|
|
diff --git a/src/main/java/net/minecraft/server/Entity.java b/src/main/java/net/minecraft/server/Entity.java
|
2020-01-28 00:16:53 +00:00
|
|
|
index 16c55a9fa0..4619f2c928 100644
|
2018-09-24 00:10:24 +00:00
|
|
|
--- a/src/main/java/net/minecraft/server/Entity.java
|
|
|
|
+++ b/src/main/java/net/minecraft/server/Entity.java
|
2019-12-12 16:20:43 +00:00
|
|
|
@@ -1679,7 +1679,7 @@ public abstract class Entity implements INamableTileEntity, ICommandListener, Ke
|
|
|
|
this.Z();
|
2019-05-05 08:33:44 +00:00
|
|
|
this.setYawPitch(this.yaw, this.pitch);
|
|
|
|
if (nbttagcompound.hasKeyOfType("CustomName", 8)) {
|
|
|
|
- this.setCustomName(IChatBaseComponent.ChatSerializer.a(nbttagcompound.getString("CustomName")));
|
|
|
|
+ this.setCustomName(MCUtil.getBaseComponentFromNbt("CustomName", nbttagcompound)); // Paper - Catch ParseException
|
|
|
|
}
|
2018-09-24 00:10:24 +00:00
|
|
|
|
2019-05-05 08:33:44 +00:00
|
|
|
this.setCustomNameVisible(nbttagcompound.getBoolean("CustomNameVisible"));
|
2018-09-24 00:10:24 +00:00
|
|
|
diff --git a/src/main/java/net/minecraft/server/MCUtil.java b/src/main/java/net/minecraft/server/MCUtil.java
|
2020-01-28 00:16:53 +00:00
|
|
|
index 2a22bc6f3e..3a482466ec 100644
|
2018-09-24 00:10:24 +00:00
|
|
|
--- a/src/main/java/net/minecraft/server/MCUtil.java
|
|
|
|
+++ b/src/main/java/net/minecraft/server/MCUtil.java
|
2020-01-28 00:16:53 +00:00
|
|
|
@@ -409,4 +409,19 @@ public final class MCUtil {
|
2018-09-24 00:10:24 +00:00
|
|
|
return null;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
+
|
|
|
|
+ @Nullable
|
|
|
|
+ public static IChatBaseComponent getBaseComponentFromNbt(String key, NBTTagCompound compound) {
|
2018-09-24 01:22:57 +00:00
|
|
|
+ if (!compound.hasKey(key)) {
|
|
|
|
+ return null;
|
|
|
|
+ }
|
|
|
|
+ String string = compound.getString(key);
|
2018-09-24 00:10:24 +00:00
|
|
|
+ try {
|
2018-09-24 01:22:57 +00:00
|
|
|
+ return IChatBaseComponent.ChatSerializer.jsonToComponent(string);
|
|
|
|
+ } catch (com.google.gson.JsonParseException e) {
|
|
|
|
+ org.bukkit.Bukkit.getLogger().warning("Unable to parse " + key + " from " + compound +": " + e.getMessage());
|
2018-09-24 00:10:24 +00:00
|
|
|
+ }
|
|
|
|
+
|
2018-09-24 01:22:57 +00:00
|
|
|
+ return null;
|
2018-09-24 00:10:24 +00:00
|
|
|
+ }
|
|
|
|
}
|
|
|
|
diff --git a/src/main/java/net/minecraft/server/TileEntityBanner.java b/src/main/java/net/minecraft/server/TileEntityBanner.java
|
2020-01-28 00:16:53 +00:00
|
|
|
index 93911a8251..d35604edb2 100644
|
2018-09-24 00:10:24 +00:00
|
|
|
--- a/src/main/java/net/minecraft/server/TileEntityBanner.java
|
|
|
|
+++ b/src/main/java/net/minecraft/server/TileEntityBanner.java
|
2020-01-22 02:02:07 +00:00
|
|
|
@@ -60,7 +60,7 @@ public class TileEntityBanner extends TileEntity implements INamableTileEntity {
|
2018-09-24 00:10:24 +00:00
|
|
|
public void load(NBTTagCompound nbttagcompound) {
|
|
|
|
super.load(nbttagcompound);
|
|
|
|
if (nbttagcompound.hasKeyOfType("CustomName", 8)) {
|
|
|
|
- this.a = IChatBaseComponent.ChatSerializer.a(nbttagcompound.getString("CustomName"));
|
|
|
|
+ this.a = MCUtil.getBaseComponentFromNbt("CustomName", nbttagcompound); // Paper - Catch ParseException
|
|
|
|
}
|
|
|
|
|
|
|
|
if (this.hasWorld()) {
|
2019-05-05 08:33:44 +00:00
|
|
|
diff --git a/src/main/java/net/minecraft/server/TileEntityContainer.java b/src/main/java/net/minecraft/server/TileEntityContainer.java
|
2020-01-28 00:16:53 +00:00
|
|
|
index 473ec2cbde..ab6b86e4e9 100644
|
2019-05-05 08:33:44 +00:00
|
|
|
--- a/src/main/java/net/minecraft/server/TileEntityContainer.java
|
|
|
|
+++ b/src/main/java/net/minecraft/server/TileEntityContainer.java
|
|
|
|
@@ -17,7 +17,7 @@ public abstract class TileEntityContainer extends TileEntity implements IInvento
|
|
|
|
super.load(nbttagcompound);
|
|
|
|
this.chestLock = ChestLock.b(nbttagcompound);
|
2018-09-24 00:10:24 +00:00
|
|
|
if (nbttagcompound.hasKeyOfType("CustomName", 8)) {
|
2019-05-05 08:33:44 +00:00
|
|
|
- this.customName = IChatBaseComponent.ChatSerializer.a(nbttagcompound.getString("CustomName"));
|
|
|
|
+ this.customName = MCUtil.getBaseComponentFromNbt("CustomName", nbttagcompound); // Paper - Catch ParseException
|
2018-09-24 00:10:24 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
}
|
|
|
|
--
|
2020-01-22 02:02:07 +00:00
|
|
|
2.25.0.windows.1
|
2018-09-24 00:10:24 +00:00
|
|
|
|