From 1a46f07e1112c3a81b5fe4bfd9dba6fabd16f108 Mon Sep 17 00:00:00 2001 From: Moulberry Date: Sun, 17 Nov 2024 00:18:55 +0800 Subject: [PATCH] Don't fire block place event for non-replaceable blocks --- .../packet/impl/SetBlockPacketListener.java | 31 +++++++++++-------- 1 file changed, 18 insertions(+), 13 deletions(-) diff --git a/src/main/java/com/moulberry/axiom/packet/impl/SetBlockPacketListener.java b/src/main/java/com/moulberry/axiom/packet/impl/SetBlockPacketListener.java index 01965ab..cf864a9 100644 --- a/src/main/java/com/moulberry/axiom/packet/impl/SetBlockPacketListener.java +++ b/src/main/java/com/moulberry/axiom/packet/impl/SetBlockPacketListener.java @@ -136,21 +136,26 @@ public void onReceive(Player bukkitPlayer, FriendlyByteBuf friendlyByteBuf) { List blockStates = new ArrayList<>(); World world = player.serverLevel().getWorld(); for (Map.Entry entry : blocks.entrySet()) { - blockStates.add(new AxiomPlacingCraftBlockState(world, entry.getKey(), entry.getValue())); + BlockState existing = player.serverLevel().getBlockState(entry.getKey()); + if (existing.canBeReplaced()) { + blockStates.add(new AxiomPlacingCraftBlockState(world, entry.getKey(), entry.getValue())); + } } - Cancellable event = null; - if (blockStates.size() > 1) { - event = CraftEventFactory.callBlockMultiPlaceEvent(player.serverLevel(), - player, hand, blockStates, blockHit.getBlockPos().getX(), - blockHit.getBlockPos().getY(), blockHit.getBlockPos().getZ()); - } else if (blockStates.size() == 1) { - event = CraftEventFactory.callBlockPlaceEvent(player.serverLevel(), - player, hand, blockStates.get(0), blockHit.getBlockPos().getX(), - blockHit.getBlockPos().getY(), blockHit.getBlockPos().getZ()); - } - if (event != null && event.isCancelled()) { - return; + if (!blockStates.isEmpty()) { + Cancellable event; + if (blockStates.size() > 1) { + event = CraftEventFactory.callBlockMultiPlaceEvent(player.serverLevel(), + player, hand, blockStates, blockHit.getBlockPos().getX(), + blockHit.getBlockPos().getY(), blockHit.getBlockPos().getZ()); + } else { + event = CraftEventFactory.callBlockPlaceEvent(player.serverLevel(), + player, hand, blockStates.get(0), blockHit.getBlockPos().getX(), + blockHit.getBlockPos().getY(), blockHit.getBlockPos().getZ()); + } + if (event.isCancelled()) { + return; + } } }