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 e6f309646c..1d725598c5 100644 --- a/paper-api/src/main/java/org/bukkit/event/Event.java +++ b/paper-api/src/main/java/org/bukkit/event/Event.java @@ -287,6 +287,12 @@ public abstract class Event implements Serializable { * @see org.bukkit.event.player.PlayerBedLeaveEvent */ PLAYER_BED_LEAVE(Category.PLAYER), + /** + * Called when a player is fishing + * + * @see org.bukkit.event.player.PlayerFishEvent + */ + PLAYER_FISH(Category.PLAYER), /** * BLOCK EVENTS diff --git a/paper-api/src/main/java/org/bukkit/event/player/PlayerFishEvent.java b/paper-api/src/main/java/org/bukkit/event/player/PlayerFishEvent.java new file mode 100644 index 0000000000..584785beb6 --- /dev/null +++ b/paper-api/src/main/java/org/bukkit/event/player/PlayerFishEvent.java @@ -0,0 +1,85 @@ +package org.bukkit.event.player; + +import org.bukkit.entity.Player; +import org.bukkit.event.Cancellable; +import org.bukkit.entity.Entity; + +/** + * Thrown when a player is fishing + */ +public class PlayerFishEvent extends PlayerEvent implements Cancellable { + private final Entity entity; + private boolean cancel = false; + private State state; + + public PlayerFishEvent(final Player player, final Entity entity, State state) { + super(Type.PLAYER_FISH, player); + this.entity = entity; + this.state = state; + } + + /** + * Gets the entity caught by the player + * + * @return Entity caught by the player, null if fishing, bobber has gotten stuck in the ground or nothing has been caught + */ + public Entity getCaught() { + return entity; + } + + /** + * 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() { + return cancel; + } + + /** + * 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) { + this.cancel = cancel; + } + + /** + * Gets the state of the fishing + * + * @return A State detailing the state of the fishing + */ + public State getState() { + return state; + } + + /** + * An enum to specify the state of the fishing + */ + public enum State { + + /** + * When a player is fishing + */ + FISHING, + /** + * When a player has successfully caught a fish + */ + CAUGHT_FISH, + /** + * When a player has successfully caught an entity + */ + CAUGHT_ENTITY, + /** + * When a bobber is stuck in the grund + */ + IN_GROUND, + /** + * When a player fails to catch anything while fishing usually due to poor aiming or timing + */ + FAILED_ATTEMPT, + } +} 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 4789bb061a..54e5f042c5 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 @@ -176,4 +176,11 @@ public class PlayerListener implements Listener { * @param event Relevant event details */ public void onPlayerPortal(PlayerPortalEvent event) {} + + /** + * Called when a player is fishing + * + * @param event Relevant event details + */ + public void onPlayerFish(PlayerFishEvent 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 ec3eb340b9..e29c301867 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 @@ -406,6 +406,13 @@ public final class JavaPluginLoader implements PluginLoader { } }; + case PLAYER_FISH: + return new EventExecutor() { + public void execute(Listener listener, Event event) { + ((PlayerListener) listener).onPlayerFish((PlayerFishEvent) event); + } + }; + // Block Events case BLOCK_PHYSICS: return new EventExecutor() {