1 /**
2  *******************************************************************************
3  * Copyright (C) 2001-2014, International Business Machines Corporation and    *
4  * others. All Rights Reserved.                                                *
5  *******************************************************************************
6  */
7 #ifndef ICUNOTIF_H
8 #define ICUNOTIF_H
9 
10 #include "unicode/utypes.h"
11 
12 #if UCONFIG_NO_SERVICE
13 
14 U_NAMESPACE_BEGIN
15 
16 /*
17  * Allow the declaration of APIs with pointers to BreakIterator
18  * even when break iteration is removed from the build.
19  */
20 class ICUNotifier;
21 
22 U_NAMESPACE_END
23 
24 #else
25 
26 #include "unicode/uobject.h"
27 #include "unicode/unistr.h"
28 
29 #include "mutex.h"
30 #include "uvector.h"
31 
32 U_NAMESPACE_BEGIN
33 
34 class U_COMMON_API EventListener : public UObject {
35 public:
36     virtual ~EventListener();
37 
38 public:
39     static UClassID U_EXPORT2 getStaticClassID();
40 
41     virtual UClassID getDynamicClassID() const;
42 
43 public:
44 #ifdef SERVICE_DEBUG
45     virtual UnicodeString& debug(UnicodeString& result) const {
46       return debugClass(result);
47     }
48 
49     virtual UnicodeString& debugClass(UnicodeString& result) const {
50       return result.append((UnicodeString)"Key");
51     }
52 #endif
53 };
54 
55 /**
56  * <p>Abstract implementation of a notification facility.  Clients add
57  * EventListeners with addListener and remove them with removeListener.
58  * Notifiers call notifyChanged when they wish to notify listeners.
59  * This queues the listener list on the notification thread, which
60  * eventually dequeues the list and calls notifyListener on each
61  * listener in the list.</p>
62  *
63  * <p>Subclasses override acceptsListener and notifyListener
64  * to add type-safe notification.  AcceptsListener should return
65  * true if the listener is of the appropriate type; ICUNotifier
66  * itself will ensure the listener is non-null and that the
67  * identical listener is not already registered with the Notifier.
68  * NotifyListener should cast the listener to the appropriate
69  * type and call the appropriate method on the listener.
70  */
71 
72 class U_COMMON_API ICUNotifier : public UMemory  {
73 private: UVector* listeners;
74 
75 public:
76     ICUNotifier(void);
77 
78     virtual ~ICUNotifier(void);
79 
80     /**
81      * Add a listener to be notified when notifyChanged is called.
82      * The listener must not be null. AcceptsListener must return
83      * true for the listener.  Attempts to concurrently
84      * register the identical listener more than once will be
85      * silently ignored.
86      */
87     virtual void addListener(const EventListener* l, UErrorCode& status);
88 
89     /**
90      * Stop notifying this listener.  The listener must
91      * not be null.  Attemps to remove a listener that is
92      * not registered will be silently ignored.
93      */
94     virtual void removeListener(const EventListener* l, UErrorCode& status);
95 
96     /**
97      * ICU doesn't spawn its own threads.  All listeners are notified in
98      * the thread of the caller.  Misbehaved listeners can therefore
99      * indefinitely block the calling thread.  Callers should beware of
100      * deadlock situations.
101      */
102     virtual void notifyChanged(void);
103 
104 protected:
105     /**
106      * Subclasses implement this to return TRUE if the listener is
107      * of the appropriate type.
108      */
109     virtual UBool acceptsListener(const EventListener& l) const = 0;
110 
111     /**
112      * Subclasses implement this to notify the listener.
113      */
114     virtual void notifyListener(EventListener& l) const = 0;
115 };
116 
117 U_NAMESPACE_END
118 
119 /* UCONFIG_NO_SERVICE */
120 #endif
121 
122 /* ICUNOTIF_H */
123 #endif
124