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
|
OF_ASSUME_NONNULL_BEGIN
@class OFMutableDictionary OF_GENERIC(KeyType, ObjectType);
#ifdef OF_HAVE_THREADS
@class OFMutex;
#endif
/**
* @class OFNotificationCenter OFNotificationCenter.h \
* ObjFW/OFNotificationCenter.h
*
* @brief A class to send and register for notifications.
*/
@interface OFNotificationCenter: OFObject
{
#ifdef OF_HAVE_THREADS
OFMutex *_mutex;
#endif
OFMutableDictionary *_notifications;
OF_RESERVE_IVARS(OFNotificationCenter, 4)
}
#ifdef OF_HAVE_CLASS_PROPERTIES
@property (class, readonly, nonatomic) OFNotificationCenter *defaultCenter;
#endif
|
>
>
>
>
>
>
>
>
>
>
|
|
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
|
OF_ASSUME_NONNULL_BEGIN
@class OFMutableDictionary OF_GENERIC(KeyType, ObjectType);
#ifdef OF_HAVE_THREADS
@class OFMutex;
#endif
@class OFNotificationCenterHandle;
#ifdef OF_HAVE_BLOCKS
/**
* @brief A block which is called when a notification has been posted.
*
* @param notification The notification that has been posted
*/
typedef void (^OFNotificationCenterBlock)(OFNotification *notification);
#endif
/**
* @class OFNotificationCenter OFNotificationCenter.h \
* ObjFW/OFNotificationCenter.h
*
* @brief A class to send and register for notifications.
*/
@interface OFNotificationCenter: OFObject
{
#ifdef OF_HAVE_THREADS
OFMutex *_mutex;
#endif
OFMutableDictionary *_handles;
OF_RESERVE_IVARS(OFNotificationCenter, 4)
}
#ifdef OF_HAVE_CLASS_PROPERTIES
@property (class, readonly, nonatomic) OFNotificationCenter *defaultCenter;
#endif
|
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
|
* @param name The name that was specified when adding the observer
* @param object The object that was specified when adding the observer
*/
- (void)removeObserver: (id)observer
selector: (SEL)selector
name: (OFNotificationName)name
object: (nullable id)object;
/**
* @brief Posts the specified notification.
*
* @param notification The notification to post
*/
- (void)postNotification: (OFNotification *)notification;
@end
OF_ASSUME_NONNULL_END
|
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
|
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
|
* @param name The name that was specified when adding the observer
* @param object The object that was specified when adding the observer
*/
- (void)removeObserver: (id)observer
selector: (SEL)selector
name: (OFNotificationName)name
object: (nullable id)object;
#ifdef OF_HAVE_BLOCKS
/**
* @brief Adds an observer for the specified notification and object.
*
* To remove the observer again, use @ref removeObserver:.
*
* @param name The name of the notification to observe
* @param object The object that should be sending the notification, or `nil`
* if the object should be ignored to determine what
* notifications to deliver
* @param block The block to handle notifications
* @return An opaque object to remove the observer again
*/
- (OFNotificationCenterHandle *)
addObserverForName: (OFNotificationName)name
object: (nullable id)object
usingBlock: (OFNotificationCenterBlock)block;
/**
* @brief Removes an observer. The specified observer must be one returned by
* @ref addObserver:selector:name:object:.
*
* @param observer The object that was returned when adding the observer
*/
- (void)removeObserver: (OFNotificationCenterHandle *)observer;
#endif
/**
* @brief Posts the specified notification.
*
* @param notification The notification to post
*/
- (void)postNotification: (OFNotification *)notification;
@end
OF_ASSUME_NONNULL_END
|