|
1 | 1 | package com.mengcraft.script; |
2 | 2 |
|
| 3 | +import com.mengcraft.script.util.Utils; |
3 | 4 | import lombok.EqualsAndHashCode; |
4 | 5 | import org.bukkit.event.Event; |
5 | 6 | import org.bukkit.event.EventPriority; |
6 | 7 |
|
| 8 | +import javax.script.Bindings; |
7 | 9 | import java.util.Comparator; |
8 | 10 | import java.util.UUID; |
9 | | -import java.util.function.Consumer; |
| 11 | +import java.util.logging.Level; |
10 | 12 |
|
11 | 13 | /** |
12 | 14 | * Created on 16-10-17. |
|
15 | 17 | public class HandledListener { |
16 | 18 |
|
17 | 19 | private final UUID id = UUID.randomUUID();// Use random id to func |
18 | | - private final Consumer<Event> executor; |
| 20 | + private final Bindings executor; |
19 | 21 | private final EventListener managedListener; |
20 | 22 | private final int priority; |
21 | 23 | private final ScriptPlugin plugin; |
22 | 24 | private final EventPriority eventPriority; |
23 | 25 |
|
24 | | - public HandledListener(EventListener managedListener, ScriptPlugin plugin, Consumer<Event> executor, int priority, EventPriority eventPriority) { |
| 26 | + public HandledListener(EventListener managedListener, ScriptPlugin plugin, Bindings executor, int priority, EventPriority eventPriority) { |
25 | 27 | this.managedListener = managedListener; |
26 | 28 | this.plugin = plugin; |
27 | 29 | this.executor = executor; |
28 | 30 | this.priority = priority; |
29 | 31 | this.eventPriority = eventPriority; |
30 | 32 | } |
31 | 33 |
|
| 34 | + public void handle(Event event) { |
| 35 | + long millis = System.currentTimeMillis(); |
| 36 | + try { |
| 37 | + Utils.invoke(executor, event); |
| 38 | + } catch (Exception e) { |
| 39 | + plugin.getLogger().log(Level.SEVERE, String.format("Exception occurred while handle %s\n%s", event.getEventName(), executor.toString()), e); |
| 40 | + } finally { |
| 41 | + millis = System.currentTimeMillis() - millis; |
| 42 | + if (millis >= 5) { |
| 43 | + plugin.getLogger().warning(String.format("Consume too much time to handle %s. (%s millis)\n%s", event.getEventName(), millis, executor.toString())); |
| 44 | + } |
| 45 | + } |
| 46 | + } |
| 47 | + |
32 | 48 | public void remove() { |
33 | 49 | if (plugin.remove(this)) { |
34 | 50 | managedListener.remove(this); |
35 | 51 | } |
36 | 52 | } |
37 | 53 |
|
38 | | - public Consumer<Event> getExecutor() { |
39 | | - return executor; |
40 | | - } |
41 | | - |
42 | 54 | public ScriptPlugin getPlugin() { |
43 | 55 | return plugin; |
44 | 56 | } |
|
0 commit comments