XSelectExtensionEvent(), XGetSelectedExtensionEvents() - select extension events, get the list of currently selected extension events
XSelectExtensionEvent (Display *display, Window w,
XEventClass *event_list, int event_count)
XGetSelectedExtensionEvents (Display *display, Window w,
int this_client_event_count_return,
XEventClass *this_client_event_list_return,
int all_clients_event_count_return,
XEventClass *all_clients_event_list_return)
The XSelectExtensionEvent(3) request causes the X server to report the events associated with the specified list of event classes. Initially, X will not report any of these events. Events are reported relative to a window. If a window is not interested in a device event, it usually propagates to the closest ancestor that is interested, unless the do_not_propagate mask prohibits it.
Multiple clients can select for the same events on the same window with the following restrictions:
The server reports the event to all interested clients.
Information contained in the XDevice structure returned by XOpenDevice(3) is used by macros to obtain the event classes that clients use in making XSelectExtensionEvent(3) requests. Currently defined macros are DeviceKeyPress(), DeviceKeyRelease(), DeviceButtonPress(), DeviceButtonRelease(), DeviceMotionNotify(), DeviceFocusIn(), DeviceFocusOut(), ProximityIn(), ProximityOut(), DeviceStateNotify(), DeviceMappiingNotify(), ChangeDeviceNotify(), DevicePointerMotionHint(), DeviceButton1Motion(), DeviceButton2Motion(), DeviceButton3Motion(), DeviceButton4Motion(), DeviceButton5Motion(), DeviceButtonMotion(), DeviceOwnerGrabButton(), DeviceButtonPressGrab(), and NoExtensionEvent().
To obtain the proper event class for a particular device, one of the above macros is invoked using the XDevice structure for that device. For example,
DeviceKeyPress (*device, type, eventclass);
returns the DeviceKeyPress event type and the eventclass for selecting DeviceKeyPress events from this device.
XSelectExtensionEvent(3) can generate a BadWindow or BadClass error. The XGetSelectedExtensionEvents(3) request reports the extension events selected by this client and all clients for the specified window. This request returns pointers to two XEventClass arrays. One lists the input extension events selected by this client from the specified window. The other lists the event classes selected by all clients from the specified window. You should use XFree(3) to free these two arrays.
XGetSelectedExtensionEvents(3) can generate a BadWindow error.
Programming With Xlib