mirror of
https://github.com/PaperMC/Paper.git
synced 2025-01-16 06:30:46 +01:00
Eventing redone, revision 1
By: durron597 <martin.jared@gmail.com>
This commit is contained in:
parent
e364e973c7
commit
ed3dcbdd2b
8 changed files with 214 additions and 44 deletions
|
@ -4,7 +4,7 @@ package com.dinnerbone.bukkit.sample;
|
||||||
import java.io.File;
|
import java.io.File;
|
||||||
import org.bukkit.Server;
|
import org.bukkit.Server;
|
||||||
import org.bukkit.event.Event.Priority;
|
import org.bukkit.event.Event.Priority;
|
||||||
import org.bukkit.event.player.PlayerEvent.EventType;
|
import org.bukkit.event.Event;
|
||||||
import org.bukkit.plugin.PluginDescriptionFile;
|
import org.bukkit.plugin.PluginDescriptionFile;
|
||||||
import org.bukkit.plugin.PluginLoader;
|
import org.bukkit.plugin.PluginLoader;
|
||||||
import org.bukkit.plugin.java.JavaPlugin;
|
import org.bukkit.plugin.java.JavaPlugin;
|
||||||
|
@ -34,7 +34,7 @@ public class SamplePlugin extends JavaPlugin {
|
||||||
}
|
}
|
||||||
|
|
||||||
private void registerEvents() {
|
private void registerEvents() {
|
||||||
getServer().getPluginManager().registerEvent(EventType.Join, playerListener, Priority.Normal, this);
|
getServer().getPluginManager().registerEvent(Event.Type.JOIN, playerListener, Priority.Normal, this);
|
||||||
getServer().getPluginManager().registerEvent(EventType.Quit, playerListener, Priority.Normal, this);
|
getServer().getPluginManager().registerEvent(Event.Type.QUIT, playerListener, Priority.Normal, this);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -1,16 +1,20 @@
|
||||||
|
|
||||||
package org.bukkit.event;
|
package org.bukkit.event;
|
||||||
|
|
||||||
|
import org.bukkit.Player;
|
||||||
import org.bukkit.Server;
|
import org.bukkit.Server;
|
||||||
|
import org.bukkit.event.player.PlayerEvent;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Represents an event
|
* Represents an event
|
||||||
*/
|
*/
|
||||||
public abstract class Event {
|
public abstract class Event {
|
||||||
private final Server server;
|
private final Server server;
|
||||||
|
private final Type type;
|
||||||
|
|
||||||
protected Event(final Server instance) {
|
protected Event(final Server instance, final Type type) {
|
||||||
server = instance;
|
server = instance;
|
||||||
|
this.type = type;
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -21,6 +25,14 @@ public abstract class Event {
|
||||||
return server;
|
return server;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Gets the Type of this event
|
||||||
|
* @return Server which this event was triggered on
|
||||||
|
*/
|
||||||
|
public Type getType() {
|
||||||
|
return type;
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Represents an events priority
|
* Represents an events priority
|
||||||
*/
|
*/
|
||||||
|
@ -50,4 +62,125 @@ public abstract class Event {
|
||||||
*/
|
*/
|
||||||
Lowest
|
Lowest
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public enum Category {
|
||||||
|
PLAYER,
|
||||||
|
BLOCK,
|
||||||
|
ITEM,
|
||||||
|
ENVIRONMENT,
|
||||||
|
ENTITY,
|
||||||
|
VEHICLE,
|
||||||
|
INVENTORY,
|
||||||
|
SIGN,
|
||||||
|
CUSTOM;
|
||||||
|
}
|
||||||
|
|
||||||
|
public enum Type {
|
||||||
|
/**
|
||||||
|
* Player Events
|
||||||
|
*/
|
||||||
|
LOGINCHECK (Category.PLAYER),
|
||||||
|
JOIN (Category.PLAYER),
|
||||||
|
CHAT (Category.PLAYER),
|
||||||
|
COMMAND (Category.PLAYER),
|
||||||
|
SERVERCOMMAND (Category.PLAYER),
|
||||||
|
BAN (Category.PLAYER),
|
||||||
|
IPBAN (Category.PLAYER),
|
||||||
|
KICK (Category.PLAYER),
|
||||||
|
QUIT (Category.PLAYER),
|
||||||
|
PLAYER_MOVE (Category.PLAYER),
|
||||||
|
ARM_SWING (Category.PLAYER),
|
||||||
|
TELEPORT (Category.PLAYER),
|
||||||
|
/**
|
||||||
|
* Block Events
|
||||||
|
*/
|
||||||
|
BLOCK_DESTROYED (Category.BLOCK),
|
||||||
|
BLOCK_BROKEN (Category.BLOCK),
|
||||||
|
BLOCK_PLACE (Category.BLOCK),
|
||||||
|
BLOCK_RIGHTCLICKED (Category.BLOCK),
|
||||||
|
REDSTONE_CHANGE (Category.BLOCK),
|
||||||
|
BLOCK_PHYSICS (Category.BLOCK),
|
||||||
|
/**
|
||||||
|
* Item Events
|
||||||
|
*/
|
||||||
|
ITEM_DROP (Category.ITEM),
|
||||||
|
ITEM_PICK_UP (Category.ITEM),
|
||||||
|
ITEM_USE (Category.ITEM),
|
||||||
|
/**
|
||||||
|
* Environment Events
|
||||||
|
*/
|
||||||
|
IGNITE (Category.ENVIRONMENT),
|
||||||
|
FLOW (Category.ENVIRONMENT),
|
||||||
|
EXPLODE (Category.ENVIRONMENT),
|
||||||
|
LIQUID_DESTROY (Category.ENVIRONMENT),
|
||||||
|
/**
|
||||||
|
* Non-player Entity Events
|
||||||
|
*/
|
||||||
|
MOB_SPAWN (Category.ENTITY),
|
||||||
|
DAMAGE (Category.ENTITY),
|
||||||
|
HEALTH_CHANGE (Category.ENTITY),
|
||||||
|
ATTACK (Category.ENTITY), // Need to look into this category more
|
||||||
|
/**
|
||||||
|
* Vehicle Events
|
||||||
|
*/
|
||||||
|
VEHICLE_CREATE (Category.VEHICLE),
|
||||||
|
VEHICLE_UPDATE (Category.VEHICLE),
|
||||||
|
VEHICLE_DAMAGE (Category.VEHICLE),
|
||||||
|
VEHICLE_COLLISION (Category.VEHICLE),
|
||||||
|
VEHICLE_DESTROYED (Category.VEHICLE),
|
||||||
|
VEHICLE_ENTERED (Category.VEHICLE),
|
||||||
|
VEHICLE_POSITIONCHANGE (Category.VEHICLE),
|
||||||
|
/**
|
||||||
|
* Inventory Events
|
||||||
|
*/
|
||||||
|
OPEN_INVENTORY (Category.INVENTORY),
|
||||||
|
/**
|
||||||
|
* Sign Events (Item events??)
|
||||||
|
*/
|
||||||
|
SIGN_SHOW (Category.SIGN),
|
||||||
|
SIGN_CHANGE (Category.SIGN),
|
||||||
|
/**
|
||||||
|
* Custom Event Placeholder?
|
||||||
|
*/
|
||||||
|
CUSTOM_EVENT (Category.CUSTOM);
|
||||||
|
|
||||||
|
private Category category;
|
||||||
|
|
||||||
|
private Type(Category category) {
|
||||||
|
this.category = category;
|
||||||
|
}
|
||||||
|
|
||||||
|
public Category getCategory() {
|
||||||
|
return category;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
public static Event eventFactory(Server server, Event.Type type, Object[] data) throws EventException {
|
||||||
|
switch (type.getCategory()) {
|
||||||
|
case PLAYER:
|
||||||
|
if (data.length < 1 || !(data[0] instanceof Player)) {
|
||||||
|
throw new EventException("Data is not a Player!");
|
||||||
|
}
|
||||||
|
return new PlayerEvent(server, type, (Player) data[0]);
|
||||||
|
// TODO: IMPLEMENT ME
|
||||||
|
case BLOCK:
|
||||||
|
return null;
|
||||||
|
case ITEM:
|
||||||
|
return null;
|
||||||
|
case ENVIRONMENT:
|
||||||
|
return null;
|
||||||
|
case ENTITY:
|
||||||
|
return null;
|
||||||
|
case VEHICLE:
|
||||||
|
return null;
|
||||||
|
case INVENTORY:
|
||||||
|
return null;
|
||||||
|
case SIGN:
|
||||||
|
return null;
|
||||||
|
case CUSTOM:
|
||||||
|
return null;
|
||||||
|
default:
|
||||||
|
return null;
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
47
paper-api/src/org/bukkit/event/EventException.java
Normal file
47
paper-api/src/org/bukkit/event/EventException.java
Normal file
|
@ -0,0 +1,47 @@
|
||||||
|
package org.bukkit.event;
|
||||||
|
|
||||||
|
public class EventException extends Exception {
|
||||||
|
private final Throwable cause;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Constructs a new EventException based on the given Exception
|
||||||
|
*
|
||||||
|
* @param throwable Exception that triggered this Exception
|
||||||
|
*/
|
||||||
|
public EventException(Throwable throwable) {
|
||||||
|
cause = throwable;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Constructs a new EventException
|
||||||
|
*/
|
||||||
|
public EventException() {
|
||||||
|
cause = null;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Constructs a new EventException with the given message
|
||||||
|
*/
|
||||||
|
public EventException(Throwable cause, String message) {
|
||||||
|
super(message);
|
||||||
|
this.cause = cause;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Constructs a new EventException with the given message
|
||||||
|
*/
|
||||||
|
public EventException(String message) {
|
||||||
|
super(message);
|
||||||
|
cause = null;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* If applicable, returns the Exception that triggered this Exception
|
||||||
|
*
|
||||||
|
* @return Inner exception, or null if one does not exist
|
||||||
|
*/
|
||||||
|
@Override
|
||||||
|
public Throwable getCause() {
|
||||||
|
return cause;
|
||||||
|
}
|
||||||
|
}
|
|
@ -11,8 +11,8 @@ import org.bukkit.event.Event;
|
||||||
public class PlayerEvent extends Event {
|
public class PlayerEvent extends Event {
|
||||||
private final Player player;
|
private final Player player;
|
||||||
|
|
||||||
public PlayerEvent(final Server server, final Player who) {
|
public PlayerEvent(final Server server, Event.Type type, final Player who) {
|
||||||
super(server);
|
super(server, type);
|
||||||
player = who;
|
player = who;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -23,18 +23,4 @@ public class PlayerEvent extends Event {
|
||||||
public final Player getPlayer() {
|
public final Player getPlayer() {
|
||||||
return player;
|
return player;
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
|
||||||
* Represents the different types of events
|
|
||||||
*/
|
|
||||||
public enum EventType {
|
|
||||||
/**
|
|
||||||
* A player joins a server
|
|
||||||
*/
|
|
||||||
Join,
|
|
||||||
/**
|
|
||||||
* A player leaves a server
|
|
||||||
*/
|
|
||||||
Quit
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
|
@ -3,7 +3,8 @@ package org.bukkit.plugin;
|
||||||
|
|
||||||
import java.io.File;
|
import java.io.File;
|
||||||
import java.util.regex.Pattern;
|
import java.util.regex.Pattern;
|
||||||
import org.bukkit.event.player.PlayerEvent;
|
|
||||||
|
import org.bukkit.event.Event;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Represents a plugin loader, which handles direct access to specific types
|
* Represents a plugin loader, which handles direct access to specific types
|
||||||
|
@ -32,5 +33,5 @@ public interface PluginLoader {
|
||||||
* @param type Type of player related event to call
|
* @param type Type of player related event to call
|
||||||
* @param event Event details
|
* @param event Event details
|
||||||
*/
|
*/
|
||||||
public void callEvent(RegisteredListener registration, PlayerEvent.EventType type, PlayerEvent event);
|
public void callEvent(RegisteredListener registration, Event event);
|
||||||
}
|
}
|
||||||
|
|
|
@ -2,9 +2,10 @@
|
||||||
package org.bukkit.plugin;
|
package org.bukkit.plugin;
|
||||||
|
|
||||||
import java.io.File;
|
import java.io.File;
|
||||||
|
|
||||||
|
import org.bukkit.event.Event;
|
||||||
import org.bukkit.event.Event.Priority;
|
import org.bukkit.event.Event.Priority;
|
||||||
import org.bukkit.event.player.PlayerEvent;
|
import org.bukkit.event.Listener;
|
||||||
import org.bukkit.event.player.PlayerListener;
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Handles all plugin management from the Server
|
* Handles all plugin management from the Server
|
||||||
|
@ -72,15 +73,15 @@ public interface PluginManager {
|
||||||
* @param type Type of player related event to call
|
* @param type Type of player related event to call
|
||||||
* @param event Event details
|
* @param event Event details
|
||||||
*/
|
*/
|
||||||
public void callEvent(PlayerEvent.EventType type, PlayerEvent event);
|
public void callEvent(Event event);
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Registers the given player event to the specified listener
|
* Registers the given player event to the specified listener
|
||||||
*
|
*
|
||||||
* @param type EventType to register
|
* @param type EventType to register
|
||||||
* @param listener PlayerListener to register
|
* @param listener Listener to register
|
||||||
* @param priority Priority of this event
|
* @param priority Priority of this event
|
||||||
* @param plugin Plugin to register
|
* @param plugin Plugin to register
|
||||||
*/
|
*/
|
||||||
public void registerEvent(PlayerEvent.EventType type, PlayerListener listener, Priority priority, Plugin plugin);
|
public void registerEvent(Event.Type type, Listener listener, Priority priority, Plugin plugin);
|
||||||
}
|
}
|
||||||
|
|
|
@ -14,9 +14,10 @@ import java.util.logging.Logger;
|
||||||
import java.util.regex.Matcher;
|
import java.util.regex.Matcher;
|
||||||
import org.bukkit.Server;
|
import org.bukkit.Server;
|
||||||
import java.util.regex.Pattern;
|
import java.util.regex.Pattern;
|
||||||
|
|
||||||
|
import org.bukkit.event.Event;
|
||||||
import org.bukkit.event.Event.Priority;
|
import org.bukkit.event.Event.Priority;
|
||||||
import org.bukkit.event.player.PlayerEvent;
|
import org.bukkit.event.Listener;
|
||||||
import org.bukkit.event.player.PlayerListener;
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Handles all plugin management from the Server
|
* Handles all plugin management from the Server
|
||||||
|
@ -26,7 +27,7 @@ public final class SimplePluginManager implements PluginManager {
|
||||||
private final Map<Pattern, PluginLoader> fileAssociations = new HashMap<Pattern, PluginLoader>();
|
private final Map<Pattern, PluginLoader> fileAssociations = new HashMap<Pattern, PluginLoader>();
|
||||||
private final List<Plugin> plugins = new ArrayList<Plugin>();
|
private final List<Plugin> plugins = new ArrayList<Plugin>();
|
||||||
private final Map<String, Plugin> lookupNames = new HashMap<String, Plugin>();
|
private final Map<String, Plugin> lookupNames = new HashMap<String, Plugin>();
|
||||||
private final Map<PlayerEvent.EventType, List<RegisteredListener>> playerListeners = new EnumMap<PlayerEvent.EventType, List<RegisteredListener>>(PlayerEvent.EventType.class);
|
private final Map<Event.Type, List<RegisteredListener>> listeners = new EnumMap<Event.Type, List<RegisteredListener>>(Event.Type.class);
|
||||||
|
|
||||||
public SimplePluginManager(Server instance) {
|
public SimplePluginManager(Server instance) {
|
||||||
server = instance;
|
server = instance;
|
||||||
|
@ -166,16 +167,16 @@ public final class SimplePluginManager implements PluginManager {
|
||||||
* @param type Type of player related event to call
|
* @param type Type of player related event to call
|
||||||
* @param event Event details
|
* @param event Event details
|
||||||
*/
|
*/
|
||||||
public void callEvent(PlayerEvent.EventType type, PlayerEvent event) {
|
public void callEvent(Event event) {
|
||||||
List<RegisteredListener> listeners = playerListeners.get(type);
|
List<RegisteredListener> eventListeners = listeners.get(event.getType());
|
||||||
|
|
||||||
if (listeners != null) {
|
if (listeners != null) {
|
||||||
for (RegisteredListener registration : listeners) {
|
for (RegisteredListener registration : eventListeners) {
|
||||||
Plugin plugin = registration.getPlugin();
|
Plugin plugin = registration.getPlugin();
|
||||||
PluginLoader loader = plugin.getPluginLoader();
|
PluginLoader loader = plugin.getPluginLoader();
|
||||||
|
|
||||||
if (plugin.isEnabled()) {
|
if (plugin.isEnabled()) {
|
||||||
loader.callEvent(registration, type, event);
|
loader.callEvent(registration, event);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -189,12 +190,12 @@ public final class SimplePluginManager implements PluginManager {
|
||||||
* @param priority Priority of this event
|
* @param priority Priority of this event
|
||||||
* @param plugin Plugin to register
|
* @param plugin Plugin to register
|
||||||
*/
|
*/
|
||||||
public void registerEvent(PlayerEvent.EventType type, PlayerListener listener, Priority priority, Plugin plugin) {
|
public void registerEvent(Event.Type type, Listener listener, Priority priority, Plugin plugin) {
|
||||||
List<RegisteredListener> listeners = playerListeners.get(type);
|
List<RegisteredListener> eventListeners = listeners.get(type);
|
||||||
int position = 0;
|
int position = 0;
|
||||||
|
|
||||||
if (listeners != null) {
|
if (listeners != null) {
|
||||||
for (RegisteredListener registration : listeners) {
|
for (RegisteredListener registration : eventListeners) {
|
||||||
if (registration.getPriority().compareTo(priority) < 0) {
|
if (registration.getPriority().compareTo(priority) < 0) {
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
@ -202,10 +203,10 @@ public final class SimplePluginManager implements PluginManager {
|
||||||
position++;
|
position++;
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
listeners = new ArrayList<RegisteredListener>();
|
eventListeners = new ArrayList<RegisteredListener>();
|
||||||
playerListeners.put(type, listeners);
|
listeners.put(type, eventListeners);
|
||||||
}
|
}
|
||||||
|
|
||||||
listeners.add(position, new RegisteredListener(listener, priority, plugin));
|
eventListeners.add(position, new RegisteredListener(listener, priority, plugin));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -13,6 +13,7 @@ import java.util.jar.JarEntry;
|
||||||
import java.util.jar.JarFile;
|
import java.util.jar.JarFile;
|
||||||
import java.util.regex.Pattern;
|
import java.util.regex.Pattern;
|
||||||
import org.bukkit.Server;
|
import org.bukkit.Server;
|
||||||
|
import org.bukkit.event.Event;
|
||||||
import org.bukkit.event.Listener;
|
import org.bukkit.event.Listener;
|
||||||
import org.bukkit.event.player.*;
|
import org.bukkit.event.player.*;
|
||||||
import org.bukkit.plugin.*;
|
import org.bukkit.plugin.*;
|
||||||
|
@ -74,17 +75,17 @@ public final class JavaPluginLoader implements PluginLoader {
|
||||||
return fileFilters;
|
return fileFilters;
|
||||||
}
|
}
|
||||||
|
|
||||||
public void callEvent(RegisteredListener registration, PlayerEvent.EventType type, PlayerEvent event) {
|
public void callEvent(RegisteredListener registration, Event event) {
|
||||||
Listener listener = registration.getListener();
|
Listener listener = registration.getListener();
|
||||||
|
|
||||||
if (listener instanceof PlayerListener) {
|
if (listener instanceof PlayerListener) {
|
||||||
PlayerListener trueListener = (PlayerListener)listener;
|
PlayerListener trueListener = (PlayerListener)listener;
|
||||||
|
|
||||||
switch (type) {
|
switch (event.getType()) {
|
||||||
case Join:
|
case JOIN:
|
||||||
trueListener.onPlayerJoin((PlayerEvent)event);
|
trueListener.onPlayerJoin((PlayerEvent)event);
|
||||||
break;
|
break;
|
||||||
case Quit:
|
case QUIT:
|
||||||
trueListener.onPlayerQuit((PlayerEvent)event);
|
trueListener.onPlayerQuit((PlayerEvent)event);
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in a new issue