summaryrefslogtreecommitdiffstats
path: root/nms-patches/BlockLever.patch
diff options
context:
space:
mode:
Diffstat (limited to 'nms-patches/BlockLever.patch')
-rw-r--r--nms-patches/BlockLever.patch32
1 files changed, 32 insertions, 0 deletions
diff --git a/nms-patches/BlockLever.patch b/nms-patches/BlockLever.patch
new file mode 100644
index 00000000..fa9482b1
--- /dev/null
+++ b/nms-patches/BlockLever.patch
@@ -0,0 +1,32 @@
+--- ../work/decompile-bb26c12b/net/minecraft/server/BlockLever.java 2014-11-27 08:59:46.541422551 +1100
++++ src/main/java/net/minecraft/server/BlockLever.java 2014-11-27 08:42:10.168850880 +1100
+@@ -2,6 +2,8 @@
+
+ import java.util.Iterator;
+
++import org.bukkit.event.block.BlockRedstoneEvent; // CraftBukkit
++
+ public class BlockLever extends Block {
+
+ public static final BlockStateEnum FACING = BlockStateEnum.of("facing", EnumLeverPosition.class);
+@@ -144,6 +146,20 @@
+ if (world.isStatic) {
+ return true;
+ } else {
++ // CraftBukkit start - Interact Lever
++ boolean powered = (Boolean)iblockdata.get(POWERED);
++ org.bukkit.block.Block block = world.getWorld().getBlockAt(blockposition.getX(), blockposition.getY(), blockposition.getZ());
++ int old = (powered) ? 15 : 0;
++ int current = (!powered) ? 15 : 0;
++
++ BlockRedstoneEvent eventRedstone = new BlockRedstoneEvent(block, old, current);
++ world.getServer().getPluginManager().callEvent(eventRedstone);
++
++ if ((eventRedstone.getNewCurrent() > 0) != (!powered)) {
++ return true;
++ }
++ // CraftBukkit end
++
+ iblockdata = iblockdata.a(BlockLever.POWERED);
+ world.setTypeAndData(blockposition, iblockdata, 3);
+ world.makeSound((double) blockposition.getX() + 0.5D, (double) blockposition.getY() + 0.5D, (double) blockposition.getZ() + 0.5D, "random.click", 0.3F, ((Boolean) iblockdata.get(BlockLever.POWERED)).booleanValue() ? 0.6F : 0.5F);