Added ChunkPopulateEvent, new "newChunk" property on ChunkLoadEvent

By: Dinnerbone <dinnerbone@dinnerbone.com>
This commit is contained in:
Bukkit/Spigot 2011-06-16 19:32:14 +01:00
parent caf78a759e
commit ae44a5e666
5 changed files with 51 additions and 4 deletions

View file

@ -455,11 +455,13 @@ public abstract class Event implements Serializable {
*/
CHUNK_UNLOAD (Category.WORLD),
/**
* Called when a chunk needs to be generated
* Called when a newly created chunk has been populated.
*
* @todo: add javadoc see comment
* If your intent is to populate the chunk using this event, please see {@link BlockPopulator}
*
* @see org.bukkit.event.world.ChunkPopulateEvent
*/
CHUNK_GENERATION (Category.WORLD),
CHUNK_POPULATED (Category.WORLD),
/**
* Called when an ItemEntity spawns in the world
*

View file

@ -6,7 +6,20 @@ import org.bukkit.Chunk;
* Called when a chunk is loaded
*/
public class ChunkLoadEvent extends ChunkEvent {
public ChunkLoadEvent(final Chunk chunk) {
private final boolean newChunk;
public ChunkLoadEvent(final Chunk chunk, final boolean newChunk) {
super(Type.CHUNK_LOAD, chunk);
this.newChunk = newChunk;
}
/**
* Gets if this chunk was newly created or not.
* Note that if this chunk is new, it will not be populated at this time.
*
* @return true if the chunk is new, otherwise false
*/
public boolean isNewChunk() {
return newChunk;
}
}

View file

@ -0,0 +1,16 @@
package org.bukkit.event.world;
import org.bukkit.Chunk;
import org.bukkit.generator.BlockPopulator;
/**
* Thrown when a new chunk has finished being populated.
*
* If your intent is to populate the chunk using this event, please see {@link BlockPopulator}
*/
public class ChunkPopulateEvent extends ChunkEvent {
public ChunkPopulateEvent(final Chunk chunk) {
super(Type.CHUNK_POPULATED, chunk);
}
}

View file

@ -15,6 +15,15 @@ public class WorldListener implements Listener {
*/
public void onChunkLoad(ChunkLoadEvent event) {}
/**
* Called when a newly created chunk has been populated.
*
* If your intent is to populate the chunk using this event, please see {@link BlockPopulator}
*
* @param event Relevant event details
*/
public void onChunkPopulate(ChunkPopulateEvent event) {}
/**
* Called when a chunk is unloaded
*

View file

@ -526,6 +526,13 @@ public final class JavaPluginLoader implements PluginLoader {
((WorldListener) listener).onChunkLoad((ChunkLoadEvent) event);
}
};
case CHUNK_POPULATED:
return new EventExecutor() {
public void execute(Listener listener, Event event) {
((WorldListener) listener).onChunkPopulate((ChunkPopulateEvent) event);
}
};
case CHUNK_UNLOAD:
return new EventExecutor() {