From cfccd9341cdc94affb207bad90e2aac378c7a792 Mon Sep 17 00:00:00 2001 From: Bukkit/Spigot Date: Sat, 18 Feb 2012 15:41:18 -0600 Subject: [PATCH] [Bleeding] Added ability to unregister listeners, updated javadoc and renamed allLists. Addresses BUKKIT-773 By: SpaceManiac --- .../java/org/bukkit/event/HandlerList.java | 80 +++++++++++++++++-- 1 file changed, 72 insertions(+), 8 deletions(-) diff --git a/paper-api/src/main/java/org/bukkit/event/HandlerList.java b/paper-api/src/main/java/org/bukkit/event/HandlerList.java index c2159402fb..5e0bfb02db 100644 --- a/paper-api/src/main/java/org/bukkit/event/HandlerList.java +++ b/paper-api/src/main/java/org/bukkit/event/HandlerList.java @@ -35,7 +35,7 @@ public class HandlerList { /** * List of all HandlerLists which have been created, for use in bakeAll() */ - private static ArrayList alllists = new ArrayList(); + private static ArrayList allLists = new ArrayList(); /** * Bake all handler lists. Best used just after all normal event @@ -43,13 +43,16 @@ public class HandlerList { * you're using fevents in a plugin system. */ public static void bakeAll() { - for (HandlerList h : alllists) { + for (HandlerList h : allLists) { h.bake(); } } + /** + * Unregister all listeners from all handler lists. + */ public static void unregisterAll() { - for (HandlerList h : alllists) { + for (HandlerList h : allLists) { for (List list : h.handlerslots.values()) { list.clear(); } @@ -57,12 +60,28 @@ public class HandlerList { } } + /** + * Unregister a specific plugin's listeners from all handler lists. + * + * @param plugin plugin to unregister + */ public static void unregisterAll(Plugin plugin) { - for (HandlerList h : alllists) { + for (HandlerList h : allLists) { h.unregister(plugin); } } + /** + * Unregister a specific listener from all handler lists. + * + * @param listener listener to unregister + */ + public static void unregisterAll(Listener listener) { + for (HandlerList h : allLists) { + h.unregister(listener); + } + } + /** * Create a new handler list and initialize using EventPriority * The HandlerList is then added to meta-list for use in bakeAll() @@ -72,7 +91,7 @@ public class HandlerList { for (EventPriority o : EventPriority.values()) { handlerslots.put(o, new ArrayList()); } - alllists.add(this); + allLists.add(this); } /** @@ -87,6 +106,11 @@ public class HandlerList { handlerslots.get(listener.getPriority()).add(listener); } + /** + * Register a collection of new listeners in this handler list + * + * @param listeners listeners to register + */ public void registerAll(Collection listeners) { for (RegisteredListener listener : listeners) { register(listener); @@ -105,7 +129,12 @@ public class HandlerList { } } - void unregister(Plugin plugin) { + /** + * Remove a specific plugin's listeners from this handler + * + * @param plugin plugin to remove + */ + public void unregister(Plugin plugin) { boolean changed = false; for (List list : handlerslots.values()) { for (ListIterator i = list.listIterator(); i.hasNext();) { @@ -118,6 +147,24 @@ public class HandlerList { if (changed) baked = false; } + /** + * Remove a specific listener from this handler + * + * @param listener listener to remove + */ + public void unregister(Listener listener) { + boolean changed = false; + for (List list : handlerslots.values()) { + for (ListIterator i = list.listIterator(); i.hasNext();) { + if (i.next().getListener().equals(listener)) { + i.remove(); + changed = true; + } + } + } + if (changed) baked = false; + } + /** * Bake HashMap and ArrayLists to 2d array - does nothing if not necessary */ @@ -129,13 +176,25 @@ public class HandlerList { baked = true; } + /** + * Get the baked registered listeners associated with this handler list + * + * @return the array of registered listeners + */ public RegisteredListener[][] getRegisteredListeners() { return handlers; } + /** + * Get a specific plugin's registered listeners associated with this handler list + * + * @param plugin the plugin to get the listeners of + * + * @return the list of registered listeners + */ public static ArrayList getRegisteredListeners(Plugin plugin) { ArrayList listeners = new ArrayList(); - for (HandlerList h : alllists) { + for (HandlerList h : allLists) { for (List list : h.handlerslots.values()) { for (RegisteredListener listener : list) { if (listener.getPlugin().equals(plugin)) { @@ -147,7 +206,12 @@ public class HandlerList { return listeners; } + /** + * Get a list of all handler lists for every event type + * + * @return the list of all handler lists + */ public static ArrayList getHandlerLists() { - return (ArrayList) alllists.clone(); + return (ArrayList) allLists.clone(); } }