From a6f809378ced3dd528b2f429f0391a4ad3946a2a Mon Sep 17 00:00:00 2001 From: Jan Boerman Date: Sun, 15 Mar 2020 19:05:50 +1100 Subject: [PATCH] SPIGOT-5606: call BlockRedstoneEvent for fence gates --- nms-patches/BlockFenceGate.patch | 20 ++++++++++++++++++++ 1 file changed, 20 insertions(+) create mode 100644 nms-patches/BlockFenceGate.patch diff --git a/nms-patches/BlockFenceGate.patch b/nms-patches/BlockFenceGate.patch new file mode 100644 index 0000000000..d29e021ddb --- /dev/null +++ b/nms-patches/BlockFenceGate.patch @@ -0,0 +1,20 @@ +--- a/net/minecraft/server/BlockFenceGate.java ++++ b/net/minecraft/server/BlockFenceGate.java +@@ -103,6 +103,17 @@ + public void doPhysics(IBlockData iblockdata, World world, BlockPosition blockposition, Block block, BlockPosition blockposition1, boolean flag) { + if (!world.isClientSide) { + boolean flag1 = world.isBlockIndirectlyPowered(blockposition); ++ // CraftBukkit start ++ boolean oldPowered = iblockdata.get(BlockFenceGate.POWERED); ++ if (oldPowered != flag1) { ++ int newPower = flag1 ? 15 : 0; ++ int oldPower = oldPowered ? 15 : 0; ++ org.bukkit.block.Block bukkitBlock = org.bukkit.craftbukkit.block.CraftBlock.at(world, blockposition); ++ org.bukkit.event.block.BlockRedstoneEvent eventRedstone = new org.bukkit.event.block.BlockRedstoneEvent(bukkitBlock, oldPower, newPower); ++ world.getServer().getPluginManager().callEvent(eventRedstone); ++ flag1 = eventRedstone.getNewCurrent() > 0; ++ } ++ // CraftBukkit end + + if ((Boolean) iblockdata.get(BlockFenceGate.POWERED) != flag1) { + world.setTypeAndData(blockposition, (IBlockData) ((IBlockData) iblockdata.set(BlockFenceGate.POWERED, flag1)).set(BlockFenceGate.OPEN, flag1), 2);