From a9ee1046a50d6ca53b056fa5ef5a0bbb1206964f Mon Sep 17 00:00:00 2001 From: Shane Freeder Date: Wed, 13 Apr 2022 08:27:16 +0100 Subject: [PATCH] Prevent tile entity copies loading chunks --- ...nt-tile-entity-copies-loading-chunks.patch | 37 +++++++++++++++++++ 1 file changed, 37 insertions(+) create mode 100644 patches/server/0892-Prevent-tile-entity-copies-loading-chunks.patch diff --git a/patches/server/0892-Prevent-tile-entity-copies-loading-chunks.patch b/patches/server/0892-Prevent-tile-entity-copies-loading-chunks.patch new file mode 100644 index 000000000..8e36eb5cc --- /dev/null +++ b/patches/server/0892-Prevent-tile-entity-copies-loading-chunks.patch @@ -0,0 +1,37 @@ +From 0000000000000000000000000000000000000000 Mon Sep 17 00:00:00 2001 +From: Shane Freeder +Date: Wed, 13 Apr 2022 08:25:42 +0100 +Subject: [PATCH] Prevent tile entity copies loading chunks + + +diff --git a/src/main/java/net/minecraft/server/network/ServerGamePacketListenerImpl.java b/src/main/java/net/minecraft/server/network/ServerGamePacketListenerImpl.java +index e4d54fdc28b6161e74626f25299b1081e6605e98..3ab4ecb9ee3586cab04da7b500024855892faa3e 100644 +--- a/src/main/java/net/minecraft/server/network/ServerGamePacketListenerImpl.java ++++ b/src/main/java/net/minecraft/server/network/ServerGamePacketListenerImpl.java +@@ -1,5 +1,6 @@ + package net.minecraft.server.network; + ++import com.destroystokyo.paper.event.player.IllegalPacketEvent; + import com.google.common.collect.Lists; + import com.google.common.primitives.Floats; + import com.mojang.brigadier.ParseResults; +@@ -2994,8 +2995,17 @@ public class ServerGamePacketListenerImpl implements ServerPlayerConnection, Ser + + if (!itemstack.isEmpty() && nbttagcompound != null && nbttagcompound.contains("x") && nbttagcompound.contains("y") && nbttagcompound.contains("z") && this.player.getBukkitEntity().hasPermission("minecraft.nbt.copy")) { // Spigot + BlockPos blockposition = BlockEntity.getPosFromTag(nbttagcompound); +- BlockEntity tileentity = this.player.level.getBlockEntity(blockposition); +- ++ // Paper start ++ BlockEntity tileentity = null; ++ if (this.player.getLevel().isLoadedAndInBounds(blockposition)) { ++ tileentity = this.player.level.getBlockEntity(blockposition); ++ } else { ++ // failed to find, cleanup ++ nbttagcompound.remove("x"); ++ nbttagcompound.remove("y"); ++ nbttagcompound.remove("z"); ++ } ++ // Paper end + if (tileentity != null) { + tileentity.saveToItem(itemstack); + }