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 095c19c6a9..681cca941e 100644 --- a/paper-api/src/main/java/org/bukkit/event/Event.java +++ b/paper-api/src/main/java/org/bukkit/event/Event.java @@ -600,6 +600,12 @@ public abstract class Event implements Serializable { * @see org.bukkit.event.world.TreeGrowEvent */ STRUCTURE_GROW(Category.WORLD), + /** + * Called when an item despawns from a world + * + * @see org.bukkit.event.entity.ItemDespawnEvent + */ + ITEM_DESPAWN (Category.WORLD), /** * ENTITY EVENTS diff --git a/paper-api/src/main/java/org/bukkit/event/entity/EntityListener.java b/paper-api/src/main/java/org/bukkit/event/entity/EntityListener.java index b439973605..1e34b89024 100644 --- a/paper-api/src/main/java/org/bukkit/event/entity/EntityListener.java +++ b/paper-api/src/main/java/org/bukkit/event/entity/EntityListener.java @@ -162,4 +162,11 @@ public class EntityListener implements Listener { * @param event Relevant event details */ public void onSlimeSplit(SlimeSplitEvent event) {} + + /** + * Called when an item despawns from a world + * + * @param event Relevant event details + */ + public void onItemDespawn(ItemDespawnEvent event) {} } diff --git a/paper-api/src/main/java/org/bukkit/event/entity/ItemDespawnEvent.java b/paper-api/src/main/java/org/bukkit/event/entity/ItemDespawnEvent.java new file mode 100644 index 0000000000..620e247a5b --- /dev/null +++ b/paper-api/src/main/java/org/bukkit/event/entity/ItemDespawnEvent.java @@ -0,0 +1,32 @@ +package org.bukkit.event.entity; + +import org.bukkit.Location; +import org.bukkit.entity.Entity; +import org.bukkit.event.Cancellable; + +public class ItemDespawnEvent extends EntityEvent implements Cancellable { + private boolean canceled; + private Location location; + + public ItemDespawnEvent(Entity spawnee, Location loc) { + super(Type.ITEM_DESPAWN, spawnee); + location = loc; + } + + public boolean isCancelled() { + return canceled; + } + + public void setCancelled(boolean cancel) { + canceled = cancel; + } + + /** + * Gets the location at which the item is despawning. + * + * @return The location at which the item is despawning + */ + public Location getLocation() { + return location; + } +} 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 0bb16653b9..5126f9a03c 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 @@ -840,6 +840,13 @@ public class JavaPluginLoader implements PluginLoader { } }; + case ITEM_DESPAWN: + return new EventExecutor() { + public void execute(Listener listener, Event event) { + ((EntityListener) listener).onItemDespawn((ItemDespawnEvent) event); + } + }; + // Vehicle Events case VEHICLE_CREATE: return new EventExecutor() {