2020-05-06 17:48:49 +08:00
|
|
|
From 0000000000000000000000000000000000000000 Mon Sep 17 00:00:00 2001
|
2019-06-16 01:30:43 +08:00
|
|
|
From: Spottedleaf <Spottedleaf@users.noreply.github.com>
|
|
|
|
Date: Sat, 15 Jun 2019 10:28:25 -0700
|
|
|
|
Subject: [PATCH] Show blockstate location if we failed to read it
|
|
|
|
|
|
|
|
|
|
|
|
diff --git a/src/main/java/org/bukkit/craftbukkit/block/CraftBlockEntityState.java b/src/main/java/org/bukkit/craftbukkit/block/CraftBlockEntityState.java
|
2020-05-06 17:48:49 +08:00
|
|
|
index f6401e2cde9d56547cee7f8d9e4b2a58764ee895..3e22d558ea09a6554e1bc71f8ca10277ec480705 100644
|
2019-06-16 01:30:43 +08:00
|
|
|
--- a/src/main/java/org/bukkit/craftbukkit/block/CraftBlockEntityState.java
|
|
|
|
+++ b/src/main/java/org/bukkit/craftbukkit/block/CraftBlockEntityState.java
|
2019-07-05 10:13:38 +08:00
|
|
|
@@ -19,6 +19,8 @@ public class CraftBlockEntityState<T extends TileEntity> extends CraftBlockState
|
2019-06-16 01:30:43 +08:00
|
|
|
public CraftBlockEntityState(Block block, Class<T> tileEntityClass) {
|
|
|
|
super(block);
|
|
|
|
|
|
|
|
+ try {// Paper - show location on failure
|
|
|
|
+
|
|
|
|
this.tileEntityClass = tileEntityClass;
|
|
|
|
|
|
|
|
// get tile entity from block:
|
2019-07-05 10:13:38 +08:00
|
|
|
@@ -38,6 +40,14 @@ public class CraftBlockEntityState<T extends TileEntity> extends CraftBlockState
|
2019-06-16 01:30:43 +08:00
|
|
|
this.load(this.snapshot);
|
|
|
|
}
|
|
|
|
// Paper end
|
2019-06-16 01:36:09 +08:00
|
|
|
+ // Paper start - show location on failure
|
2019-06-16 01:30:43 +08:00
|
|
|
+ } catch (Throwable thr) {
|
|
|
|
+ if (thr instanceof ThreadDeath) {
|
|
|
|
+ throw (ThreadDeath)thr;
|
|
|
|
+ }
|
2019-06-18 08:43:18 +08:00
|
|
|
+ throw new RuntimeException("Failed to read BlockState at: world: " + block.getWorld().getName() + " location: (" + block.getX() + ", " + block.getY() + ", " + block.getZ() + ")", thr);
|
2019-06-16 01:30:43 +08:00
|
|
|
+ }
|
2019-06-16 01:36:09 +08:00
|
|
|
+ // Paper end
|
2019-06-16 01:30:43 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
public final boolean snapshotDisabled; // Paper
|