From 15b97782c444747c6e38f8c4cbd9be0db2fd2e6e Mon Sep 17 00:00:00 2001 From: mrapple Date: Sat, 23 Jul 2011 10:51:31 -0500 Subject: [PATCH] Remove unnecessary player animation event, just use player interact instead --- .../bukkit/WorldEditPlayerListener.java | 27 +++++-------------- .../worldedit/bukkit/WorldEditPlugin.java | 1 - 2 files changed, 6 insertions(+), 22 deletions(-) diff --git a/src/main/java/com/sk89q/worldedit/bukkit/WorldEditPlayerListener.java b/src/main/java/com/sk89q/worldedit/bukkit/WorldEditPlayerListener.java index 0e6063fb1..6df113a1c 100644 --- a/src/main/java/com/sk89q/worldedit/bukkit/WorldEditPlayerListener.java +++ b/src/main/java/com/sk89q/worldedit/bukkit/WorldEditPlayerListener.java @@ -46,22 +46,6 @@ public class WorldEditPlayerListener extends PlayerListener { * * @param event Relevant event details */ - @Override - public void onPlayerAnimation(PlayerAnimationEvent event) { - LocalPlayer localPlayer = wrapPlayer(event.getPlayer()); - - if (event.getAnimationType() == PlayerAnimationType.ARM_SWING) { - plugin.getWorldEdit().handleArmSwing(localPlayer); - } - - // As of Minecraft 1.3, a block dig packet is no longer sent for - // bedrock, so we have to do an (inaccurate) detection ourself - WorldVector pt = localPlayer.getBlockTrace(5); - if (pt != null && pt.getWorld().getBlockType(pt) == BlockID.BEDROCK) { - if (plugin.getWorldEdit().handleBlockLeftClick(localPlayer, pt)) { - } - } - } /** * Construct the object; @@ -103,15 +87,16 @@ public void onPlayerCommandPreprocess(PlayerCommandPreprocessEvent event) { */ @Override public void onPlayerInteract(PlayerInteractEvent event) { - if (event.getAction() == Action.LEFT_CLICK_BLOCK) { + if (event.getAction() == Action.LEFT_CLICK_BLOCK || event.getAction() == Action.LEFT_CLICK_AIR) { LocalWorld world = new BukkitWorld(event.getClickedBlock().getWorld()); WorldVector pos = new WorldVector(world, event.getClickedBlock().getX(), event.getClickedBlock().getY(), event.getClickedBlock().getZ()); LocalPlayer player = wrapPlayer(event.getPlayer()); - - if (plugin.getWorldEdit().handleBlockLeftClick(player, pos)) { - event.setCancelled(true); - } + + if (!(event.getAction() == Action.LEFT_CLICK_BLOCK && plugin.getWorldEdit().handleBlockLeftClick(player, pos))) { + plugin.getWorldEdit().handleArmSwing(localPlayer); + } + event.setCancelled(true); } else if (event.getAction() == Action.RIGHT_CLICK_BLOCK) { LocalWorld world = new BukkitWorld(event.getClickedBlock().getWorld()); WorldVector pos = new WorldVector(world, event.getClickedBlock().getX(), diff --git a/src/main/java/com/sk89q/worldedit/bukkit/WorldEditPlugin.java b/src/main/java/com/sk89q/worldedit/bukkit/WorldEditPlugin.java index 9d1c4bb75..1a1e70c20 100644 --- a/src/main/java/com/sk89q/worldedit/bukkit/WorldEditPlugin.java +++ b/src/main/java/com/sk89q/worldedit/bukkit/WorldEditPlugin.java @@ -138,7 +138,6 @@ protected void registerEvents() { PlayerListener criticalPlayerListener = new WorldEditCriticalPlayerListener(this); registerEvent(Event.Type.PLAYER_QUIT, playerListener); - registerEvent(Event.Type.PLAYER_ANIMATION, playerListener); registerEvent(Event.Type.PLAYER_INTERACT, playerListener); registerEvent(Event.Type.PLAYER_COMMAND_PREPROCESS, playerListener); registerEvent(Event.Type.PLAYER_JOIN, criticalPlayerListener, Priority.Lowest);