diff --git a/paper-api/src/main/java/org/bukkit/entity/HumanEntity.java b/paper-api/src/main/java/org/bukkit/entity/HumanEntity.java index 91cc11b5f0..f275331ac1 100644 --- a/paper-api/src/main/java/org/bukkit/entity/HumanEntity.java +++ b/paper-api/src/main/java/org/bukkit/entity/HumanEntity.java @@ -2,10 +2,12 @@ package org.bukkit.entity; import java.util.Collection; import java.util.Set; +import java.util.UUID; import org.bukkit.GameMode; import org.bukkit.Location; import org.bukkit.Material; import org.bukkit.NamespacedKey; +import org.bukkit.inventory.EquipmentSlot; import org.bukkit.inventory.Inventory; import org.bukkit.inventory.InventoryHolder; import org.bukkit.inventory.InventoryView; @@ -706,7 +708,6 @@ public interface HumanEntity extends LivingEntity, AnimalTamer, InventoryHolder */ public boolean dropItem(boolean dropAll); - // Paper start - Extend HumanEntity#dropItem API /** * Makes the entity drop the first declared {@link ItemStack} occurrence in the inventory * @@ -720,17 +721,17 @@ public interface HumanEntity extends LivingEntity, AnimalTamer, InventoryHolder /** * Makes the entity drop an item from their inventory based on the specified ItemStack. * <br> - * This method calls {@link HumanEntity#dropItem(int slot, java.util.UUID thrower, boolean throwRandomly)} + * This method calls {@link HumanEntity#dropItem(int slot, UUID thrower, boolean throwRandomly)} * with the first {@link ItemStack} occurrence in the inventory * * @param itemStack The ItemStack to drop - * @param thrower The {@link java.util.UUID} to set the resulting {@link Item}'s thrower to + * @param thrower The {@link UUID} to set the resulting {@link Item}'s thrower to * @param throwRandomly Whether the item should disperse randomly. * This means that instead of the item being dropped where the player is currently looking, * it instead throws it in any direction, similar to how items drop after a player's death. * @return The dropped item, or null if the action was unsuccessful */ - public @Nullable Item dropItem(final @NotNull ItemStack itemStack, final @Nullable java.util.UUID thrower, final boolean throwRandomly); + public @Nullable Item dropItem(final @NotNull ItemStack itemStack, final @Nullable UUID thrower, final boolean throwRandomly); /** * Makes the entity drop an item from their inventory based on the slot. @@ -747,22 +748,22 @@ public interface HumanEntity extends LivingEntity, AnimalTamer, InventoryHolder * Makes the entity drop an item from their inventory based on the slot. * * @param slot The slot to drop - * @param thrower The {@link java.util.UUID} to set the resulting {@link Item}'s thrower to + * @param thrower The {@link UUID} to set the resulting {@link Item}'s thrower to * @param throwRandomly Whether the item should disperse randomly. * This means that instead of the item being dropped where the player is currently looking, * it instead throws it in any direction, similar to how items drop after a player's death. * @return The dropped item entity, or null if the action was unsuccessful * @throws IndexOutOfBoundsException If the slot is negative or bigger than the player's inventory */ - public @Nullable Item dropItem(final int slot, final @Nullable java.util.UUID thrower, final boolean throwRandomly); + public @Nullable Item dropItem(final int slot, final @Nullable UUID thrower, final boolean throwRandomly); /** - * Makes the entity drop an item from their inventory based on the {@link org.bukkit.inventory.EquipmentSlot} + * Makes the entity drop an item from their inventory based on the {@link EquipmentSlot} * * @param slot The equipment slot to drop * @return The dropped item entity, or null if the action was unsuccessful */ - public default @Nullable Item dropItem(final @NotNull org.bukkit.inventory.EquipmentSlot slot) { + public default @Nullable Item dropItem(final @NotNull EquipmentSlot slot) { return this.dropItem(slot, null, false); } @@ -770,14 +771,14 @@ public interface HumanEntity extends LivingEntity, AnimalTamer, InventoryHolder * Makes the player drop an item from their inventory based on the equipment slot. * * @param slot The equipment slot to drop - * @param thrower The {@link java.util.UUID} to set the resulting {@link Item}'s thrower to + * @param thrower The {@link UUID} to set the resulting {@link Item}'s thrower to * @param throwRandomly Whether the item should disperse randomly. * This means that instead of the item being dropped where the player is currently looking, * it instead throws it in any direction, similar to how items drop after a player's death. * @return The dropped item entity, or null if the action was unsuccessful */ - public @Nullable Item dropItem(final @NotNull org.bukkit.inventory.EquipmentSlot slot, final @Nullable java.util.UUID thrower, final boolean throwRandomly); - // Paper end + public @Nullable Item dropItem(final @NotNull EquipmentSlot slot, final @Nullable UUID thrower, final boolean throwRandomly); + /** * Gets the players current exhaustion level. diff --git a/paper-server/src/main/java/org/bukkit/craftbukkit/entity/CraftHumanEntity.java b/paper-server/src/main/java/org/bukkit/craftbukkit/entity/CraftHumanEntity.java index a43845e0f9..35350604ae 100644 --- a/paper-server/src/main/java/org/bukkit/craftbukkit/entity/CraftHumanEntity.java +++ b/paper-server/src/main/java/org/bukkit/craftbukkit/entity/CraftHumanEntity.java @@ -803,7 +803,6 @@ public class CraftHumanEntity extends CraftLivingEntity implements HumanEntity { // Paper end - Fix HumanEntity#drop not updating the client inv } - // Paper start - Extend HumanEntity#dropItem API @Override public @Nullable org.bukkit.entity.Item dropItem(final @NotNull ItemStack itemStack, final @Nullable java.util.UUID thrower, final boolean throwRandomly) { final int slot = this.inventory.first(itemStack); @@ -817,7 +816,7 @@ public class CraftHumanEntity extends CraftLivingEntity implements HumanEntity { @Override public @Nullable org.bukkit.entity.Item dropItem(final int slot, final @Nullable java.util.UUID thrower, final boolean throwRandomly) { // Make sure the slot is in bounds - if (slot < 0 || this.inventory.getSize() <= slot) { + if (slot < 0 || slot >= this.inventory.getSize()) { throw new IndexOutOfBoundsException("Slot " + slot + " out of range for inventory of size " + this.inventory.getSize()); } @@ -838,7 +837,7 @@ public class CraftHumanEntity extends CraftLivingEntity implements HumanEntity { } private org.bukkit.entity.Item dropItemRaw(final ItemStack is, final @Nullable java.util.UUID thrower, final boolean throwRandomly) { - if (is == null || is.getType() == Material.AIR) { + if (is == null || is.isEmpty()) { return null; }