blob: 971030686be7eed57343432c10b9e9be4051b746 [file] [log] [blame]
tomd7356722014-08-26 01:07:39 -07001package org.onlab.onos.event;
2
3import org.slf4j.Logger;
tomd7356722014-08-26 01:07:39 -07004
5import java.util.Set;
6import java.util.concurrent.CopyOnWriteArraySet;
7
8import static com.google.common.base.Preconditions.checkArgument;
9import static com.google.common.base.Preconditions.checkNotNull;
tom5f38b3a2014-08-27 23:50:54 -070010import static org.slf4j.LoggerFactory.getLogger;
tomd7356722014-08-26 01:07:39 -070011
12/**
tom96dfcab2014-08-28 09:26:03 -070013 * Base implementation of an event sink and a registry capable of tracking
14 * listeners and dispatching events to them as part of event sink processing.
tomd7356722014-08-26 01:07:39 -070015 */
tom96dfcab2014-08-28 09:26:03 -070016public class AbstractListenerRegistry<E extends Event, L extends EventListener<E>>
tomd7356722014-08-26 01:07:39 -070017 implements EventSink<E> {
18
tom5f38b3a2014-08-27 23:50:54 -070019 private final Logger log = getLogger(getClass());
tomd7356722014-08-26 01:07:39 -070020
21 private final Set<L> listeners = new CopyOnWriteArraySet<>();
22
23 /**
24 * Adds the specified listener.
25 *
26 * @param listener listener to be added
27 */
28 public void addListener(L listener) {
29 checkNotNull(listener, "Listener cannot be null");
30 listeners.add(listener);
31 }
32
33 /**
34 * Removes the specified listener.
35 *
36 * @param listener listener to be removed
37 */
38 public void removeListener(L listener) {
39 checkNotNull(listener, "Listener cannot be null");
40 checkArgument(listeners.remove(listener), "Listener not registered");
41 }
42
43 @Override
44 public void process(E event) {
45 for (L listener : listeners) {
46 try {
47 listener.event(event);
tom19bf4212014-08-29 13:08:29 -070048 } catch (Exception error) {
tomd7356722014-08-26 01:07:39 -070049 reportProblem(event, error);
50 }
51 }
52 }
53
tomb36046e2014-08-27 00:22:24 -070054 /**
55 * Reports a problem encountered while processing an event.
56 *
57 * @param event event being processed
58 * @param error error encountered while processing
59 */
60 protected void reportProblem(E event, Throwable error) {
tomd7356722014-08-26 01:07:39 -070061 log.warn("Exception encountered while processing event " + event, error);
62 }
63
64}