This commit is contained in:
TheMode 2021-08-20 10:13:08 +02:00
parent a365676848
commit 9a4ced9a6e

View File

@ -238,15 +238,14 @@ class EventNodeImpl<T extends Event> implements EventNode<T> {
} }
private void propagateEvent(Class<? extends T> eventClass) { private void propagateEvent(Class<? extends T> eventClass) {
// Recursive event forTargetEvents(eventClass, type -> {
forEachRecursive(eventType, recursiveClass -> propagateEvent((Class<? extends T>) recursiveClass));
// Propagate
final var parent = this.parent; final var parent = this.parent;
if (parent == null) return; if (parent == null) return;
Handle<? super T> parentHandle = parent.handleMap.get(eventClass); Handle<? super T> parentHandle = parent.handleMap.get(type);
if (parentHandle == null) return; if (parentHandle == null) return;
parentHandle.updated = false; parentHandle.updated = false;
parent.propagateEvent(eventClass); parent.propagateEvent((Class<? extends T>) type);
});
} }
private ListenerEntry<T> getEntry(Class<? extends T> type) { private ListenerEntry<T> getEntry(Class<? extends T> type) {
@ -259,17 +258,14 @@ class EventNodeImpl<T extends Event> implements EventNode<T> {
return nameCheck && typeCheck; return nameCheck && typeCheck;
} }
private static boolean isRecursive(Class<?> type) { private static void forTargetEvents(Class<?> type, Consumer<Class<?>> consumer) {
if (type == null) return false; consumer.accept(type);
return RecursiveEvent.class.isAssignableFrom(type); // Recursion
} if (RecursiveEvent.class.isAssignableFrom(type)) {
private static void forEachRecursive(Class<?> type, Consumer<Class<? extends RecursiveEvent>> consumer) {
if (isRecursive(type)) {
final var superclass = type.getSuperclass(); final var superclass = type.getSuperclass();
if (isRecursive(superclass)) consumer.accept((Class<? extends RecursiveEvent>) superclass); if (superclass != null && RecursiveEvent.class.isAssignableFrom(superclass)) consumer.accept(superclass);
for (var inter : type.getInterfaces()) { for (var inter : type.getInterfaces()) {
if (isRecursive(inter)) consumer.accept((Class<? extends RecursiveEvent>) inter); if (RecursiveEvent.class.isAssignableFrom(inter)) consumer.accept(inter);
} }
} }
} }
@ -300,12 +296,9 @@ class EventNodeImpl<T extends Event> implements EventNode<T> {
private void recursiveUpdate(EventNodeImpl<E> targetNode) { private void recursiveUpdate(EventNodeImpl<E> targetNode) {
final var handleType = eventType; final var handleType = eventType;
ListenerEntry<E> entry = targetNode.listenerMap.get(handleType); forTargetEvents(handleType, type -> {
ListenerEntry<E> entry = targetNode.listenerMap.get(type);
if (entry != null) appendEntry(listeners, entry, targetNode); if (entry != null) appendEntry(listeners, entry, targetNode);
// Recursive event
forEachRecursive(eventType, recursiveClass -> {
ListenerEntry<E> recursiveEntry = targetNode.listenerMap.get(recursiveClass);
if (recursiveEntry != null) appendEntry(listeners, recursiveEntry, targetNode);
}); });
// Add children // Add children
final var children = targetNode.children; final var children = targetNode.children;