From 2ff558c10bbbeb2dbad585cde4dabcaf85b3b5e5 Mon Sep 17 00:00:00 2001 From: Bukkit/Spigot <noreply+git-bukkit@papermc.io> Date: Mon, 3 Jan 2011 16:52:44 +0800 Subject: [PATCH] Implemented vehicle hooks (some changes will still be made). By: sk89q <the.sk89q@gmail.com> --- .../src/main/java/org/bukkit/event/Event.java | 8 +-- .../vehicle/VehicleBlockCollisionEvent.java | 22 +++++++ .../event/vehicle/VehicleCollisionEvent.java | 14 ++++ .../event/vehicle/VehicleDamageEvent.java | 26 ++++++++ .../event/vehicle/VehicleEnterEvent.java | 38 +++++++++++ .../vehicle/VehicleEntityCollisionEvent.java | 22 +++++++ .../bukkit/event/vehicle/VehicleEvent.java | 27 ++++++++ .../event/vehicle/VehicleExitEvent.java | 38 +++++++++++ .../bukkit/event/vehicle/VehicleListener.java | 64 +++++++++++++++++++ .../event/vehicle/VehicleMoveEvent.java | 40 ++++++++++++ .../event/vehicle/VehiclePlaceEvent.java | 26 ++++++++ .../bukkit/plugin/java/JavaPluginLoader.java | 27 ++++++++ 12 files changed, 348 insertions(+), 4 deletions(-) create mode 100644 paper-api/src/main/java/org/bukkit/event/vehicle/VehicleBlockCollisionEvent.java create mode 100644 paper-api/src/main/java/org/bukkit/event/vehicle/VehicleCollisionEvent.java create mode 100644 paper-api/src/main/java/org/bukkit/event/vehicle/VehicleDamageEvent.java create mode 100644 paper-api/src/main/java/org/bukkit/event/vehicle/VehicleEnterEvent.java create mode 100644 paper-api/src/main/java/org/bukkit/event/vehicle/VehicleEntityCollisionEvent.java create mode 100644 paper-api/src/main/java/org/bukkit/event/vehicle/VehicleEvent.java create mode 100644 paper-api/src/main/java/org/bukkit/event/vehicle/VehicleExitEvent.java create mode 100644 paper-api/src/main/java/org/bukkit/event/vehicle/VehicleListener.java create mode 100644 paper-api/src/main/java/org/bukkit/event/vehicle/VehicleMoveEvent.java create mode 100644 paper-api/src/main/java/org/bukkit/event/vehicle/VehiclePlaceEvent.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 2559fd1472..51992ad361 100644 --- a/paper-api/src/main/java/org/bukkit/event/Event.java +++ b/paper-api/src/main/java/org/bukkit/event/Event.java @@ -337,12 +337,12 @@ public abstract class Event { /** * Called when a vehicle is placed by a player */ - VEHICLE_PLACED (Category.VEHICLE), + VEHICLE_PLACE (Category.VEHICLE), /** * Called when a vehicle is damaged by a LivingEntity */ - VEHICLE_DAMAGED (Category.VEHICLE), + VEHICLE_DAMAGE (Category.VEHICLE), /** * Called when a vehicle collides with an Entity @@ -357,12 +357,12 @@ public abstract class Event { /** * Called when a vehicle is entered by a LivingEntity */ - VEHICLE_ENTERED (Category.VEHICLE), + VEHICLE_ENTER (Category.VEHICLE), /** * Called when a vehicle is exited by a LivingEntity */ - VEHICLE_EXITED (Category.VEHICLE), + VEHICLE_EXIT (Category.VEHICLE), /** * Called when a vehicle moves position in the world diff --git a/paper-api/src/main/java/org/bukkit/event/vehicle/VehicleBlockCollisionEvent.java b/paper-api/src/main/java/org/bukkit/event/vehicle/VehicleBlockCollisionEvent.java new file mode 100644 index 0000000000..6141c1c12e --- /dev/null +++ b/paper-api/src/main/java/org/bukkit/event/vehicle/VehicleBlockCollisionEvent.java @@ -0,0 +1,22 @@ +package org.bukkit.event.vehicle; + +import org.bukkit.Block; +import org.bukkit.Vehicle; + +/** + * Raised when a vehicle collides with a block. + * + * @author sk89q + */ +public class VehicleBlockCollisionEvent extends VehicleCollisionEvent { + private Block block; + + public VehicleBlockCollisionEvent(Type type, Vehicle vehicle, Block block) { + super(type, vehicle); + this.block = block; + } + + public Block getBlock() { + return block; + } +} diff --git a/paper-api/src/main/java/org/bukkit/event/vehicle/VehicleCollisionEvent.java b/paper-api/src/main/java/org/bukkit/event/vehicle/VehicleCollisionEvent.java new file mode 100644 index 0000000000..6e4bb48a89 --- /dev/null +++ b/paper-api/src/main/java/org/bukkit/event/vehicle/VehicleCollisionEvent.java @@ -0,0 +1,14 @@ +package org.bukkit.event.vehicle; + +import org.bukkit.Vehicle; + +/** + * Raised when a vehicle collides. + * + * @author sk89q + */ +public class VehicleCollisionEvent extends VehicleEvent { + public VehicleCollisionEvent(Type type, Vehicle vehicle) { + super(type, vehicle); + } +} diff --git a/paper-api/src/main/java/org/bukkit/event/vehicle/VehicleDamageEvent.java b/paper-api/src/main/java/org/bukkit/event/vehicle/VehicleDamageEvent.java new file mode 100644 index 0000000000..fd112bd6ce --- /dev/null +++ b/paper-api/src/main/java/org/bukkit/event/vehicle/VehicleDamageEvent.java @@ -0,0 +1,26 @@ +package org.bukkit.event.vehicle; + +import org.bukkit.Vehicle; +import org.bukkit.event.Cancellable; + +/** + * Raised when a vehicle receives damage. + * + * @author sk89q + */ +public class VehicleDamageEvent extends VehicleEvent implements Cancellable { + private boolean cancelled; + + public VehicleDamageEvent(Type type, Vehicle vehicle) { + super(type, vehicle); + } + + public boolean isCancelled() { + return cancelled; + } + + public void setCancelled(boolean cancel) { + this.cancelled = cancel; + } + +} diff --git a/paper-api/src/main/java/org/bukkit/event/vehicle/VehicleEnterEvent.java b/paper-api/src/main/java/org/bukkit/event/vehicle/VehicleEnterEvent.java new file mode 100644 index 0000000000..da8fc30c3c --- /dev/null +++ b/paper-api/src/main/java/org/bukkit/event/vehicle/VehicleEnterEvent.java @@ -0,0 +1,38 @@ +package org.bukkit.event.vehicle; + +import org.bukkit.LivingEntity; +import org.bukkit.Vehicle; +import org.bukkit.event.Cancellable; + +/** + * Raised when a living entity enters a vehicle. + * + * @author sk89q + */ +public class VehicleEnterEvent extends VehicleEvent implements Cancellable { + private boolean cancelled; + private LivingEntity entered; + + public VehicleEnterEvent(Type type, Vehicle vehicle, LivingEntity entered) { + super(type, vehicle); + + this.entered = entered; + } + + /** + * Get the living entity that entered the vehicle. + * + * @return + */ + public LivingEntity getEntered() { + return entered; + } + + public boolean isCancelled() { + return cancelled; + } + + public void setCancelled(boolean cancel) { + this.cancelled = cancel; + } +} diff --git a/paper-api/src/main/java/org/bukkit/event/vehicle/VehicleEntityCollisionEvent.java b/paper-api/src/main/java/org/bukkit/event/vehicle/VehicleEntityCollisionEvent.java new file mode 100644 index 0000000000..fe2c3b71c6 --- /dev/null +++ b/paper-api/src/main/java/org/bukkit/event/vehicle/VehicleEntityCollisionEvent.java @@ -0,0 +1,22 @@ +package org.bukkit.event.vehicle; + +import org.bukkit.Entity; +import org.bukkit.Vehicle; + +/** + * Raised when a vehicle collides with an entity. + * + * @author sk89q + */ +public class VehicleEntityCollisionEvent extends VehicleCollisionEvent { + private Entity entity; + + public VehicleEntityCollisionEvent(Type type, Vehicle vehicle, Entity entity) { + super(type, vehicle); + this.entity = entity; + } + + public Entity getEntity() { + return entity; + } +} diff --git a/paper-api/src/main/java/org/bukkit/event/vehicle/VehicleEvent.java b/paper-api/src/main/java/org/bukkit/event/vehicle/VehicleEvent.java new file mode 100644 index 0000000000..b08c334046 --- /dev/null +++ b/paper-api/src/main/java/org/bukkit/event/vehicle/VehicleEvent.java @@ -0,0 +1,27 @@ +package org.bukkit.event.vehicle; + +import org.bukkit.Vehicle; +import org.bukkit.event.Event; + +/** + * Represents a vehicle-related event. + * + * @author sk89q + */ +public class VehicleEvent extends Event { + protected Vehicle vehicle; + + public VehicleEvent(final Event.Type type, final Vehicle vehicle) { + super(type); + this.vehicle = vehicle; + } + + /** + * Get the vehicle. + * + * @return the vehicle + */ + public final Vehicle getVehicle() { + return vehicle; + } +} diff --git a/paper-api/src/main/java/org/bukkit/event/vehicle/VehicleExitEvent.java b/paper-api/src/main/java/org/bukkit/event/vehicle/VehicleExitEvent.java new file mode 100644 index 0000000000..957571edd6 --- /dev/null +++ b/paper-api/src/main/java/org/bukkit/event/vehicle/VehicleExitEvent.java @@ -0,0 +1,38 @@ +package org.bukkit.event.vehicle; + +import org.bukkit.LivingEntity; +import org.bukkit.Vehicle; +import org.bukkit.event.Cancellable; + +/** + * Raised when a living entity exits a vehicle. + * + * @author sk89q + */ +public class VehicleExitEvent extends VehicleEvent implements Cancellable { + private boolean cancelled; + private LivingEntity exited; + + public VehicleExitEvent(Type type, Vehicle vehicle, LivingEntity exited) { + super(type, vehicle); + + this.exited = exited; + } + + /** + * Get the living entity that exited the vehicle. + * + * @return + */ + public LivingEntity getExited() { + return exited; + } + + public boolean isCancelled() { + return cancelled; + } + + public void setCancelled(boolean cancel) { + this.cancelled = cancel; + } +} diff --git a/paper-api/src/main/java/org/bukkit/event/vehicle/VehicleListener.java b/paper-api/src/main/java/org/bukkit/event/vehicle/VehicleListener.java new file mode 100644 index 0000000000..95e6e2df49 --- /dev/null +++ b/paper-api/src/main/java/org/bukkit/event/vehicle/VehicleListener.java @@ -0,0 +1,64 @@ +package org.bukkit.event.vehicle; + +/** + * Listener for vehicle events. + * + * @author sk89q + */ +public class VehicleListener { + /** + * Called when a vehicle is placed by a player. + * + * @param event + */ + public void onVehiclePlace(VehiclePlaceEvent event) { + } + + /** + * Called when a vehicle is damaged by the player. + * + * @param event + */ + public void onVehicleDamage(VehicleDamageEvent event) { + } + + /** + * Called when a vehicle collides with a block. + * + * @param event + */ + public void onVehicleBlockCollision(VehicleBlockCollisionEvent event) { + } + + /** + * Called when a vehicle collides with an entity. + * + * @param event + */ + public void onVehicleEntityCollision(VehicleEntityCollisionEvent event) { + } + + /** + * Called when an entity enters a vehicle. + * + * @param event + */ + public void onVehicleEnter(VehicleEnterEvent event) { + } + + /** + * Called when an entity exits a vehicle. + * + * @param event + */ + public void onVehicleExit(VehicleExitEvent event) { + } + + /** + * Called when an vehicle moves. + * + * @param event + */ + public void onVehicleMove(VehicleMoveEvent event) { + } +} diff --git a/paper-api/src/main/java/org/bukkit/event/vehicle/VehicleMoveEvent.java b/paper-api/src/main/java/org/bukkit/event/vehicle/VehicleMoveEvent.java new file mode 100644 index 0000000000..65921ad489 --- /dev/null +++ b/paper-api/src/main/java/org/bukkit/event/vehicle/VehicleMoveEvent.java @@ -0,0 +1,40 @@ +package org.bukkit.event.vehicle; + +import org.bukkit.Location; +import org.bukkit.Vehicle; + +/** + * Raised when a vehicle moves. + * + * @author sk89q + */ +public class VehicleMoveEvent extends VehicleEvent { + private Location from; + private Location to; + + public VehicleMoveEvent(Type type, Vehicle vehicle, + Location from, Location to) { + super(type, vehicle); + + this.from = from; + this.to = to; + } + + /** + * Get the previous position. + * + * @return + */ + public Location getFrom() { + return from; + } + + /** + * Get the next position. + * + * @return + */ + public Location getTo() { + return to; + } +} diff --git a/paper-api/src/main/java/org/bukkit/event/vehicle/VehiclePlaceEvent.java b/paper-api/src/main/java/org/bukkit/event/vehicle/VehiclePlaceEvent.java new file mode 100644 index 0000000000..446288790c --- /dev/null +++ b/paper-api/src/main/java/org/bukkit/event/vehicle/VehiclePlaceEvent.java @@ -0,0 +1,26 @@ +package org.bukkit.event.vehicle; + +import org.bukkit.Vehicle; +import org.bukkit.event.Cancellable; + +/** + * Raised when a vehicle is placed by a player. + * + * @author sk89q + */ +public class VehiclePlaceEvent extends VehicleEvent implements Cancellable { + private boolean cancelled; + + public VehiclePlaceEvent(Type type, Vehicle vehicle) { + super(type, vehicle); + } + + public boolean isCancelled() { + return cancelled; + } + + public void setCancelled(boolean cancel) { + this.cancelled = cancel; + } + +} 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 667fcb3f2c..56fcbe7984 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 @@ -19,6 +19,7 @@ import org.bukkit.event.block.*; import org.bukkit.event.player.*; import org.bukkit.event.server.PluginEvent; import org.bukkit.event.server.ServerListener; +import org.bukkit.event.vehicle.*; import org.bukkit.plugin.*; /** @@ -132,6 +133,32 @@ public final class JavaPluginLoader implements PluginLoader { trueListener.onPluginDisabled((PluginEvent)event); break; } + } else if (listener instanceof VehicleListener) { + VehicleListener trueListener = (VehicleListener)listener; + + switch (event.getType()) { + case VEHICLE_PLACE: + trueListener.onVehiclePlace((VehiclePlaceEvent)event); + break; + case VEHICLE_DAMAGE: + trueListener.onVehicleDamage((VehicleDamageEvent)event); + break; + case VEHICLE_COLLISION_BLOCK: + trueListener.onVehicleBlockCollision((VehicleBlockCollisionEvent)event); + break; + case VEHICLE_COLLISION_ENTITY: + trueListener.onVehicleEntityCollision((VehicleEntityCollisionEvent)event); + break; + case VEHICLE_ENTER: + trueListener.onVehicleEnter((VehicleEnterEvent)event); + break; + case VEHICLE_EXIT: + trueListener.onVehicleExit((VehicleExitEvent)event); + break; + case VEHICLE_MOVE: + trueListener.onVehicleMove((VehicleMoveEvent)event); + break; + } } else if(listener instanceof CustomEventListener) { if(event.getType()==Event.Type.CUSTOM_EVENT) { ((CustomEventListener)listener).onCustomEvent(event);