aboutsummaryrefslogtreecommitdiffhomepage
path: root/patches/server/0568-Fix-PlayerDropItemEvent-using-wrong-item.patch
diff options
context:
space:
mode:
Diffstat (limited to 'patches/server/0568-Fix-PlayerDropItemEvent-using-wrong-item.patch')
-rw-r--r--patches/server/0568-Fix-PlayerDropItemEvent-using-wrong-item.patch61
1 files changed, 61 insertions, 0 deletions
diff --git a/patches/server/0568-Fix-PlayerDropItemEvent-using-wrong-item.patch b/patches/server/0568-Fix-PlayerDropItemEvent-using-wrong-item.patch
new file mode 100644
index 0000000000..9646d27bb6
--- /dev/null
+++ b/patches/server/0568-Fix-PlayerDropItemEvent-using-wrong-item.patch
@@ -0,0 +1,61 @@
+From 0000000000000000000000000000000000000000 Mon Sep 17 00:00:00 2001
+From: Spottedleaf <[email protected]>
+Date: Sun, 20 Jun 2021 21:55:59 -0700
+Subject: [PATCH] Fix PlayerDropItemEvent using wrong item
+
+
+diff --git a/src/main/java/net/minecraft/server/commands/GiveCommand.java b/src/main/java/net/minecraft/server/commands/GiveCommand.java
+index c81fd3e1108fb0a02f9240263404af2b968c8494..0d9de4c61c7b26a6ff37c12fde629161fd0c3d5a 100644
+--- a/src/main/java/net/minecraft/server/commands/GiveCommand.java
++++ b/src/main/java/net/minecraft/server/commands/GiveCommand.java
+@@ -38,6 +38,7 @@ public class GiveCommand {
+
+ private static int giveItem(CommandSourceStack source, ItemInput item, Collection<ServerPlayer> targets, int count) throws CommandSyntaxException {
+ ItemStack itemstack = item.createItemStack(1, false);
++ final Component displayName = itemstack.getDisplayName(); // Paper - get display name early
+ int j = itemstack.getMaxStackSize();
+ int k = j * 100;
+
+@@ -79,11 +80,11 @@ public class GiveCommand {
+
+ if (targets.size() == 1) {
+ source.sendSuccess(() -> {
+- return Component.translatable("commands.give.success.single", count, itemstack.getDisplayName(), ((ServerPlayer) targets.iterator().next()).getDisplayName());
++ return Component.translatable("commands.give.success.single", count, displayName, ((ServerPlayer) targets.iterator().next()).getDisplayName()); // Paper - use cached display name
+ }, true);
+ } else {
+ source.sendSuccess(() -> {
+- return Component.translatable("commands.give.success.single", count, itemstack.getDisplayName(), targets.size());
++ return Component.translatable("commands.give.success.single", count, displayName, targets.size()); // Paper - use cached display name
+ }, true);
+ }
+
+diff --git a/src/main/java/net/minecraft/server/level/ServerPlayer.java b/src/main/java/net/minecraft/server/level/ServerPlayer.java
+index 2ff11c9aff04f404d45e0b267285e2b4a2a23b6f..b342516707448ab5f0f1e763bf6be3f004b9e4b4 100644
+--- a/src/main/java/net/minecraft/server/level/ServerPlayer.java
++++ b/src/main/java/net/minecraft/server/level/ServerPlayer.java
+@@ -2434,7 +2434,7 @@ public class ServerPlayer extends Player {
+
+ if (retainOwnership) {
+ if (!itemstack1.isEmpty()) {
+- this.awardStat(Stats.ITEM_DROPPED.get(itemstack1.getItem()), stack.getCount());
++ this.awardStat(Stats.ITEM_DROPPED.get(itemstack1.getItem()), itemstack1.getCount()); // Paper - Fix PlayerDropItemEvent using wrong item
+ }
+
+ this.awardStat(Stats.DROP);
+diff --git a/src/main/java/net/minecraft/world/entity/player/Player.java b/src/main/java/net/minecraft/world/entity/player/Player.java
+index b7c674505c2319c906a0cce53e0def2337b24d42..5019b9f257382f15aa333a8d421915a7a3afe991 100644
+--- a/src/main/java/net/minecraft/world/entity/player/Player.java
++++ b/src/main/java/net/minecraft/world/entity/player/Player.java
+@@ -726,6 +726,11 @@ public abstract class Player extends LivingEntity {
+ }
+
+ double d0 = this.getEyeY() - 0.30000001192092896D;
++ // Paper start
++ ItemStack tmp = itemstack.copy();
++ itemstack.setCount(0);
++ itemstack = tmp;
++ // Paper end
+ ItemEntity entityitem = new ItemEntity(this.level(), this.getX(), d0, this.getZ(), itemstack);
+
+ entityitem.setPickUpDelay(40);