From 9aa9b8775aa00eb14d3d6b4010f4d2ec2c875f77 Mon Sep 17 00:00:00 2001 From: CraftBukkit/Spigot Date: Mon, 17 Dec 2012 16:32:52 -0600 Subject: [PATCH] Clarify functionality in CraftInventory. Fixes BUKKIT-3097 Changes some NPEs to IllegalArgumentExceptions for exception consistency. Contains(ItemStack, int) correctly calculates number of ItemStacks. Adds a containsAtLeast(ItemStack, int) for finding a combined amount of a single similar ItemStack. Makes some utility methods private to prevent ambiguity in use. By: Wesley Wolfe --- .../craftbukkit/inventory/CraftInventory.java | 48 +++++++++++++++---- 1 file changed, 39 insertions(+), 9 deletions(-) diff --git a/paper-server/src/main/java/org/bukkit/craftbukkit/inventory/CraftInventory.java b/paper-server/src/main/java/org/bukkit/craftbukkit/inventory/CraftInventory.java index 537a479ad5..7342179d6b 100644 --- a/paper-server/src/main/java/org/bukkit/craftbukkit/inventory/CraftInventory.java +++ b/paper-server/src/main/java/org/bukkit/craftbukkit/inventory/CraftInventory.java @@ -16,6 +16,7 @@ import net.minecraft.server.TileEntityBrewingStand; import net.minecraft.server.TileEntityDispenser; import net.minecraft.server.TileEntityFurnace; +import org.apache.commons.lang.Validate; import org.bukkit.entity.HumanEntity; import org.bukkit.event.inventory.InventoryType; import org.bukkit.inventory.Inventory; @@ -88,6 +89,7 @@ public class CraftInventory implements Inventory { } public boolean contains(Material material) { + Validate.notNull(material, "Material cannot be null"); return contains(material.getId()); } @@ -104,16 +106,21 @@ public class CraftInventory implements Inventory { } public boolean contains(int materialId, int amount) { - int amt = 0; + if (amount <= 0) { + return true; + } for (ItemStack item : getContents()) { if (item != null && item.getTypeId() == materialId) { - amt += item.getAmount(); + if ((amount -= item.getAmount()) <= 0) { + return true; + } } } - return amt >= amount; + return false; } public boolean contains(Material material, int amount) { + Validate.notNull(material, "Material cannot be null"); return contains(material.getId(), amount); } @@ -121,13 +128,30 @@ public class CraftInventory implements Inventory { if (item == null) { return false; } - int amt = 0; + if (amount <= 0) { + return true; + } for (ItemStack i : getContents()) { - if (item.equals(i)) { - amt += item.getAmount(); + if (item.equals(i) && --amount <= 0) { + return true; } } - return amt >= amount; + return false; + } + + public boolean containsAtLeast(ItemStack item, int amount) { + if (item == null) { + return false; + } + if (amount <= 0) { + return true; + } + for (ItemStack i : getContents()) { + if (i != null && item.getTypeId() == i.getTypeId() && item.getDurability() == i.getDurability() && item.getEnchantments().equals(i.getEnchantments()) && (amount -= i.getAmount()) <= 0) { + return true; + } + } + return false; } public HashMap all(int materialId) { @@ -144,6 +168,7 @@ public class CraftInventory implements Inventory { } public HashMap all(Material material) { + Validate.notNull(material, "Material cannot be null"); return all(material.getId()); } @@ -172,6 +197,7 @@ public class CraftInventory implements Inventory { } public int first(Material material) { + Validate.notNull(material, "Material cannot be null"); return first(material.getId()); } @@ -179,7 +205,7 @@ public class CraftInventory implements Inventory { return first(item, true); } - public int first(ItemStack item, boolean withAmount) { + private int first(ItemStack item, boolean withAmount) { if (item == null) { return -1; } @@ -224,10 +250,11 @@ public class CraftInventory implements Inventory { } public int firstPartial(Material material) { + Validate.notNull(material, "Material cannot be null"); return firstPartial(material.getId()); } - public int firstPartial(ItemStack item) { + private int firstPartial(ItemStack item) { ItemStack[] inventory = getContents(); ItemStack filteredItem = CraftItemStack.asCraftCopy(item); if (item == null) { @@ -243,6 +270,7 @@ public class CraftInventory implements Inventory { } public HashMap addItem(ItemStack... items) { + Validate.noNullElements(items, "Item cannot be null"); HashMap leftover = new HashMap(); /* TODO: some optimization @@ -302,6 +330,7 @@ public class CraftInventory implements Inventory { } public HashMap removeItem(ItemStack... items) { + Validate.notNull(items, "Items cannot be null"); HashMap leftover = new HashMap(); // TODO: optimization @@ -357,6 +386,7 @@ public class CraftInventory implements Inventory { } public void remove(Material material) { + Validate.notNull(material, "Material cannot be null"); remove(material.getId()); }