aboutsummaryrefslogtreecommitdiffhomepage
path: root/patches/server/0982-Deprecate-InvAction-HOTBAR_MOVE_AND_READD.patch
diff options
context:
space:
mode:
Diffstat (limited to 'patches/server/0982-Deprecate-InvAction-HOTBAR_MOVE_AND_READD.patch')
-rw-r--r--patches/server/0982-Deprecate-InvAction-HOTBAR_MOVE_AND_READD.patch26
1 files changed, 26 insertions, 0 deletions
diff --git a/patches/server/0982-Deprecate-InvAction-HOTBAR_MOVE_AND_READD.patch b/patches/server/0982-Deprecate-InvAction-HOTBAR_MOVE_AND_READD.patch
new file mode 100644
index 0000000000..1af38ab7e6
--- /dev/null
+++ b/patches/server/0982-Deprecate-InvAction-HOTBAR_MOVE_AND_READD.patch
@@ -0,0 +1,26 @@
+From 0000000000000000000000000000000000000000 Mon Sep 17 00:00:00 2001
+From: Jake Potrebic <[email protected]>
+Date: Sat, 25 May 2024 09:51:13 -0700
+Subject: [PATCH] Deprecate InvAction#HOTBAR_MOVE_AND_READD
+
+
+diff --git a/src/main/java/net/minecraft/server/network/ServerGamePacketListenerImpl.java b/src/main/java/net/minecraft/server/network/ServerGamePacketListenerImpl.java
+index a0f5839719ca0ce6ed048229f074041b4f64cc97..a8debfad8c8e66099f8a9aedc6f1971a8576dade 100644
+--- a/src/main/java/net/minecraft/server/network/ServerGamePacketListenerImpl.java
++++ b/src/main/java/net/minecraft/server/network/ServerGamePacketListenerImpl.java
+@@ -2998,14 +2998,7 @@ public class ServerGamePacketListenerImpl extends ServerCommonPacketListenerImpl
+ Slot clickedSlot = this.player.containerMenu.getSlot(packet.getSlotNum());
+ if (clickedSlot.mayPickup(this.player)) {
+ ItemStack hotbar = this.player.getInventory().getItem(packet.getButtonNum());
+- boolean canCleanSwap = hotbar.isEmpty() || (clickedSlot.container == this.player.getInventory() && clickedSlot.mayPlace(hotbar)); // the slot will accept the hotbar item
+- if (clickedSlot.hasItem()) {
+- if (canCleanSwap) {
+- action = InventoryAction.HOTBAR_SWAP;
+- } else {
+- action = InventoryAction.HOTBAR_MOVE_AND_READD;
+- }
+- } else if (!clickedSlot.hasItem() && !hotbar.isEmpty() && clickedSlot.mayPlace(hotbar)) {
++ if ((!hotbar.isEmpty() && clickedSlot.mayPlace(hotbar)) || (hotbar.isEmpty() && clickedSlot.hasItem())) { // Paper - modernify this logic (no such thing as a "hotbar move and readd"
+ action = InventoryAction.HOTBAR_SWAP;
+ } else {
+ action = InventoryAction.NOTHING;