From 7824cc02e7e622b94974d0433ea2f42ab78fe564 Mon Sep 17 00:00:00 2001 From: Bukkit/Spigot Date: Wed, 23 Mar 2011 12:30:54 +0100 Subject: [PATCH] Add PLAYER_INTERACT, remove BLOCK_RIGHT_CLICK, BLOCK_INTERACT and PLAYER_ITEM By: Erik Broes --- .../src/main/java/org/bukkit/event/Event.java | 38 ++-- .../java/org/bukkit/event/block/Action.java | 24 +++ .../org/bukkit/event/block/BlockListener.java | 16 -- .../event/player/PlayerInteractEvent.java | 171 ++++++++++++++++++ .../bukkit/event/player/PlayerListener.java | 4 +- .../bukkit/plugin/java/JavaPluginLoader.java | 14 +- 6 files changed, 222 insertions(+), 45 deletions(-) create mode 100644 paper-api/src/main/java/org/bukkit/event/block/Action.java create mode 100644 paper-api/src/main/java/org/bukkit/event/player/PlayerInteractEvent.java 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 ea703032d7..cf636ce0f6 100644 --- a/paper-api/src/main/java/org/bukkit/event/Event.java +++ b/paper-api/src/main/java/org/bukkit/event/Event.java @@ -213,7 +213,7 @@ public abstract class Event implements Serializable { * * @see org.bukkit.event.player.PlayerItemEvent */ - PLAYER_ITEM (Category.PLAYER), + PLAYER_INTERACT (Category.PLAYER), /** * Called when a player throws an egg and it might hatch @@ -311,13 +311,6 @@ public abstract class Event implements Serializable { */ BLOCK_PHYSICS (Category.BLOCK), - /** - * Called when a player is attempting to place a block - * - * @see org.bukkit.event.block.BlockRightClickEvent - */ - BLOCK_RIGHTCLICK (Category.BLOCK), - /** * Called when a player is attempting to place a block * @@ -325,13 +318,6 @@ public abstract class Event implements Serializable { */ BLOCK_PLACE (Category.BLOCK), - /** - * Called when an entity interacts with a block (lever, door, pressure plate, chest, furnace) - * - * @see org.bukkit.event.block.BlockInteractEvent - */ - BLOCK_INTERACT (Category.BLOCK), - /** * Called when a block is destroyed from being burnt by fire * @@ -624,4 +610,26 @@ public abstract class Event implements Serializable { return category; } } + + public enum Result { + /** + * Deny the event. + * Depending on the event, the action indicated by the event will either not take place or will be reverted. + * Some actions may not be denied. + */ + DENY, + + /** + * Neither deny nor allow the event. + * The server will proceed with its normal handling. + */ + DEFAULT, + + /** + * Allow / Force the event. + * The action indicated by the event will take place if possible, even if the server would not normally allow the action. + * Some actions may not be allowed. + */ + ALLOW; + } } diff --git a/paper-api/src/main/java/org/bukkit/event/block/Action.java b/paper-api/src/main/java/org/bukkit/event/block/Action.java new file mode 100644 index 0000000000..097cd80007 --- /dev/null +++ b/paper-api/src/main/java/org/bukkit/event/block/Action.java @@ -0,0 +1,24 @@ +package org.bukkit.event.block; + +public enum Action { + /** + * Left-clicking a block + */ + LEFT_CLICK_BLOCK, + /** + * Right-clicking a block + */ + RIGHT_CLICK_BLOCK, + /** + * Left-clicking the air + */ + LEFT_CLICK_AIR, + /** + * Right-clicking the air + */ + RIGHT_CLICK_AIR, + /** + * Ass-pressure + */ + PHYSICAL, +} 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 7cf893c9f8..39c7bc2e16 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 @@ -60,22 +60,6 @@ public class BlockListener implements Listener { public void onBlockPlace(BlockPlaceEvent event) { } - /** - * Called when a block is interacted with - * - * @param event Relevant event details - */ - public void onBlockInteract(BlockInteractEvent event) { - } - - /** - * Called when a player right clicks a block - * - * @param event Relevant event details - */ - public void onBlockRightClick(BlockRightClickEvent event) { - } - /** * Called when redstone changes * From: the source of the redstone change diff --git a/paper-api/src/main/java/org/bukkit/event/player/PlayerInteractEvent.java b/paper-api/src/main/java/org/bukkit/event/player/PlayerInteractEvent.java new file mode 100644 index 0000000000..4f06f4d7b3 --- /dev/null +++ b/paper-api/src/main/java/org/bukkit/event/player/PlayerInteractEvent.java @@ -0,0 +1,171 @@ +package org.bukkit.event.player; + +import org.bukkit.block.Block; +import org.bukkit.block.BlockFace; +import org.bukkit.inventory.ItemStack; +import org.bukkit.Material; +import org.bukkit.entity.Player; +import org.bukkit.event.Cancellable; +import org.bukkit.event.Event.Result; +import org.bukkit.event.block.Action; + +/** + * + * @author durron597 + * + */ +public class PlayerInteractEvent extends PlayerEvent implements Cancellable { + protected ItemStack item; + protected Action action; + protected Block blockClicked; + protected BlockFace blockFace; + + private Result useClickedBlock; + private Result useItemInHand; + + public PlayerInteractEvent(Player who, Action action, ItemStack item, Block clickedBlock, BlockFace clickedFace) { + super(Type.PLAYER_INTERACT, who); + this.action = action; + this.item = item; + this.blockClicked = clickedBlock; + this.blockFace = clickedFace; + + useItemInHand = item == null ? Result.DENY : Result.ALLOW; + useClickedBlock = clickedBlock == null ? Result.DENY : Result.ALLOW; + } + + /** + * Returns the action type + * + * @return Action returns the type of interaction + */ + public Action getAction() { + return action; + } + + /** + * Gets the cancellation state of this event. Set to true if you + * want to prevent buckets from placing water and so forth + * + * @return boolean cancellation state + */ + public boolean isCancelled() { + return useInteractedBlock() == Result.DENY; + } + + /** + * Sets the cancellation state of this event. A canceled event will not + * be executed in the server, but will still pass to other plugins + * + * Canceling this event will prevent use of food (player won't lose the + * food item), prevent bows/snowballs/eggs from firing, etc. (player won't + * lose the ammo) + * + * @param cancel true if you wish to cancel this event + */ + public void setCancelled(boolean cancel) { + setUseInteractedBlock(cancel ? Result.DENY : useInteractedBlock() == Result.DENY ? Result.DEFAULT : useInteractedBlock()); + } + + /** + * Returns the item in hand represented by this event + * + * @return ItemStack the item used + */ + public ItemStack getItem() { + return this.item; + } + + /** + * Convenience method. Returns the material of the item represented by this + * event + * + * @return Material the material of the item used + */ + public Material getMaterial() { + if (!hasItem()) return Material.AIR; + + return item.getType(); + } + + /** + * Check if this event involved a block + * + * return boolean true if it did + */ + public boolean hasBlock() { + return this.blockClicked != null; + } + + /** + * Check if this event involved an item + * + * return boolean true if it did + */ + public boolean hasItem() { + return this.item != null; + } + + /** + * Convenience method to inform the user whether this was a block placement + * event. + * + * @return boolean true if the item in hand was a block + */ + public boolean isBlockInHand() { + if (!hasItem()) return false; + + return item.getType().isBlock(); + } + + /** + * Returns the clicked block + * + * @return Block returns the block clicked with this item. + */ + public Block getClickedBlock() { + return blockClicked; + } + + /** + * Returns the face of the block that was clicked + * + * @return BlockFace returns the face of the block that was clicked + */ + public BlockFace getBlockFace() { + return blockFace; + } + + /** + * This controls the action to take with the block (if any) that was clicked on + * This event gets processed for all blocks, but most don't have a default action + * @return the action to take with the interacted block + */ + public Result useInteractedBlock() { + return useClickedBlock; + } + + /** + * @param useInteractedBlock the action to take with the interacted block + */ + public void setUseInteractedBlock(Result useInteractedBlock) { + this.useClickedBlock = useInteractedBlock; + } + + /** + * This controls the action to take with the item the player is holding + * This includes both blocks and items (such as flint and steel or records) + * When this is set to default, it will be allowed if no action is taken on the interacted block + * @return the action to take with the item in hand + */ + public Result useItemInHand() { + return useItemInHand; + } + + /** + * @param useItemInHand the action to take with the item in hand + */ + public void setUseItemInHand(Result useItemInHand) { + this.useItemInHand = useItemInHand; + } +} diff --git a/paper-api/src/main/java/org/bukkit/event/player/PlayerListener.java b/paper-api/src/main/java/org/bukkit/event/player/PlayerListener.java index bc18d131ac..0c817c1dbe 100644 --- a/paper-api/src/main/java/org/bukkit/event/player/PlayerListener.java +++ b/paper-api/src/main/java/org/bukkit/event/player/PlayerListener.java @@ -76,11 +76,11 @@ public class PlayerListener implements Listener { } /** - * Called when a player uses an item + * Called when a player interacts * * @param event Relevant event details */ - public void onPlayerItem(PlayerItemEvent event) { + public void onPlayerInteract(PlayerInteractEvent event) { } /** 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 d0170bbbd5..ee0a1a01d6 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 @@ -197,9 +197,9 @@ public final class JavaPluginLoader implements PluginLoader { ((PlayerListener)listener).onPlayerTeleport( (PlayerMoveEvent)event ); } }; - case PLAYER_ITEM: + case PLAYER_INTERACT: return new EventExecutor() { public void execute( Listener listener, Event event ) { - ((PlayerListener)listener).onPlayerItem( (PlayerItemEvent)event ); + ((PlayerListener)listener).onPlayerInteract( (PlayerInteractEvent)event ); } }; case PLAYER_LOGIN: @@ -266,11 +266,6 @@ public final class JavaPluginLoader implements PluginLoader { ((BlockListener)listener).onBlockCanBuild( (BlockCanBuildEvent)event ); } }; - case BLOCK_RIGHTCLICK: - return new EventExecutor() { public void execute( Listener listener, Event event ) { - ((BlockListener)listener).onBlockRightClick( (BlockRightClickEvent)event ); - } - }; case BLOCK_PLACE: return new EventExecutor() { public void execute( Listener listener, Event event ) { ((BlockListener)listener).onBlockPlace( (BlockPlaceEvent)event ); @@ -281,11 +276,6 @@ public final class JavaPluginLoader implements PluginLoader { ((BlockListener)listener).onBlockDamage( (BlockDamageEvent)event ); } }; - case BLOCK_INTERACT: - return new EventExecutor() { public void execute( Listener listener, Event event ) { - ((BlockListener)listener).onBlockInteract( (BlockInteractEvent)event ); - } - }; case BLOCK_FROMTO: return new EventExecutor() { public void execute( Listener listener, Event event ) { ((BlockListener)listener).onBlockFlow( (BlockFromToEvent)event );