summaryrefslogtreecommitdiffstats
path: root/src/main/java/org
diff options
context:
space:
mode:
Diffstat (limited to 'src/main/java/org')
-rw-r--r--src/main/java/org/bukkit/plugin/java/JavaPluginLoader.java14
1 files changed, 10 insertions, 4 deletions
diff --git a/src/main/java/org/bukkit/plugin/java/JavaPluginLoader.java b/src/main/java/org/bukkit/plugin/java/JavaPluginLoader.java
index c82f731c..1c04edfe 100644
--- a/src/main/java/org/bukkit/plugin/java/JavaPluginLoader.java
+++ b/src/main/java/org/bukkit/plugin/java/JavaPluginLoader.java
@@ -276,16 +276,22 @@ public class JavaPluginLoader implements PluginLoader {
boolean useTimings = server.getPluginManager().useTimings();
Map<Class<? extends Event>, Set<RegisteredListener>> ret = new HashMap<Class<? extends Event>, Set<RegisteredListener>>();
- Method[] methods;
+ Set<Method> methods;
try {
- methods = listener.getClass().getDeclaredMethods();
+ Method[] publicMethods = listener.getClass().getMethods();
+ methods = new HashSet<Method>(publicMethods.length, Float.MAX_VALUE);
+ for (Method method : publicMethods) {
+ methods.add(method);
+ }
+ for (Method method : listener.getClass().getDeclaredMethods()) {
+ methods.add(method);
+ }
} catch (NoClassDefFoundError e) {
plugin.getLogger().severe("Plugin " + plugin.getDescription().getFullName() + " has failed to register events for " + listener.getClass() + " because " + e.getMessage() + " does not exist.");
return ret;
}
- for (int i = 0; i < methods.length; i++) {
- final Method method = methods[i];
+ for (final Method method : methods) {
final EventHandler eh = method.getAnnotation(EventHandler.class);
if (eh == null) continue;
final Class<?> checkClass = method.getParameterTypes()[0];