From d9f0444df05d2dece6db574620b87b73296ff794 Mon Sep 17 00:00:00 2001 From: Aria Sangarin Date: Thu, 6 Feb 2020 08:32:14 +0100 Subject: [PATCH] Pushing placed blocks with pistons no longer makes them give exp again --- .../mmocore/listener/BlockListener.java | 28 +++++++++++++++++++ 1 file changed, 28 insertions(+) diff --git a/src/main/java/net/Indyuce/mmocore/listener/BlockListener.java b/src/main/java/net/Indyuce/mmocore/listener/BlockListener.java index 93f03ce7..8fb16ba4 100644 --- a/src/main/java/net/Indyuce/mmocore/listener/BlockListener.java +++ b/src/main/java/net/Indyuce/mmocore/listener/BlockListener.java @@ -11,6 +11,8 @@ import org.bukkit.event.EventHandler; import org.bukkit.event.EventPriority; import org.bukkit.event.Listener; import org.bukkit.event.block.BlockBreakEvent; +import org.bukkit.event.block.BlockPistonExtendEvent; +import org.bukkit.event.block.BlockPistonRetractEvent; import org.bukkit.event.block.BlockPlaceEvent; import org.bukkit.inventory.ItemStack; import org.bukkit.metadata.FixedMetadataValue; @@ -122,7 +124,33 @@ public class BlockListener implements Listener { public void b(BlockPlaceEvent event) { event.getBlock().setMetadata("player_placed", new FixedMetadataValue(MMOCore.plugin, true)); } + + @EventHandler + public void c1(BlockPistonExtendEvent event) { + Block movedBlock = event.getBlock(); + if(!movedBlock.hasMetadata("player_placed")) return; + BlockFace direction = event.getDirection(); + movedBlock = movedBlock.getRelative(direction, 2); + for (Block b : event.getBlocks()) { + if (b.hasMetadata("player_placed")) { + movedBlock = b.getRelative(direction); + movedBlock.setMetadata("player_placed", new FixedMetadataValue(MMOCore.plugin, true)); + } + } + } + @EventHandler + public void c2(BlockPistonRetractEvent event) { + BlockFace direction = event.getDirection(); + Block movedBlock = event.getBlock().getRelative(direction); + movedBlock.setMetadata("player_placed", new FixedMetadataValue(MMOCore.plugin, true)); + + for (Block block : event.getBlocks()) { + movedBlock = block.getRelative(direction); + movedBlock.setMetadata("player_placed", new FixedMetadataValue(MMOCore.plugin, true)); + } + } + private Location getSafeDropLocation(Block block, boolean self) { if (block.getType() == Material.AIR && self) return block.getLocation();