2021-03-16 09:00:00 +11:00
|
|
|
--- a/net/minecraft/world/inventory/Container.java
|
|
|
|
+++ b/net/minecraft/world/inventory/Container.java
|
2021-06-11 15:00:00 +10:00
|
|
|
@@ -29,6 +29,20 @@
|
2021-03-16 09:00:00 +11:00
|
|
|
import net.minecraft.world.level.block.Block;
|
|
|
|
import net.minecraft.world.level.block.entity.TileEntity;
|
2014-11-26 08:32:16 +11:00
|
|
|
|
|
|
|
+// CraftBukkit start
|
2019-04-23 12:00:00 +10:00
|
|
|
+import com.google.common.base.Preconditions;
|
2014-11-26 08:32:16 +11:00
|
|
|
+import java.util.HashMap;
|
|
|
|
+import java.util.Map;
|
2021-03-16 09:00:00 +11:00
|
|
|
+import net.minecraft.network.chat.IChatBaseComponent;
|
|
|
|
+import net.minecraft.network.protocol.game.PacketPlayOutSetSlot;
|
2014-11-26 08:32:16 +11:00
|
|
|
+import org.bukkit.craftbukkit.inventory.CraftInventory;
|
|
|
|
+import org.bukkit.craftbukkit.inventory.CraftItemStack;
|
|
|
|
+import org.bukkit.event.Event.Result;
|
|
|
|
+import org.bukkit.event.inventory.InventoryDragEvent;
|
|
|
|
+import org.bukkit.event.inventory.InventoryType;
|
|
|
|
+import org.bukkit.inventory.InventoryView;
|
|
|
|
+// CraftBukkit end
|
|
|
|
+
|
|
|
|
public abstract class Container {
|
|
|
|
|
2021-06-11 15:00:00 +10:00
|
|
|
public static final int SLOT_CLICKED_OUTSIDE = -999;
|
2021-06-11 19:10:28 +10:00
|
|
|
@@ -43,7 +57,7 @@
|
|
|
|
public NonNullList<Slot> slots = NonNullList.a();
|
|
|
|
private final List<ContainerProperty> dataSlots = Lists.newArrayList();
|
|
|
|
private ItemStack carried;
|
|
|
|
- private final NonNullList<ItemStack> remoteSlots;
|
|
|
|
+ public NonNullList<ItemStack> remoteSlots;
|
|
|
|
private final IntList remoteDataSlots;
|
|
|
|
private ItemStack remoteCarried;
|
|
|
|
@Nullable
|
2021-06-11 15:00:00 +10:00
|
|
|
@@ -57,6 +71,27 @@
|
|
|
|
private ContainerSynchronizer synchronizer;
|
|
|
|
private boolean suppressRemoteUpdates;
|
2015-02-26 22:41:06 +00:00
|
|
|
|
2014-11-26 08:32:16 +11:00
|
|
|
+ // CraftBukkit start
|
|
|
|
+ public boolean checkReachable = true;
|
|
|
|
+ public abstract InventoryView getBukkitView();
|
|
|
|
+ public void transferTo(Container other, org.bukkit.craftbukkit.entity.CraftHumanEntity player) {
|
|
|
|
+ InventoryView source = this.getBukkitView(), destination = other.getBukkitView();
|
|
|
|
+ ((CraftInventory) source.getTopInventory()).getInventory().onClose(player);
|
|
|
|
+ ((CraftInventory) source.getBottomInventory()).getInventory().onClose(player);
|
|
|
|
+ ((CraftInventory) destination.getTopInventory()).getInventory().onOpen(player);
|
|
|
|
+ ((CraftInventory) destination.getBottomInventory()).getInventory().onOpen(player);
|
|
|
|
+ }
|
2019-04-23 12:00:00 +10:00
|
|
|
+ private IChatBaseComponent title;
|
2019-04-24 10:23:12 +10:00
|
|
|
+ public final IChatBaseComponent getTitle() {
|
2019-04-23 12:00:00 +10:00
|
|
|
+ Preconditions.checkState(this.title != null, "Title not set");
|
|
|
|
+ return this.title;
|
|
|
|
+ }
|
2019-04-24 10:23:12 +10:00
|
|
|
+ public final void setTitle(IChatBaseComponent title) {
|
2019-04-23 12:00:00 +10:00
|
|
|
+ Preconditions.checkState(this.title == null, "Title already set");
|
|
|
|
+ this.title = title;
|
|
|
|
+ }
|
2015-02-26 22:41:06 +00:00
|
|
|
+ // CraftBukkit end
|
|
|
|
+
|
2019-04-23 12:00:00 +10:00
|
|
|
protected Container(@Nullable Containers<?> containers, int i) {
|
2021-06-11 15:00:00 +10:00
|
|
|
this.carried = ItemStack.EMPTY;
|
|
|
|
this.remoteSlots = NonNullList.a();
|
|
|
|
@@ -154,6 +189,15 @@
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
+ // CraftBukkit start
|
|
|
|
+ public void broadcastCarriedItem() {
|
|
|
|
+ this.remoteCarried = this.getCarried().cloneItemStack();
|
|
|
|
+ if (this.synchronizer != null) {
|
|
|
|
+ this.synchronizer.sendCarriedChange(this, this.remoteCarried);
|
|
|
|
+ }
|
|
|
|
+ }
|
|
|
|
+ // CraftBukkit end
|
|
|
|
+
|
|
|
|
public void b(ICrafting icrafting) {
|
|
|
|
this.containerListeners.remove(icrafting);
|
|
|
|
}
|
|
|
|
@@ -349,6 +393,7 @@
|
|
|
|
l = this.getCarried().getCount();
|
|
|
|
Iterator iterator = this.quickcraftSlots.iterator();
|
2014-11-26 08:32:16 +11:00
|
|
|
|
|
|
|
+ Map<Integer, ItemStack> draggedSlots = new HashMap<Integer, ItemStack>(); // CraftBukkit - Store slots from drag in map (raw slot id -> new stack)
|
|
|
|
while (iterator.hasNext()) {
|
|
|
|
Slot slot1 = (Slot) iterator.next();
|
2021-06-11 15:00:00 +10:00
|
|
|
ItemStack itemstack2 = this.getCarried();
|
|
|
|
@@ -365,12 +410,48 @@
|
2014-11-26 08:32:16 +11:00
|
|
|
}
|
|
|
|
|
2021-06-11 15:00:00 +10:00
|
|
|
l -= itemstack3.getCount() - j1;
|
|
|
|
- slot1.set(itemstack3);
|
|
|
|
+ // slot1.set(itemstack3);
|
|
|
|
+ draggedSlots.put(slot1.index, itemstack3); // CraftBukkit - Put in map instead of setting
|
|
|
|
+ }
|
|
|
|
+ }
|
|
|
|
+
|
2014-11-26 08:32:16 +11:00
|
|
|
+ // CraftBukkit start - InventoryDragEvent
|
|
|
|
+ InventoryView view = getBukkitView();
|
2021-06-11 15:00:00 +10:00
|
|
|
+ org.bukkit.inventory.ItemStack newcursor = CraftItemStack.asCraftMirror(itemstack1);
|
|
|
|
+ newcursor.setAmount(l);
|
2014-11-26 08:32:16 +11:00
|
|
|
+ Map<Integer, org.bukkit.inventory.ItemStack> eventmap = new HashMap<Integer, org.bukkit.inventory.ItemStack>();
|
|
|
|
+ for (Map.Entry<Integer, ItemStack> ditem : draggedSlots.entrySet()) {
|
|
|
|
+ eventmap.put(ditem.getKey(), CraftItemStack.asBukkitCopy(ditem.getValue()));
|
|
|
|
+ }
|
2015-02-26 22:41:06 +00:00
|
|
|
+
|
2014-11-26 08:32:16 +11:00
|
|
|
+ // It's essential that we set the cursor to the new value here to prevent item duplication if a plugin closes the inventory.
|
2021-06-11 15:00:00 +10:00
|
|
|
+ ItemStack oldCursor = this.getCarried();
|
|
|
|
+ this.setCarried(CraftItemStack.asNMSCopy(newcursor));
|
2014-11-26 08:32:16 +11:00
|
|
|
+
|
2021-06-11 15:00:00 +10:00
|
|
|
+ InventoryDragEvent event = new InventoryDragEvent(view, (newcursor.getType() != org.bukkit.Material.AIR ? newcursor : null), CraftItemStack.asBukkitCopy(oldCursor), this.quickcraftType == 1, eventmap);
|
2021-06-11 21:33:49 +10:00
|
|
|
+ entityhuman.level.getCraftServer().getPluginManager().callEvent(event);
|
2014-11-26 08:32:16 +11:00
|
|
|
+
|
|
|
|
+ // Whether or not a change was made to the inventory that requires an update.
|
|
|
|
+ boolean needsUpdate = event.getResult() != Result.DEFAULT;
|
|
|
|
+
|
|
|
|
+ if (event.getResult() != Result.DENY) {
|
|
|
|
+ for (Map.Entry<Integer, ItemStack> dslot : draggedSlots.entrySet()) {
|
|
|
|
+ view.setItem(dslot.getKey(), CraftItemStack.asBukkitCopy(dslot.getValue()));
|
|
|
|
+ }
|
|
|
|
+ // The only time the carried item will be set to null is if the inventory is closed by the server.
|
|
|
|
+ // If the inventory is closed by the server, then the cursor items are dropped. This is why we change the cursor early.
|
2021-06-11 15:00:00 +10:00
|
|
|
+ if (this.getCarried() != null) {
|
|
|
|
+ this.setCarried(CraftItemStack.asNMSCopy(event.getCursor()));
|
2014-11-26 08:32:16 +11:00
|
|
|
+ needsUpdate = true;
|
2021-06-11 15:00:00 +10:00
|
|
|
}
|
2014-11-26 08:32:16 +11:00
|
|
|
+ } else {
|
2021-06-11 15:00:00 +10:00
|
|
|
+ this.setCarried(oldCursor);
|
|
|
|
}
|
|
|
|
|
|
|
|
- itemstack1.setCount(l);
|
|
|
|
- this.setCarried(itemstack1);
|
2014-11-26 08:32:16 +11:00
|
|
|
+ if (needsUpdate && entityhuman instanceof EntityPlayer) {
|
2021-06-11 15:00:00 +10:00
|
|
|
+ this.updateInventory();
|
2014-11-26 08:32:16 +11:00
|
|
|
+ }
|
|
|
|
+ // CraftBukkit end
|
|
|
|
}
|
|
|
|
|
2021-06-11 15:00:00 +10:00
|
|
|
this.e();
|
|
|
|
@@ -388,8 +469,11 @@
|
2016-11-20 10:19:22 +11:00
|
|
|
if (i == -999) {
|
2021-06-11 15:00:00 +10:00
|
|
|
if (!this.getCarried().isEmpty()) {
|
|
|
|
if (clickaction == ClickAction.PRIMARY) {
|
|
|
|
- entityhuman.drop(this.getCarried(), true);
|
2016-11-20 10:19:22 +11:00
|
|
|
+ // CraftBukkit start
|
2021-06-11 15:00:00 +10:00
|
|
|
+ ItemStack carried = this.getCarried();
|
|
|
|
this.setCarried(ItemStack.EMPTY);
|
2016-11-20 10:19:22 +11:00
|
|
|
+ entityhuman.drop(carried, true);
|
|
|
|
+ // CraftBukkit start
|
2021-06-11 15:00:00 +10:00
|
|
|
} else {
|
|
|
|
entityhuman.drop(this.getCarried().cloneAndSubtract(1), true);
|
2016-11-20 10:19:22 +11:00
|
|
|
}
|
2021-06-11 15:00:00 +10:00
|
|
|
@@ -452,6 +536,15 @@
|
|
|
|
}
|
2016-11-20 10:19:22 +11:00
|
|
|
|
2021-06-11 15:00:00 +10:00
|
|
|
slot.d();
|
|
|
|
+ // CraftBukkit start - Make sure the client has the right slot contents
|
|
|
|
+ if (entityhuman instanceof EntityPlayer && slot.getMaxStackSize() != 64) {
|
|
|
|
+ ((EntityPlayer) entityhuman).connection.sendPacket(new PacketPlayOutSetSlot(this.containerId, slot.index, slot.getItem()));
|
|
|
|
+ // Updating a crafting inventory makes the client reset the result slot, have to send it again
|
|
|
|
+ if (this.getBukkitView().getType() == InventoryType.WORKBENCH || this.getBukkitView().getType() == InventoryType.CRAFTING) {
|
|
|
|
+ ((EntityPlayer) entityhuman).connection.sendPacket(new PacketPlayOutSetSlot(this.containerId, 0, this.getSlot(0).getItem()));
|
2014-11-26 08:32:16 +11:00
|
|
|
+ }
|
2021-06-11 15:00:00 +10:00
|
|
|
+ }
|
|
|
|
+ // CraftBukkit end
|
2014-11-26 08:32:16 +11:00
|
|
|
}
|
2021-06-11 15:00:00 +10:00
|
|
|
} else {
|
|
|
|
Slot slot2;
|
|
|
|
@@ -556,8 +649,11 @@
|
2018-12-31 10:13:02 +11:00
|
|
|
|
2021-06-11 15:00:00 +10:00
|
|
|
public void b(EntityHuman entityhuman) {
|
|
|
|
if (!this.getCarried().isEmpty()) {
|
|
|
|
- entityhuman.drop(this.getCarried(), false);
|
2018-12-31 10:13:02 +11:00
|
|
|
+ // CraftBukkit start - SPIGOT-4556
|
2021-06-11 15:00:00 +10:00
|
|
|
+ ItemStack carried = this.getCarried();
|
|
|
|
this.setCarried(ItemStack.EMPTY);
|
2018-12-31 10:13:02 +11:00
|
|
|
+ entityhuman.drop(carried, false);
|
|
|
|
+ // CraftBukkit end
|
|
|
|
}
|
|
|
|
|
|
|
|
}
|
2021-06-11 15:00:00 +10:00
|
|
|
@@ -767,6 +863,11 @@
|
|
|
|
}
|
|
|
|
|
|
|
|
public ItemStack getCarried() {
|
|
|
|
+ // CraftBukkit start
|
|
|
|
+ if (this.carried.isEmpty()) {
|
|
|
|
+ this.setCarried(ItemStack.EMPTY);
|
|
|
|
+ }
|
|
|
|
+ // CraftBukkit end
|
|
|
|
return this.carried;
|
|
|
|
}
|
|
|
|
|