Add support for arbitrary event handler ordering.

This allows for 65,536 different orders, which should be more than enough for anyone.
This commit is contained in:
Andrew Steinborn
2020-10-22 01:02:40 -04:00
parent abfa05c249
commit 929d623be2
4 changed files with 13 additions and 9 deletions

View File

@@ -39,7 +39,7 @@ public interface EventManager {
* @param handler the handler to register
* @param <E> the event type to handle
*/
<E> void register(Object plugin, Class<E> eventClass, PostOrder postOrder,
<E> void register(Object plugin, Class<E> eventClass, short postOrder,
EventHandler<E> handler);
/**

View File

@@ -4,7 +4,12 @@ package com.velocitypowered.api.event;
* Represents the order an event will be posted to a listener method, relative to other listeners.
*/
public enum PostOrder {
;
FIRST, EARLY, NORMAL, LATE, LAST
public static final short FIRST = Short.MIN_VALUE;
public static final short EARLY = Short.MIN_VALUE >> 1;
public static final short NORMAL = 0;
public static final short LATE = Short.MAX_VALUE >> 1;
public static final short LAST = Short.MAX_VALUE;
}

View File

@@ -17,6 +17,6 @@ public @interface Subscribe {
*
* @return the order
*/
PostOrder order() default PostOrder.NORMAL;
short order() default PostOrder.NORMAL;
}

View File

@@ -94,11 +94,10 @@ public class VelocityEventManager implements EventManager {
@Override
@SuppressWarnings("type.argument.type.incompatible")
public <E> void register(Object plugin, Class<E> eventClass, PostOrder postOrder,
public <E> void register(Object plugin, Class<E> eventClass, short postOrder,
EventHandler<E> handler) {
ensurePlugin(plugin);
Preconditions.checkNotNull(eventClass, "eventClass");
Preconditions.checkNotNull(postOrder, "postOrder");
Preconditions.checkNotNull(handler, "listener");
registeredHandlersByPlugin.put(plugin, handler);
@@ -201,7 +200,7 @@ public class VelocityEventManager implements EventManager {
@Override
public int postOrder(@NonNull Object listener, @NonNull Method method) {
return method.getAnnotation(Subscribe.class).order().ordinal();
return method.getAnnotation(Subscribe.class).order();
}
@Override
@@ -213,11 +212,11 @@ public class VelocityEventManager implements EventManager {
private static class KyoriToVelocityHandler<E> implements EventSubscriber<E> {
private final EventHandler<E> handler;
private final int postOrder;
private final short postOrder;
private KyoriToVelocityHandler(EventHandler<E> handler, PostOrder postOrder) {
private KyoriToVelocityHandler(EventHandler<E> handler, short postOrder) {
this.handler = handler;
this.postOrder = postOrder.ordinal();
this.postOrder = postOrder;
}
@Override