From 24d01b6267a495d76615f58478ce586eef99e65c Mon Sep 17 00:00:00 2001 From: RecursivePineapple Date: Sun, 1 Dec 2024 10:11:56 -0500 Subject: [PATCH] Split FixHandleSetSlot into container & inv (#444) --- ...NetHandlerPlayClient_FixHandleSetSlot.java | 23 +++++++++++++------ 1 file changed, 16 insertions(+), 7 deletions(-) diff --git a/src/main/java/com/mitchej123/hodgepodge/mixins/early/minecraft/MixinNetHandlerPlayClient_FixHandleSetSlot.java b/src/main/java/com/mitchej123/hodgepodge/mixins/early/minecraft/MixinNetHandlerPlayClient_FixHandleSetSlot.java index 82699555..e67a512a 100644 --- a/src/main/java/com/mitchej123/hodgepodge/mixins/early/minecraft/MixinNetHandlerPlayClient_FixHandleSetSlot.java +++ b/src/main/java/com/mitchej123/hodgepodge/mixins/early/minecraft/MixinNetHandlerPlayClient_FixHandleSetSlot.java @@ -17,18 +17,27 @@ public class MixinNetHandlerPlayClient_FixHandleSetSlot { @Inject( locals = LocalCapture.CAPTURE_FAILSOFT, method = "handleSetSlot(Lnet/minecraft/network/play/server/S2FPacketSetSlot;)V", - at = { @At( + at = @At( opcode = Opcodes.GETFIELD, ordinal = 1, target = "Lnet/minecraft/client/entity/EntityClientPlayerMP;inventoryContainer:Lnet/minecraft/inventory/Container;", value = "FIELD"), - @At( - opcode = Opcodes.GETFIELD, - ordinal = 1, - target = "Lnet/minecraft/client/entity/EntityClientPlayerMP;openContainer:Lnet/minecraft/inventory/Container;", - value = "FIELD") }, cancellable = true) - public void hodgepodge$checkPacketItemStackSize(S2FPacketSetSlot packetIn, CallbackInfo ci, + public void hodgepodge$checkPacketItemStackSizeInventory(S2FPacketSetSlot packetIn, CallbackInfo ci, + EntityClientPlayerMP entityclientplayermp) { + if (packetIn.func_149173_d() >= entityclientplayermp.inventoryContainer.inventorySlots.size()) ci.cancel(); + } + + @Inject( + locals = LocalCapture.CAPTURE_FAILSOFT, + method = "handleSetSlot(Lnet/minecraft/network/play/server/S2FPacketSetSlot;)V", + at = @At( + opcode = Opcodes.GETFIELD, + ordinal = 1, + target = "Lnet/minecraft/client/entity/EntityClientPlayerMP;openContainer:Lnet/minecraft/inventory/Container;", + value = "FIELD"), + cancellable = true) + public void hodgepodge$checkPacketItemStackSizeContainer(S2FPacketSetSlot packetIn, CallbackInfo ci, EntityClientPlayerMP entityclientplayermp) { if (packetIn.func_149173_d() >= entityclientplayermp.openContainer.inventorySlots.size()) ci.cancel(); }