From 531a69463a0031a01cac218fa922f3c1e5abc86e Mon Sep 17 00:00:00 2001 From: Bukkit/Spigot Date: Tue, 29 Mar 2011 01:59:00 -0700 Subject: [PATCH] Added the SPAWN_CHANGE event, which occurs when a world's spawn is changed. This event includes the world who's spawn changed and its previous spawn location. To listen for this event: PluginManager pm = getServer().getPluginManager(); YourWorldListener worldListener = new YourWorldListener(this); pm.registerEvent(Event.Type.SPAWN_CHANGE, worldListener, Priority.Normal, this); To use this event: public class YourWorldListener extends WorldListener { @Override public void onSpawnChange(SpawnChangeEvent event) { World world = event.getWorld(); Location previousLocation = event.getPreviousLocation(); } } By: William Bowers --- .../src/main/java/org/bukkit/event/Event.java | 7 +++++ .../bukkit/event/world/SpawnChangeEvent.java | 28 +++++++++++++++++++ .../org/bukkit/event/world/WorldListener.java | 8 ++++++ .../bukkit/plugin/java/JavaPluginLoader.java | 6 ++++ 4 files changed, 49 insertions(+) create mode 100644 paper-api/src/main/java/org/bukkit/event/world/SpawnChangeEvent.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 cf636ce0f6..dd59c06921 100644 --- a/paper-api/src/main/java/org/bukkit/event/Event.java +++ b/paper-api/src/main/java/org/bukkit/event/Event.java @@ -454,6 +454,13 @@ public abstract class Event implements Serializable { */ ITEM_SPAWN (Category.WORLD), + /** + * Called when a World's spawn is changed + * + * @see org.bukkit.event.world.SpawnChangeEvent + */ + SPAWN_CHANGE (Category.WORLD), + /** * Called when a world is saved * diff --git a/paper-api/src/main/java/org/bukkit/event/world/SpawnChangeEvent.java b/paper-api/src/main/java/org/bukkit/event/world/SpawnChangeEvent.java new file mode 100644 index 0000000000..02159d01d4 --- /dev/null +++ b/paper-api/src/main/java/org/bukkit/event/world/SpawnChangeEvent.java @@ -0,0 +1,28 @@ +package org.bukkit.event.world; + +import org.bukkit.World; +import org.bukkit.Location; + +/** + * An event that is called when a world's spawn changes. The + * world's previous spawn location is included. + * + * @author willurd + */ +public class SpawnChangeEvent extends WorldEvent { + private Location previousLocation; + + public SpawnChangeEvent(World world, Location previousLocation) { + super(Type.SPAWN_CHANGE, world); + this.previousLocation = previousLocation; + } + + /** + * Gets the previous spawn location + * + * @return Location that used to be spawn + */ + public Location getPreviousLocation() { + return previousLocation; + } +} diff --git a/paper-api/src/main/java/org/bukkit/event/world/WorldListener.java b/paper-api/src/main/java/org/bukkit/event/world/WorldListener.java index 0cdc7fcf1c..ef70af8389 100644 --- a/paper-api/src/main/java/org/bukkit/event/world/WorldListener.java +++ b/paper-api/src/main/java/org/bukkit/event/world/WorldListener.java @@ -24,6 +24,14 @@ public class WorldListener implements Listener { public void onChunkUnload(ChunkUnloadEvent event) { } + /** + * Called when a World's spawn is changed + * + * @param event Relevant event details + */ + public void onSpawnChange(SpawnChangeEvent event) { + } + /** * Called when a world is saved * 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 42d893d5a0..ceb750ad7e 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 @@ -379,6 +379,12 @@ public final class JavaPluginLoader implements PluginLoader { ((WorldListener) listener).onChunkUnload((ChunkUnloadEvent) event); } }; + case SPAWN_CHANGE: + return new EventExecutor() { + public void execute(Listener listener, Event event) { + ((WorldListener) listener).onSpawnChange((SpawnChangeEvent) event); + } + }; case WORLD_SAVE: return new EventExecutor() { public void execute(Listener listener, Event event) {