0
0
mirror of https://hub.spigotmc.org/stash/scm/spigot/spigot.git synced 2025-07-06 18:10:34 +00:00
Files
spigot/CraftBukkit-Patches/0018-Properly-Close-Inventories.patch
2025-06-18 01:15:00 +10:00

45 lines
2.2 KiB
Diff

From 4248f95ca7074705da23a3db88c4bf4132fa9677 Mon Sep 17 00:00:00 2001
From: md_5 <git@md-5.net>
Date: Thu, 27 Jun 2013 17:26:09 +1000
Subject: [PATCH] Properly Close Inventories
Properly close inventories when unloading and switching worlds.
diff --git a/src/main/java/net/minecraft/server/level/WorldServer.java b/src/main/java/net/minecraft/server/level/WorldServer.java
index 7fd2f8bea..e9fadfb9d 100644
--- a/src/main/java/net/minecraft/server/level/WorldServer.java
+++ b/src/main/java/net/minecraft/server/level/WorldServer.java
@@ -1148,6 +1148,15 @@ public class WorldServer extends World implements ServerEntityGetter, GeneratorA
}
public void unload(Chunk chunk) {
+ // Spigot Start
+ for (net.minecraft.world.level.block.entity.TileEntity tileentity : chunk.getBlockEntities().values()) {
+ if (tileentity instanceof net.minecraft.world.IInventory) {
+ for (org.bukkit.entity.HumanEntity h : Lists.newArrayList(((net.minecraft.world.IInventory) tileentity).getViewers())) {
+ h.closeInventory();
+ }
+ }
+ }
+ // Spigot End
chunk.clearAllBlockEntities();
chunk.unregisterTickContainerFromLevel(this);
}
@@ -2070,6 +2079,13 @@ public class WorldServer extends World implements ServerEntityGetter, GeneratorA
public void onTrackingEnd(Entity entity) {
org.spigotmc.AsyncCatcher.catchOp("entity unregister"); // Spigot
+ // Spigot Start
+ if (entity.getBukkitEntity() instanceof org.bukkit.inventory.InventoryHolder && (!(entity instanceof EntityPlayer) || entity.getRemovalReason() != Entity.RemovalReason.KILLED)) { // SPIGOT-6876: closeInventory clears death message
+ for (org.bukkit.entity.HumanEntity h : Lists.newArrayList(((org.bukkit.inventory.InventoryHolder) entity.getBukkitEntity()).getInventory().getViewers())) {
+ h.closeInventory();
+ }
+ }
+ // Spigot End
WorldServer.this.getChunkSource().removeEntity(entity);
if (entity instanceof EntityPlayer entityplayer) {
WorldServer.this.players.remove(entityplayer);
--
2.49.0