SPIGOT-3674: Take into account max stack size for PlayerDropItemEvent

This commit is contained in:
md_5 2017-12-03 08:55:19 +11:00
parent 809c399a62
commit 22564a9177

View File

@ -94,7 +94,7 @@
+ if (flag1 && (cur == null || cur.getAmount() == 0)) { + if (flag1 && (cur == null || cur.getAmount() == 0)) {
+ // The complete stack was dropped + // The complete stack was dropped
+ player.getInventory().setItemInHand(drop.getItemStack()); + player.getInventory().setItemInHand(drop.getItemStack());
+ } else if (flag1 && cur.isSimilar(drop.getItemStack()) && drop.getItemStack().getAmount() == 1) { + } else if (flag1 && cur.isSimilar(drop.getItemStack()) && cur.getAmount() < cur.getMaxStackSize() && drop.getItemStack().getAmount() == 1) {
+ // Only one item is dropped + // Only one item is dropped
+ cur.setAmount(cur.getAmount() + 1); + cur.setAmount(cur.getAmount() + 1);
+ player.getInventory().setItemInHand(cur); + player.getInventory().setItemInHand(cur);