2015-03-22 20:50:13 +01:00
|
|
|
From b7986cfe637a536c4a1ce520737f660ad52e314a Mon Sep 17 00:00:00 2001
|
2014-07-21 22:46:54 +02: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.
|
|
|
|
|
|
|
|
diff --git a/src/main/java/net/minecraft/server/Chunk.java b/src/main/java/net/minecraft/server/Chunk.java
|
2015-03-22 20:50:13 +01:00
|
|
|
index 3e72a01..7e56837 100644
|
2014-07-21 22:46:54 +02:00
|
|
|
--- a/src/main/java/net/minecraft/server/Chunk.java
|
|
|
|
+++ b/src/main/java/net/minecraft/server/Chunk.java
|
2015-03-22 20:50:13 +01:00
|
|
|
@@ -828,6 +828,18 @@ public class Chunk {
|
2014-07-21 22:46:54 +02:00
|
|
|
|
|
|
|
while (iterator.hasNext()) {
|
|
|
|
TileEntity tileentity = (TileEntity) iterator.next();
|
|
|
|
+ // Spigot Start
|
|
|
|
+ if ( tileentity instanceof IInventory )
|
|
|
|
+ {
|
2014-11-28 02:17:45 +01:00
|
|
|
+ for ( org.bukkit.entity.HumanEntity h : Lists.<org.bukkit.entity.HumanEntity>newArrayList((List<org.bukkit.entity.HumanEntity>) ( (IInventory) tileentity ).getViewers() ) )
|
2014-07-21 22:46:54 +02:00
|
|
|
+ {
|
2014-08-07 01:00:55 +02:00
|
|
|
+ if ( h instanceof org.bukkit.craftbukkit.entity.CraftHumanEntity )
|
|
|
|
+ {
|
|
|
|
+ ( (org.bukkit.craftbukkit.entity.CraftHumanEntity) h).getHandle().closeInventory();
|
|
|
|
+ }
|
2014-07-21 22:46:54 +02:00
|
|
|
+ }
|
|
|
|
+ }
|
|
|
|
+ // Spigot End
|
|
|
|
|
2014-11-28 02:17:45 +01:00
|
|
|
this.world.b(tileentity);
|
2014-07-21 22:46:54 +02:00
|
|
|
}
|
2015-03-22 20:50:13 +01:00
|
|
|
@@ -838,6 +850,18 @@ public class Chunk {
|
2014-11-28 02:17:45 +01:00
|
|
|
java.util.Iterator<Entity> iter = newList.iterator();
|
2014-07-21 22:46:54 +02:00
|
|
|
while (iter.hasNext()) {
|
2014-11-28 02:17:45 +01:00
|
|
|
Entity entity = iter.next();
|
2014-07-21 22:46:54 +02:00
|
|
|
+ // Spigot Start
|
|
|
|
+ if ( entity instanceof IInventory )
|
|
|
|
+ {
|
2014-11-28 02:17:45 +01:00
|
|
|
+ for ( org.bukkit.entity.HumanEntity h : Lists.<org.bukkit.entity.HumanEntity>newArrayList( (List<org.bukkit.entity.HumanEntity>) ( (IInventory) entity ).getViewers() ) )
|
2014-07-21 22:46:54 +02:00
|
|
|
+ {
|
2014-08-07 01:00:55 +02:00
|
|
|
+ if ( h instanceof org.bukkit.craftbukkit.entity.CraftHumanEntity )
|
|
|
|
+ {
|
|
|
|
+ ( (org.bukkit.craftbukkit.entity.CraftHumanEntity) h).getHandle().closeInventory();
|
|
|
|
+ }
|
2014-07-21 22:46:54 +02:00
|
|
|
+ }
|
|
|
|
+ }
|
|
|
|
+ // Spigot End
|
|
|
|
|
|
|
|
// Do not pass along players, as doing so can get them stuck outside of time.
|
|
|
|
// (which for example disables inventory icon updates and prevents block breaking)
|
|
|
|
diff --git a/src/main/java/net/minecraft/server/EntityMinecartContainer.java b/src/main/java/net/minecraft/server/EntityMinecartContainer.java
|
2015-02-28 12:36:22 +01:00
|
|
|
index 712018a..17b5714 100644
|
2014-07-21 22:46:54 +02:00
|
|
|
--- a/src/main/java/net/minecraft/server/EntityMinecartContainer.java
|
|
|
|
+++ b/src/main/java/net/minecraft/server/EntityMinecartContainer.java
|
2015-02-28 12:36:22 +01:00
|
|
|
@@ -127,6 +127,12 @@ public abstract class EntityMinecartContainer extends EntityMinecartAbstract imp
|
2014-07-21 22:46:54 +02:00
|
|
|
}
|
|
|
|
|
2014-11-28 02:17:45 +01:00
|
|
|
public void c(int i) {
|
2014-07-21 22:46:54 +02:00
|
|
|
+ // Spigot Start
|
|
|
|
+ for ( HumanEntity human : new java.util.ArrayList<HumanEntity>( transaction ) )
|
|
|
|
+ {
|
|
|
|
+ human.closeInventory();
|
|
|
|
+ }
|
|
|
|
+ // Spigot End
|
|
|
|
this.b = false;
|
2014-11-28 02:17:45 +01:00
|
|
|
super.c(i);
|
2014-07-21 22:46:54 +02:00
|
|
|
}
|
|
|
|
--
|
2014-11-28 02:17:45 +01:00
|
|
|
2.1.0
|
2014-08-09 00:15:42 +02:00
|
|
|
|