2022-06-10 11:15:57 +10:00
From 0855caaed58ef6be6924fc9b6358cc428bf71ed7 Mon Sep 17 00:00:00 2001
2014-04-12 14:18:37 +10:00
From: md_5 <md_5@live.com.au>
Date: Thu, 27 Jun 2013 17:26:09 +1000
Subject: [PATCH] Properly Close Inventories
Properly close inventories when unloading and switching worlds.
2021-03-16 09:00:00 +11:00
diff --git a/src/main/java/net/minecraft/server/level/WorldServer.java b/src/main/java/net/minecraft/server/level/WorldServer.java
2022-06-10 11:15:57 +10:00
index 3b5f771e7..c980cda98 100644
2021-03-16 09:00:00 +11:00
--- a/src/main/java/net/minecraft/server/level/WorldServer.java
+++ b/src/main/java/net/minecraft/server/level/WorldServer.java
2022-06-10 11:15:57 +10:00
@@ -1047,6 +1047,15 @@ public class WorldServer extends World implements GeneratorAccessSeed {
2019-04-23 12:00:00 +10:00
}
2014-04-12 14:18:37 +10:00
2021-11-22 09:00:00 +11:00
public void unload(Chunk chunk) {
2019-04-23 12:00:00 +10:00
+ // Spigot Start
2021-11-22 09:00:00 +11:00
+ for (net.minecraft.world.level.block.entity.TileEntity tileentity : chunk.getBlockEntities().values()) {
2021-03-16 09:00:00 +11:00
+ if (tileentity instanceof net.minecraft.world.IInventory) {
+ for (org.bukkit.entity.HumanEntity h : Lists.newArrayList(((net.minecraft.world.IInventory) tileentity).getViewers())) {
2020-05-09 19:41:03 +10:00
+ h.closeInventory();
2014-04-12 14:18:37 +10:00
+ }
+ }
2019-04-23 12:00:00 +10:00
+ }
+ // Spigot End
2021-11-22 09:00:00 +11:00
chunk.clearAllBlockEntities();
chunk.unregisterTickContainerFromLevel(this);
2021-06-11 15:00:00 +10:00
}
2022-06-10 11:15:57 +10:00
@@ -1997,6 +2006,13 @@ public class WorldServer extends World implements GeneratorAccessSeed {
2014-04-12 14:18:37 +10:00
2021-11-22 09:00:00 +11:00
public void onTrackingEnd(Entity entity) {
2021-06-11 15:00:00 +10:00
org.spigotmc.AsyncCatcher.catchOp("entity unregister"); // Spigot
+ // Spigot Start
2022-01-02 11:42:29 +11:00
+ if (entity.getBukkitEntity() instanceof org.bukkit.inventory.InventoryHolder && (!(entity instanceof EntityPlayer) || entity.getRemovalReason() != Entity.RemovalReason.KILLED)) { // SPIGOT-6876: closeInventory clears death message
2021-06-11 15:00:00 +10:00
+ for (org.bukkit.entity.HumanEntity h : Lists.newArrayList(((org.bukkit.inventory.InventoryHolder) entity.getBukkitEntity()).getInventory().getViewers())) {
+ h.closeInventory();
+ }
2020-05-09 19:41:03 +10:00
+ }
2021-06-11 15:00:00 +10:00
+ // Spigot End
2021-11-22 09:00:00 +11:00
WorldServer.this.getChunkSource().removeEntity(entity);
2021-06-11 15:00:00 +10:00
if (entity instanceof EntityPlayer) {
EntityPlayer entityplayer = (EntityPlayer) entity;
2014-04-12 14:18:37 +10:00
--
2020-05-09 18:48:11 +10:00
2.25.1
2014-04-12 14:18:37 +10:00