mirror of
https://github.com/PaperMC/Paper.git
synced 2025-01-28 11:11:34 +01:00
Prevent overfilled bundles from duplicating items (#9633)
Bundles compute the amount to remove from an item based on the formula (64 - currentWeight) / itemWeight. An overfilled bundle however, with a currentWeight of > 64 ends up with a negative removal amount for the item. This can cause duplication issues on craftbukkit inventory implementations as they do currently not gracefully handle negative removal amounts in their remove methods.
This commit is contained in:
parent
a92fdba593
commit
60d2ea03ad
@ -54,6 +54,9 @@ https://bugs.mojang.com/browse/MC-264285
|
|||||||
https://bugs.mojang.com/browse/MC-84789
|
https://bugs.mojang.com/browse/MC-84789
|
||||||
Fix wild wolves not considering bones interesting
|
Fix wild wolves not considering bones interesting
|
||||||
|
|
||||||
|
https://bugs.mojang.com/browse/MC-225381
|
||||||
|
Fix overfilled bundles duplicating items / being filled with air
|
||||||
|
|
||||||
Co-authored-by: William Blake Galbreath <blake.galbreath@gmail.com>
|
Co-authored-by: William Blake Galbreath <blake.galbreath@gmail.com>
|
||||||
|
|
||||||
diff --git a/src/main/java/net/minecraft/core/dispenser/DispenseItemBehavior.java b/src/main/java/net/minecraft/core/dispenser/DispenseItemBehavior.java
|
diff --git a/src/main/java/net/minecraft/core/dispenser/DispenseItemBehavior.java b/src/main/java/net/minecraft/core/dispenser/DispenseItemBehavior.java
|
||||||
@ -316,6 +319,28 @@ index 0000000000000000000000000000000000000000..00000000000000000000000000000000
|
|||||||
if (!raid.hasFirstWaveSpawned()) {
|
if (!raid.hasFirstWaveSpawned()) {
|
||||||
player.awardStat(Stats.RAID_TRIGGER);
|
player.awardStat(Stats.RAID_TRIGGER);
|
||||||
CriteriaTriggers.BAD_OMEN.trigger(player);
|
CriteriaTriggers.BAD_OMEN.trigger(player);
|
||||||
|
diff --git a/src/main/java/net/minecraft/world/item/BundleItem.java b/src/main/java/net/minecraft/world/item/BundleItem.java
|
||||||
|
index 0000000000000000000000000000000000000000..0000000000000000000000000000000000000000 100644
|
||||||
|
--- a/src/main/java/net/minecraft/world/item/BundleItem.java
|
||||||
|
+++ b/src/main/java/net/minecraft/world/item/BundleItem.java
|
||||||
|
@@ -0,0 +0,0 @@ public class BundleItem extends Item {
|
||||||
|
});
|
||||||
|
} else if (itemStack.getItem().canFitInsideContainerItems()) {
|
||||||
|
int i = (64 - getContentWeight(stack)) / getWeight(itemStack);
|
||||||
|
- int j = add(stack, slot.safeTake(itemStack.getCount(), i, player));
|
||||||
|
+ int j = add(stack, slot.safeTake(itemStack.getCount(), Math.max(0, i), player)); // Paper - prevent item addition on overfilled bundles - safeTake will yield EMPTY for amount == 0.
|
||||||
|
if (j > 0) {
|
||||||
|
this.playInsertSound(player);
|
||||||
|
}
|
||||||
|
@@ -0,0 +0,0 @@ public class BundleItem extends Item {
|
||||||
|
int i = getContentWeight(bundle);
|
||||||
|
int j = getWeight(stack);
|
||||||
|
int k = Math.min(stack.getCount(), (64 - i) / j);
|
||||||
|
- if (k == 0) {
|
||||||
|
+ if (k <= 0) { // Paper - prevent item addition on overfilled bundles
|
||||||
|
return 0;
|
||||||
|
} else {
|
||||||
|
ListTag listTag = compoundTag.getList("Items", 10);
|
||||||
diff --git a/src/main/java/net/minecraft/world/item/SaddleItem.java b/src/main/java/net/minecraft/world/item/SaddleItem.java
|
diff --git a/src/main/java/net/minecraft/world/item/SaddleItem.java b/src/main/java/net/minecraft/world/item/SaddleItem.java
|
||||||
index 0000000000000000000000000000000000000000..0000000000000000000000000000000000000000 100644
|
index 0000000000000000000000000000000000000000..0000000000000000000000000000000000000000 100644
|
||||||
--- a/src/main/java/net/minecraft/world/item/SaddleItem.java
|
--- a/src/main/java/net/minecraft/world/item/SaddleItem.java
|
||||||
|
Loading…
Reference in New Issue
Block a user