2023-03-04 23:57:02 +01:00
|
|
|
From 0000000000000000000000000000000000000000 Mon Sep 17 00:00:00 2001
|
|
|
|
From: Jake Potrebic <jake.m.potrebic@gmail.com>
|
|
|
|
Date: Sun, 10 Oct 2021 18:18:01 -0700
|
|
|
|
Subject: [PATCH] Fix HumanEntity#drop not updating the client inv
|
|
|
|
|
|
|
|
== AT ==
|
|
|
|
public net.minecraft.server.level.ServerPlayer containerSynchronizer
|
|
|
|
|
|
|
|
diff --git a/src/main/java/org/bukkit/craftbukkit/entity/CraftHumanEntity.java b/src/main/java/org/bukkit/craftbukkit/entity/CraftHumanEntity.java
|
2023-08-14 01:32:51 +02:00
|
|
|
index 50f2a94c5f2e9f7c08cea137d8d84d65e2c41326..5fe9a0985432ac6cdd28a2a138854a24f10e42ba 100644
|
2023-03-04 23:57:02 +01:00
|
|
|
--- a/src/main/java/org/bukkit/craftbukkit/entity/CraftHumanEntity.java
|
|
|
|
+++ b/src/main/java/org/bukkit/craftbukkit/entity/CraftHumanEntity.java
|
2023-06-13 01:51:45 +02:00
|
|
|
@@ -755,8 +755,15 @@ public class CraftHumanEntity extends CraftLivingEntity implements HumanEntity {
|
2023-03-04 23:57:02 +01:00
|
|
|
// Paper end
|
|
|
|
@Override
|
|
|
|
public boolean dropItem(boolean dropAll) {
|
|
|
|
- if (!(this.getHandle() instanceof ServerPlayer)) return false;
|
|
|
|
- return ((ServerPlayer) this.getHandle()).drop(dropAll);
|
|
|
|
+ // Paper start - notify client of remote slot change
|
|
|
|
+ if (!(this.getHandle() instanceof ServerPlayer player)) return false;
|
|
|
|
+ boolean success = player.drop(dropAll);
|
|
|
|
+ if (!success) return false;
|
|
|
|
+ final net.minecraft.world.entity.player.Inventory inv = player.getInventory();
|
|
|
|
+ final java.util.OptionalInt optionalSlot = player.containerMenu.findSlot(inv, inv.selected);
|
|
|
|
+ optionalSlot.ifPresent(slot -> player.containerSynchronizer.sendSlotChange(player.containerMenu, slot, inv.getSelected()));
|
|
|
|
+ return true;
|
|
|
|
+ // Paper end
|
|
|
|
}
|
|
|
|
|
|
|
|
@Override
|