mirror of
https://github.com/Minestom/Minestom.git
synced 2025-01-23 16:41:35 +01:00
Fix event calling
This commit is contained in:
parent
c3f52031e6
commit
bc2a075b60
@ -9,20 +9,18 @@ import java.util.function.Predicate;
|
|||||||
|
|
||||||
public class EventListener<T extends Event> {
|
public class EventListener<T extends Event> {
|
||||||
|
|
||||||
private final Consumer<T> combined;
|
protected final Class<T> type;
|
||||||
|
protected final Consumer<T> combined;
|
||||||
|
|
||||||
private EventListener(@NotNull Consumer<T> combined) {
|
private EventListener(@NotNull Class<T> type, @NotNull Consumer<T> combined) {
|
||||||
|
this.type = type;
|
||||||
this.combined = combined;
|
this.combined = combined;
|
||||||
}
|
}
|
||||||
|
|
||||||
public static <T extends Event> EventListener.Builder<T> of(Class<T> eventType) {
|
public static <T extends Event> EventListener.Builder<T> of(@NotNull Class<T> eventType) {
|
||||||
return new EventListener.Builder<>(eventType);
|
return new EventListener.Builder<>(eventType);
|
||||||
}
|
}
|
||||||
|
|
||||||
protected Consumer<T> getCombined() {
|
|
||||||
return combined;
|
|
||||||
}
|
|
||||||
|
|
||||||
public static class Builder<T extends Event> {
|
public static class Builder<T extends Event> {
|
||||||
|
|
||||||
private final Class<T> eventType;
|
private final Class<T> eventType;
|
||||||
@ -45,7 +43,7 @@ public class EventListener<T extends Event> {
|
|||||||
}
|
}
|
||||||
|
|
||||||
public EventListener<T> build() {
|
public EventListener<T> build() {
|
||||||
return new EventListener<>(event -> {
|
return new EventListener<>(eventType, event -> {
|
||||||
// Filtering
|
// Filtering
|
||||||
if (!filters.isEmpty()) {
|
if (!filters.isEmpty()) {
|
||||||
if (filters.stream().anyMatch(filter -> !filter.test(event))) {
|
if (filters.stream().anyMatch(filter -> !filter.test(event))) {
|
||||||
@ -53,7 +51,6 @@ public class EventListener<T extends Event> {
|
|||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
// Handler
|
// Handler
|
||||||
if (handler != null) {
|
if (handler != null) {
|
||||||
handler.accept(event);
|
handler.accept(event);
|
||||||
|
@ -4,6 +4,8 @@ import org.jetbrains.annotations.NotNull;
|
|||||||
|
|
||||||
import java.util.Collections;
|
import java.util.Collections;
|
||||||
import java.util.List;
|
import java.util.List;
|
||||||
|
import java.util.Map;
|
||||||
|
import java.util.concurrent.ConcurrentHashMap;
|
||||||
import java.util.concurrent.CopyOnWriteArrayList;
|
import java.util.concurrent.CopyOnWriteArrayList;
|
||||||
import java.util.function.Consumer;
|
import java.util.function.Consumer;
|
||||||
import java.util.function.Predicate;
|
import java.util.function.Predicate;
|
||||||
@ -11,7 +13,8 @@ import java.util.function.Predicate;
|
|||||||
public abstract class EventNode<T extends Event> {
|
public abstract class EventNode<T extends Event> {
|
||||||
|
|
||||||
private final String name = "debug";
|
private final String name = "debug";
|
||||||
private final List<EventListener<T>> listeners = new CopyOnWriteArrayList<>();
|
|
||||||
|
private final Map<Class<? extends T>, List<EventListener<T>>> listenerMap = new ConcurrentHashMap<>();
|
||||||
private final List<EventNode<T>> children = new CopyOnWriteArrayList<>();
|
private final List<EventNode<T>> children = new CopyOnWriteArrayList<>();
|
||||||
|
|
||||||
private static final EventNode<Event> EMPTY = new EventNode<>() {
|
private static final EventNode<Event> EMPTY = new EventNode<>() {
|
||||||
@ -27,7 +30,7 @@ public abstract class EventNode<T extends Event> {
|
|||||||
|
|
||||||
public static <E extends Event> EventNode<E> conditional(@NotNull Class<E> type,
|
public static <E extends Event> EventNode<E> conditional(@NotNull Class<E> type,
|
||||||
@NotNull Predicate<E> predicate) {
|
@NotNull Predicate<E> predicate) {
|
||||||
return new EventNodeConditional<>(predicate);
|
return new EventNodeConditional<>(type, predicate);
|
||||||
}
|
}
|
||||||
|
|
||||||
public static <E extends Event> EventNode<E> conditional(@NotNull Class<E> eventType) {
|
public static <E extends Event> EventNode<E> conditional(@NotNull Class<E> eventType) {
|
||||||
@ -39,7 +42,11 @@ public abstract class EventNode<T extends Event> {
|
|||||||
public void call(@NotNull T event) {
|
public void call(@NotNull T event) {
|
||||||
if (!isValid(event))
|
if (!isValid(event))
|
||||||
return;
|
return;
|
||||||
this.listeners.forEach(eventListener -> eventListener.getCombined().accept(event));
|
final var listeners = listenerMap.get(event.getClass());
|
||||||
|
if (listeners != null && !listeners.isEmpty()) {
|
||||||
|
listeners.forEach(eventListener ->
|
||||||
|
eventListener.combined.accept(event));
|
||||||
|
}
|
||||||
this.children.forEach(eventNode -> eventNode.call(event));
|
this.children.forEach(eventNode -> eventNode.call(event));
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -48,7 +55,8 @@ public abstract class EventNode<T extends Event> {
|
|||||||
}
|
}
|
||||||
|
|
||||||
public void addListener(@NotNull EventListener<? extends T> listener) {
|
public void addListener(@NotNull EventListener<? extends T> listener) {
|
||||||
this.listeners.add((EventListener<T>) listener);
|
this.listenerMap.computeIfAbsent(listener.type, aClass -> new CopyOnWriteArrayList<>())
|
||||||
|
.add((EventListener<T>) listener);
|
||||||
}
|
}
|
||||||
|
|
||||||
public <E extends T> void addListener(@NotNull Class<E> eventClass, @NotNull Consumer<@NotNull E> listener) {
|
public <E extends T> void addListener(@NotNull Class<E> eventClass, @NotNull Consumer<@NotNull E> listener) {
|
||||||
|
@ -6,22 +6,25 @@ import java.util.function.Predicate;
|
|||||||
|
|
||||||
public class EventNodeConditional<T extends Event> extends EventNode<T> {
|
public class EventNodeConditional<T extends Event> extends EventNode<T> {
|
||||||
|
|
||||||
|
private final Class<T> type;
|
||||||
private volatile Predicate<T> predicate;
|
private volatile Predicate<T> predicate;
|
||||||
|
|
||||||
protected EventNodeConditional(Predicate<T> predicate) {
|
protected EventNodeConditional(Class<T> type, Predicate<T> predicate) {
|
||||||
|
this.type = type;
|
||||||
this.predicate = predicate;
|
this.predicate = predicate;
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
protected boolean isValid(@NotNull T event) {
|
protected boolean isValid(@NotNull T event) {
|
||||||
return predicate.test(event);
|
final boolean typeCheck = type.isAssignableFrom(event.getClass());
|
||||||
|
return typeCheck && predicate.test(event);
|
||||||
}
|
}
|
||||||
|
|
||||||
public Predicate<T> getPredicate() {
|
public @NotNull Predicate<@NotNull T> getPredicate() {
|
||||||
return predicate;
|
return predicate;
|
||||||
}
|
}
|
||||||
|
|
||||||
public void setPredicate(Predicate<T> predicate) {
|
public void setPredicate(@NotNull Predicate<@NotNull T> predicate) {
|
||||||
this.predicate = predicate;
|
this.predicate = predicate;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user