@@ -5,11 +5,24 @@ Subject: [PATCH] Make hoppers respect inventory max stack size
5
5
6
6
7
7
diff --git a/src/main/java/net/minecraft/world/level/block/entity/HopperBlockEntity.java b/src/main/java/net/minecraft/world/level/block/entity/HopperBlockEntity.java
8
- index 08c4a0996410a42418d4a5da3ed1f4db2f171dd2..d41851f9119c334cae3fc2c433d6450a3eed9096 100644
8
+ index 08c4a0996410a42418d4a5da3ed1f4db2f171dd2..4950d49ed414e1c82c125b9347113f595f1078b6 100644
9
9
--- a/src/main/java/net/minecraft/world/level/block/entity/HopperBlockEntity.java
10
10
+++ b/src/main/java/net/minecraft/world/level/block/entity/HopperBlockEntity.java
11
- @@ -599,7 +599,7 @@ public class HopperBlockEntity extends RandomizableContainerBlockEntity implemen
12
- stack = ItemStack.EMPTY;
11
+ @@ -589,17 +589,19 @@ public class HopperBlockEntity extends RandomizableContainerBlockEntity implemen
12
+
13
+ if (itemstack1.isEmpty()) {
14
+ // Spigot start - SPIGOT-6693, InventorySubcontainer#setItem
15
+ + ItemStack leftover = ItemStack.EMPTY; // Paper
16
+ if (!stack.isEmpty() && stack.getCount() > to.getMaxStackSize()) {
17
+ + leftover = stack; // Paper
18
+ stack = stack.split(to.getMaxStackSize());
19
+ }
20
+ // Spigot end
21
+ IGNORE_TILE_UPDATES = true; // Paper
22
+ to.setItem(slot, stack);
23
+ IGNORE_TILE_UPDATES = false; // Paper
24
+ - stack = ItemStack.EMPTY;
25
+ + stack = leftover; // Paper
13
26
flag = true;
14
27
} else if (HopperBlockEntity.canMergeItems(itemstack1, stack)) {
15
28
- int j = stack.getMaxStackSize() - itemstack1.getCount();
0 commit comments