1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
|
/*
@ITMillApache2LicenseForJavaFiles@
*/
package com.itmill.toolkit.event;
import java.lang.reflect.Method;
import java.util.EventObject;
import java.util.Iterator;
import java.util.LinkedHashSet;
import java.util.Set;
/**
* <code>EventRouter</code> class implementing the inheritable event listening
* model. For more information on the event model see the
* {@link com.itmill.toolkit.event package documentation}.
*
* @author IT Mill Ltd.
* @version
* @VERSION@
* @since 3.0
*/
public class EventRouter implements MethodEventSource {
/**
* List of registered listeners.
*/
private Set listenerList = null;
/*
* Registers a new listener with the specified activation method to listen
* events generated by this component. Don't add a JavaDoc comment here, we
* use the default documentation from implemented interface.
*/
public void addListener(Class eventType, Object object, Method method) {
if (listenerList == null) {
listenerList = new LinkedHashSet();
}
listenerList.add(new ListenerMethod(eventType, object, method));
}
/*
* Registers a new listener with the specified named activation method to
* listen events generated by this component. Don't add a JavaDoc comment
* here, we use the default documentation from implemented interface.
*/
public void addListener(Class eventType, Object object, String methodName) {
if (listenerList == null) {
listenerList = new LinkedHashSet();
}
listenerList.add(new ListenerMethod(eventType, object, methodName));
}
/*
* Removes all registered listeners matching the given parameters. Don't add
* a JavaDoc comment here, we use the default documentation from implemented
* interface.
*/
public void removeListener(Class eventType, Object target) {
if (listenerList != null) {
final Iterator i = listenerList.iterator();
while (i.hasNext()) {
try {
final ListenerMethod lm = (ListenerMethod) i.next();
if (lm.matches(eventType, target)) {
i.remove();
return;
}
} catch (final java.lang.ClassCastException e) {
// Class cast exceptions are ignored
}
}
}
}
/*
* Removes the event listener methods matching the given given paramaters.
* Don't add a JavaDoc comment here, we use the default documentation from
* implemented interface.
*/
public void removeListener(Class eventType, Object target, Method method) {
if (listenerList != null) {
final Iterator i = listenerList.iterator();
while (i.hasNext()) {
try {
final ListenerMethod lm = (ListenerMethod) i.next();
if (lm.matches(eventType, target, method)) {
i.remove();
return;
}
} catch (final java.lang.ClassCastException e) {
// Class cast exceptions are ignored
}
}
}
}
/*
* Removes the event listener method matching the given given parameters.
* Don't add a JavaDoc comment here, we use the default documentation from
* implemented interface.
*/
public void removeListener(Class eventType, Object target, String methodName) {
// Find the correct method
final Method[] methods = target.getClass().getMethods();
Method method = null;
for (int i = 0; i < methods.length; i++) {
if (methods[i].getName().equals(methodName)) {
method = methods[i];
}
}
if (method == null) {
throw new IllegalArgumentException();
}
// Remove the listeners
if (listenerList != null) {
final Iterator i = listenerList.iterator();
while (i.hasNext()) {
try {
final ListenerMethod lm = (ListenerMethod) i.next();
if (lm.matches(eventType, target, method)) {
i.remove();
return;
}
} catch (final java.lang.ClassCastException e) {
// Class cast exceptions are ignored
}
}
}
}
/**
* Removes all listeners from event router.
*/
public void removeAllListeners() {
listenerList = null;
}
/**
* Sends an event to all registered listeners. The listeners will decide if
* the activation method should be called or not.
*
* @param event
* the Event to be sent to all listeners.
*/
public void fireEvent(EventObject event) {
// It is not necessary to send any events if there are no listeners
if (listenerList != null) {
// Send the event to all listeners. The listeners themselves
// will filter out unwanted events.
final Iterator i = listenerList.iterator();
while (i.hasNext()) {
((ListenerMethod) i.next()).receiveEvent(event);
}
}
}
}
|