From 86ab32254fed398ecb443047c841d625eb89b09a Mon Sep 17 00:00:00 2001 From: Bukkit/Spigot Date: Fri, 15 Jul 2011 23:59:12 +0200 Subject: [PATCH] Added Block.getPistonMoveReaction, BlockPistonExtend and BlockPistonRetractEvent By: Erik Broes --- .../src/main/java/org/bukkit/block/Block.java | 16 +++++++ .../org/bukkit/block/PistonMoveReaction.java | 30 +++++++++++++ .../java/org/bukkit/event/Cancellable.java | 13 ++++++ .../src/main/java/org/bukkit/event/Event.java | 12 ++++++ .../org/bukkit/event/block/BlockListener.java | 14 ++++++ .../bukkit/event/block/BlockPistonEvent.java | 43 +++++++++++++++++++ .../event/block/BlockPistonExtendEvent.java | 43 +++++++++++++++++++ .../event/block/BlockPistonRetractEvent.java | 20 +++++++++ .../bukkit/plugin/java/JavaPluginLoader.java | 14 ++++++ 9 files changed, 205 insertions(+) create mode 100644 paper-api/src/main/java/org/bukkit/block/PistonMoveReaction.java create mode 100644 paper-api/src/main/java/org/bukkit/event/block/BlockPistonEvent.java create mode 100644 paper-api/src/main/java/org/bukkit/event/block/BlockPistonExtendEvent.java create mode 100644 paper-api/src/main/java/org/bukkit/event/block/BlockPistonRetractEvent.java diff --git a/paper-api/src/main/java/org/bukkit/block/Block.java b/paper-api/src/main/java/org/bukkit/block/Block.java index 391545b20e..05fb9ca8c8 100644 --- a/paper-api/src/main/java/org/bukkit/block/Block.java +++ b/paper-api/src/main/java/org/bukkit/block/Block.java @@ -66,6 +66,15 @@ public interface Block { */ Block getRelative(BlockFace face); + /** + * Gets the block at the given offsets + * + * @param face face + * @param distance distance + * @return Block at the given offset and distance + */ + Block getRelative(BlockFace face, int distance); + /** * Gets the type of this block * @@ -268,4 +277,11 @@ public interface Block { * @return Humidity of this block */ double getHumidity(); + + /** + * Returns the reaction of the block when moved by a piston + * + * @return reaction + */ + PistonMoveReaction getPistonMoveReaction(); } diff --git a/paper-api/src/main/java/org/bukkit/block/PistonMoveReaction.java b/paper-api/src/main/java/org/bukkit/block/PistonMoveReaction.java new file mode 100644 index 0000000000..83064122cb --- /dev/null +++ b/paper-api/src/main/java/org/bukkit/block/PistonMoveReaction.java @@ -0,0 +1,30 @@ +package org.bukkit.block; + +import java.util.HashMap; +import java.util.Map; + +public enum PistonMoveReaction { + MOVE(0), + BREAK(1), + BLOCK(2); + + private int id; + private static Map byId = new HashMap(); + static { + for (PistonMoveReaction reaction: PistonMoveReaction.values()) { + byId.put(reaction.id, reaction); + } + } + + private PistonMoveReaction(int id) { + this.id = id; + } + + public int getId() { + return this.id; + } + + public static PistonMoveReaction getById(int id) { + return byId.get(id); + } +} diff --git a/paper-api/src/main/java/org/bukkit/event/Cancellable.java b/paper-api/src/main/java/org/bukkit/event/Cancellable.java index 91407a9a07..3fc13fc84a 100644 --- a/paper-api/src/main/java/org/bukkit/event/Cancellable.java +++ b/paper-api/src/main/java/org/bukkit/event/Cancellable.java @@ -1,6 +1,19 @@ package org.bukkit.event; public interface Cancellable { + /** + * Gets the cancellation state of this event. A cancelled event will not + * be executed in the server, but will still pass to other plugins + * + * @return true if this event is cancelled + */ public boolean isCancelled(); + + /** + * Sets the cancellation state of this event. A cancelled event will not + * be executed in the server, but will still pass to other plugins. + * + * @param cancel true if you wish to cancel this event + */ public void setCancelled(boolean cancel); } diff --git a/paper-api/src/main/java/org/bukkit/event/Event.java b/paper-api/src/main/java/org/bukkit/event/Event.java index 1d725598c5..80e0341856 100644 --- a/paper-api/src/main/java/org/bukkit/event/Event.java +++ b/paper-api/src/main/java/org/bukkit/event/Event.java @@ -404,6 +404,18 @@ public abstract class Event implements Serializable { * @see org.bukkit.event.block.BlockFadeEvent */ BLOCK_FADE (Category.BLOCK), + /** + * Called when a piston extends + * + * @see org.bukkit.event.block.PistonExtendEvent + */ + BLOCK_PISTON_EXTEND (Category.BLOCK), + /** + * Called when a piston retracts + * + * @see org.bukkit.event.block.PistonRetractEvent + */ + BLOCK_PISTON_RETRACT (Category.BLOCK), /** * INVENTORY EVENTS diff --git a/paper-api/src/main/java/org/bukkit/event/block/BlockListener.java b/paper-api/src/main/java/org/bukkit/event/block/BlockListener.java index f98fe50880..1b51b0f207 100644 --- a/paper-api/src/main/java/org/bukkit/event/block/BlockListener.java +++ b/paper-api/src/main/java/org/bukkit/event/block/BlockListener.java @@ -183,4 +183,18 @@ public class BlockListener implements Listener { * @param event Relevant event details */ public void onBlockDispense(BlockDispenseEvent event) {} + + /** + * Called when a piston retracts + * + * @param event Relevant event details + */ + public void onBlockPistonRetract(BlockPistonRetractEvent event) {} + + /** + * Called when a piston extends + * + * @param event Relevant event details + */ + public void onBlockPistonExtend(BlockPistonExtendEvent event) {} } diff --git a/paper-api/src/main/java/org/bukkit/event/block/BlockPistonEvent.java b/paper-api/src/main/java/org/bukkit/event/block/BlockPistonEvent.java new file mode 100644 index 0000000000..3ffaea7eff --- /dev/null +++ b/paper-api/src/main/java/org/bukkit/event/block/BlockPistonEvent.java @@ -0,0 +1,43 @@ +package org.bukkit.event.block; + +import org.bukkit.Material; +import org.bukkit.block.Block; +import org.bukkit.block.BlockFace; +import org.bukkit.event.Cancellable; +import org.bukkit.material.PistonBaseMaterial; + +public abstract class BlockPistonEvent extends BlockEvent implements Cancellable { + private boolean cancelled; + + public BlockPistonEvent(Type type, Block block) { + super(type, block); + } + + public boolean isCancelled() { + return this.cancelled; + } + + public void setCancelled(boolean cancelled) { + this.cancelled = cancelled; + } + + /** + * Returns true if the Piston in the event is sticky. + * + * @return stickiness of the piston + */ + public boolean isSticky() { + return block.getType() == Material.PISTON_STICKY_BASE; + } + + /** + * Return the direction in which the piston will operate. + * + * @return direction of the piston + */ + public BlockFace getDirection() { + // Both are meh! + // return ((PistonBaseMaterial) block.getType().getNewData(block.getData ())).getFacing(); + return ((PistonBaseMaterial) block.getState().getData()).getFacing(); + } +} diff --git a/paper-api/src/main/java/org/bukkit/event/block/BlockPistonExtendEvent.java b/paper-api/src/main/java/org/bukkit/event/block/BlockPistonExtendEvent.java new file mode 100644 index 0000000000..1643120d84 --- /dev/null +++ b/paper-api/src/main/java/org/bukkit/event/block/BlockPistonExtendEvent.java @@ -0,0 +1,43 @@ +package org.bukkit.event.block; + +import java.util.ArrayList; +import java.util.Collections; +import java.util.List; + +import org.bukkit.block.Block; + +public class BlockPistonExtendEvent extends BlockPistonEvent { + private int length; + private List blocks; + + public BlockPistonExtendEvent(Block block, int length) { + super(Type.BLOCK_PISTON_EXTEND, block); + + this.length = length; + } + + /** + * Get the amount of blocks which will be moved while extending. + * + * @return the amount of moving blocks + */ + public int getLength() { + return this.length; + } + + /** + * Get an immutable list of the blocks which will be moved by the extending. + * + * @return Immutable list of the moved blocks. + */ + public List getBlocks() { + if (blocks == null) { + ArrayList tmp = new ArrayList(); + for (int i = 0; i < this.getLength(); i++) { + tmp.add(block.getRelative(getDirection(), i + 1)); + } + blocks = Collections.unmodifiableList(tmp); + } + return blocks; + } +} diff --git a/paper-api/src/main/java/org/bukkit/event/block/BlockPistonRetractEvent.java b/paper-api/src/main/java/org/bukkit/event/block/BlockPistonRetractEvent.java new file mode 100644 index 0000000000..d57fc6b75c --- /dev/null +++ b/paper-api/src/main/java/org/bukkit/event/block/BlockPistonRetractEvent.java @@ -0,0 +1,20 @@ +package org.bukkit.event.block; + +import org.bukkit.Location; +import org.bukkit.block.Block; + +public class BlockPistonRetractEvent extends BlockPistonEvent { + public BlockPistonRetractEvent(Block block) { + super(Type.BLOCK_PISTON_RETRACT, block); + } + + /** + * Gets the location where the possible moving block might be if the retracting + * piston is sticky. + * + * @return The possible location of the possibly moving block. + */ + public Location getRetractLocation() { + return getBlock().getRelative(getDirection(), 2).getLocation(); + } +} diff --git a/paper-api/src/main/java/org/bukkit/plugin/java/JavaPluginLoader.java b/paper-api/src/main/java/org/bukkit/plugin/java/JavaPluginLoader.java index e29c301867..e0b3b53e28 100644 --- a/paper-api/src/main/java/org/bukkit/plugin/java/JavaPluginLoader.java +++ b/paper-api/src/main/java/org/bukkit/plugin/java/JavaPluginLoader.java @@ -527,6 +527,20 @@ public final class JavaPluginLoader implements PluginLoader { } }; + case BLOCK_PISTON_RETRACT: + return new EventExecutor() { + public void execute(Listener listener, Event event) { + ((BlockListener) listener).onBlockPistonRetract((BlockPistonRetractEvent) event); + } + }; + + case BLOCK_PISTON_EXTEND: + return new EventExecutor() { + public void execute(Listener listener, Event event) { + ((BlockListener) listener).onBlockPistonExtend((BlockPistonExtendEvent) event); + } + }; + // Server Events case PLUGIN_ENABLE: return new EventExecutor() {