From c5e76ed156140383c70f7276074b0090f03813d8 Mon Sep 17 00:00:00 2001 From: Emmanuel Lampe Date: Wed, 20 Mar 2024 04:13:16 +0100 Subject: [PATCH] feat(event): event listener builder This commit adds the option to create event listeners with filters in a builder style --- .../boilerplate/event/BukkitEventBus.java | 42 ------- .../rexlmanu/boilerplate/event/EventBus.java | 2 + .../event/EventListenerBuilder.java | 17 +++ .../boilerplate/event/EventModule.java | 1 + .../event/impl/BukkitEventBus.java | 105 ++++++++++++++++++ .../listener/ExamplePlayerJoinListener.java | 9 +- 6 files changed, 132 insertions(+), 44 deletions(-) delete mode 100644 src/main/java/de/rexlmanu/boilerplate/event/BukkitEventBus.java create mode 100644 src/main/java/de/rexlmanu/boilerplate/event/EventListenerBuilder.java create mode 100644 src/main/java/de/rexlmanu/boilerplate/event/impl/BukkitEventBus.java diff --git a/src/main/java/de/rexlmanu/boilerplate/event/BukkitEventBus.java b/src/main/java/de/rexlmanu/boilerplate/event/BukkitEventBus.java deleted file mode 100644 index b38f389..0000000 --- a/src/main/java/de/rexlmanu/boilerplate/event/BukkitEventBus.java +++ /dev/null @@ -1,42 +0,0 @@ -package de.rexlmanu.boilerplate.event; - -import com.google.inject.Inject; -import com.google.inject.Singleton; -import java.util.function.Consumer; -import lombok.RequiredArgsConstructor; -import org.bukkit.Bukkit; -import org.bukkit.event.Event; -import org.bukkit.event.EventPriority; -import org.bukkit.event.HandlerList; -import org.bukkit.event.Listener; -import org.bukkit.plugin.java.JavaPlugin; - -@Singleton -@RequiredArgsConstructor(onConstructor = @__(@Inject)) -public class BukkitEventBus implements EventBus { - private final JavaPlugin plugin; - - @Override - public Listener subscribe( - Class eventType, Consumer action, EventPriority priority, boolean ignoreCancelled) { - Listener eventListener = new Listener() {}; - Bukkit.getPluginManager() - .registerEvent( - eventType, - eventListener, - priority, - (listener, event) -> { - if (eventType.isInstance(event)) { - action.accept(eventType.cast(event)); - } - }, - this.plugin, - ignoreCancelled); - return eventListener; - } - - @Override - public void unsubscribe(Listener listener) { - HandlerList.unregisterAll(listener); - } -} diff --git a/src/main/java/de/rexlmanu/boilerplate/event/EventBus.java b/src/main/java/de/rexlmanu/boilerplate/event/EventBus.java index 31344cd..a0c9000 100644 --- a/src/main/java/de/rexlmanu/boilerplate/event/EventBus.java +++ b/src/main/java/de/rexlmanu/boilerplate/event/EventBus.java @@ -18,5 +18,7 @@ default Listener subscribe(Class eventType, Consumer act return this.subscribe(eventType, action, EventPriority.NORMAL); } + EventListenerBuilder on(Class eventType); + void unsubscribe(Listener listener); } diff --git a/src/main/java/de/rexlmanu/boilerplate/event/EventListenerBuilder.java b/src/main/java/de/rexlmanu/boilerplate/event/EventListenerBuilder.java new file mode 100644 index 0000000..e0d691a --- /dev/null +++ b/src/main/java/de/rexlmanu/boilerplate/event/EventListenerBuilder.java @@ -0,0 +1,17 @@ +package de.rexlmanu.boilerplate.event; + +import java.util.function.Consumer; +import java.util.function.Predicate; +import org.bukkit.event.Event; +import org.bukkit.event.EventPriority; +import org.bukkit.event.Listener; + +public interface EventListenerBuilder { + EventListenerBuilder priority(EventPriority priority); + + EventListenerBuilder ignoreCancelled(boolean ignoreCancelled); + + EventListenerBuilder filter(Predicate predicate); + + Listener subscribe(Consumer action); +} diff --git a/src/main/java/de/rexlmanu/boilerplate/event/EventModule.java b/src/main/java/de/rexlmanu/boilerplate/event/EventModule.java index 94c7f80..cc662c0 100644 --- a/src/main/java/de/rexlmanu/boilerplate/event/EventModule.java +++ b/src/main/java/de/rexlmanu/boilerplate/event/EventModule.java @@ -6,6 +6,7 @@ import com.google.inject.spi.InjectionListener; import com.google.inject.spi.TypeEncounter; import com.google.inject.spi.TypeListener; +import de.rexlmanu.boilerplate.event.impl.BukkitEventBus; import lombok.RequiredArgsConstructor; import org.bukkit.event.HandlerList; import org.bukkit.event.Listener; diff --git a/src/main/java/de/rexlmanu/boilerplate/event/impl/BukkitEventBus.java b/src/main/java/de/rexlmanu/boilerplate/event/impl/BukkitEventBus.java new file mode 100644 index 0000000..fafff7f --- /dev/null +++ b/src/main/java/de/rexlmanu/boilerplate/event/impl/BukkitEventBus.java @@ -0,0 +1,105 @@ +package de.rexlmanu.boilerplate.event.impl; + +import com.google.inject.Inject; +import com.google.inject.Singleton; +import de.rexlmanu.boilerplate.event.EventBus; +import de.rexlmanu.boilerplate.event.EventListenerBuilder; +import java.util.function.Consumer; +import java.util.function.Predicate; +import lombok.RequiredArgsConstructor; +import org.bukkit.Bukkit; +import org.bukkit.event.Event; +import org.bukkit.event.EventPriority; +import org.bukkit.event.HandlerList; +import org.bukkit.event.Listener; +import org.bukkit.plugin.java.JavaPlugin; + +@Singleton +@RequiredArgsConstructor(onConstructor = @__(@Inject)) +public class BukkitEventBus implements EventBus { + private final JavaPlugin plugin; + + @Override + public Listener subscribe( + Class eventType, Consumer action, EventPriority priority, boolean ignoreCancelled) { + Listener eventListener = new Listener() {}; + Bukkit.getPluginManager() + .registerEvent( + eventType, + eventListener, + priority, + (listener, event) -> { + if (eventType.isInstance(event)) { + action.accept(eventType.cast(event)); + } + }, + this.plugin, + ignoreCancelled); + return eventListener; + } + + @Override + public EventListenerBuilder on(Class eventType) { + return new EventListenerBuilderImpl<>(eventType, this.plugin); + } + + @Override + public void unsubscribe(Listener listener) { + HandlerList.unregisterAll(listener); + } + + @RequiredArgsConstructor + static class EventListenerBuilderImpl implements EventListenerBuilder { + private EventPriority priority = EventPriority.NORMAL; + private boolean ignoreCancelled = false; + private Consumer action; + private Predicate predicate = null; + + private final Class eventType; + private final JavaPlugin plugin; + + @Override + public EventListenerBuilder priority(EventPriority priority) { + this.priority = priority; + return this; + } + + @Override + public EventListenerBuilder ignoreCancelled(boolean ignoreCancelled) { + this.ignoreCancelled = ignoreCancelled; + return this; + } + + @Override + public EventListenerBuilder filter(Predicate predicate) { + if (this.predicate == null) { + this.predicate = predicate; + } else { + this.predicate = this.predicate.and(predicate); + } + return this; + } + + @Override + public Listener subscribe(Consumer action) { + this.action = action; + Listener eventListener = new Listener() {}; + Bukkit.getPluginManager() + .registerEvent( + this.eventType, + eventListener, + this.priority, + (listener, event) -> { + if (this.eventType.isInstance(event)) { + T castedEvent = this.eventType.cast(event); + if (this.predicate == null || this.predicate.test(castedEvent)) { + this.action.accept(castedEvent); + } + } + }, + this.plugin, + this.ignoreCancelled); + return eventListener; + } + } +} diff --git a/src/main/java/de/rexlmanu/paperpluginstarter/listener/ExamplePlayerJoinListener.java b/src/main/java/de/rexlmanu/paperpluginstarter/listener/ExamplePlayerJoinListener.java index 1183db0..76d351f 100644 --- a/src/main/java/de/rexlmanu/paperpluginstarter/listener/ExamplePlayerJoinListener.java +++ b/src/main/java/de/rexlmanu/paperpluginstarter/listener/ExamplePlayerJoinListener.java @@ -52,7 +52,7 @@ public void loadData() { this.logger.info("Test instance: {}", instance); - eventBus.subscribe( + this.eventBus.subscribe( PlayerJoinEvent.class, event -> { event.joinMessage( @@ -63,7 +63,12 @@ public void loadData() { this.logger.info("{} has joined the server.", event.getPlayer().getName()); }); - eventBus.subscribe(ServerLoadEvent.class, event -> this.logger.info("Server loaded.")); + this.eventBus + .on(PlayerJoinEvent.class) + .filter(event -> event.getPlayer().getName().equals("rexlManu")) + .subscribe(event -> this.logger.info("rexlManu joined the server.")); + + this.eventBus.subscribe(ServerLoadEvent.class, event -> this.logger.info("Server loaded.")); } @OnPluginDisable