Fix Inventory#addItem not respecting max stack size

By: md_5 <git@md-5.net>
This commit is contained in:
CraftBukkit/Spigot 2024-11-24 11:06:35 +11:00
parent f642133483
commit 4992aa1b5d

View file

@ -255,19 +255,6 @@ public class CraftInventory implements Inventory {
return inventory.isEmpty(); return inventory.isEmpty();
} }
public int firstPartial(Material material) {
Preconditions.checkArgument(material != null, "Material cannot be null");
material = CraftLegacy.fromLegacy(material);
ItemStack[] inventory = getStorageContents();
for (int i = 0; i < inventory.length; i++) {
ItemStack item = inventory[i];
if (item != null && item.getType() == material && item.getAmount() < item.getMaxStackSize()) {
return i;
}
}
return -1;
}
private int firstPartial(ItemStack item) { private int firstPartial(ItemStack item) {
ItemStack[] inventory = getStorageContents(); ItemStack[] inventory = getStorageContents();
ItemStack filteredItem = CraftItemStack.asCraftCopy(item); ItemStack filteredItem = CraftItemStack.asCraftCopy(item);
@ -276,7 +263,7 @@ public class CraftInventory implements Inventory {
} }
for (int i = 0; i < inventory.length; i++) { for (int i = 0; i < inventory.length; i++) {
ItemStack cItem = inventory[i]; ItemStack cItem = inventory[i];
if (cItem != null && cItem.getAmount() < cItem.getMaxStackSize() && cItem.isSimilar(filteredItem)) { if (cItem != null && cItem.getAmount() < getMaxItemStack(cItem) && cItem.isSimilar(filteredItem)) {
return i; return i;
} }
} }
@ -312,11 +299,12 @@ public class CraftInventory implements Inventory {
break; break;
} else { } else {
// More than a single stack! // More than a single stack!
if (item.getAmount() > getMaxItemStack()) { int maxAmount = getMaxItemStack(item);
if (item.getAmount() > maxAmount) {
CraftItemStack stack = CraftItemStack.asCraftCopy(item); CraftItemStack stack = CraftItemStack.asCraftCopy(item);
stack.setAmount(getMaxItemStack()); stack.setAmount(maxAmount);
setItem(firstFree, stack); setItem(firstFree, stack);
item.setAmount(item.getAmount() - getMaxItemStack()); item.setAmount(item.getAmount() - maxAmount);
} else { } else {
// Just store it // Just store it
setItem(firstFree, item); setItem(firstFree, item);
@ -329,7 +317,7 @@ public class CraftInventory implements Inventory {
int amount = item.getAmount(); int amount = item.getAmount();
int partialAmount = partialItem.getAmount(); int partialAmount = partialItem.getAmount();
int maxAmount = partialItem.getMaxStackSize(); int maxAmount = getMaxItemStack(partialItem);
// Check if it fully fits // Check if it fully fits
if (amount + partialAmount <= maxAmount) { if (amount + partialAmount <= maxAmount) {
@ -395,8 +383,8 @@ public class CraftInventory implements Inventory {
return leftover; return leftover;
} }
private int getMaxItemStack() { private int getMaxItemStack(ItemStack itemstack) {
return getInventory().getMaxStackSize(); return Math.min(itemstack.getMaxStackSize(), getInventory().getMaxStackSize());
} }
@Override @Override