notify(3) is a simple API that allows processes to poke other processes, and to be poked.
The API is similar to NSDistributedNotificationCenter
, except that it’s not object-oriented, it’s not based on Foundation or CF, and it doesn’t allow you to attach a property list to the notification.
You register in one of four ways:
notify_register_check
- Sign up under a name, and get a registration token.
notify_register_signal
- Have the system send your process a signal when another process posts a notification with a particular name. Also get a registration token.
notify_register_mach_port
- Have the system send your process a message on a Mach port when another process posts a notification with a particular name. Also get a registration token.
notify_register_file_descriptor
- Get a registration token, and have the system write that token to a file descriptor when another process posts a notification with a particular name.
Each of the last two functions will create the Mach port or file descriptor for you, unless you tell it to use one you already have. You do that by passing NOTIFY_REUSE
.
All four functions give you a registration token (the first one does nothing else), which is simply a signed 32-bit integer. You can then use notify_check
to poll that token to see whether any processes have posted a notification to it since the last time you checked. (I don’t know how the other notification methods affect this—e.g., whether notify_check
will ever return true
if you got the token from notify_register_signal
.)
You free the token using notify_cancel
. This also closes any Mach ports or file descriptors you have associated with it. There is no way to disassociate them from the token or to cancel the token without closing the associated resources.
On the sending side, the API provides one function: notify_post
. It takes one argument, which is the notification name; this is the same name that any receiving processes passed to their chosen notify_register_whatever
function.
Leopard adds a new feature: you can associate a shared 64-bit number with a name using notify_set_state
, and retrieve that number using notify_get_state
. I suggest that you only use notify_set_state
in a single process, as I can imagine race conditions occurring if two processes try to set state under the same name. If you need bidirectional communication, use two notification names (or a different means of communication, such as sockets or Mach ports).
Apple introduced the rest of the notify(3) API in Panther.