libxkbcommon
0.5.0
|
Macros | |
#define | XKB_X11_MIN_MAJOR_XKB_VERSION 1 |
#define | XKB_X11_MIN_MINOR_XKB_VERSION 0 |
Enumerations | |
enum | xkb_x11_setup_xkb_extension_flags { XKB_X11_SETUP_XKB_EXTENSION_NO_FLAGS = 0 } |
Functions | |
int | xkb_x11_setup_xkb_extension (xcb_connection_t *connection, uint16_t major_xkb_version, uint16_t minor_xkb_version, enum xkb_x11_setup_xkb_extension_flags flags, uint16_t *major_xkb_version_out, uint16_t *minor_xkb_version_out, uint8_t *base_event_out, uint8_t *base_error_out) |
int32_t | xkb_x11_get_core_keyboard_device_id (xcb_connection_t *connection) |
struct xkb_keymap * | xkb_keymap::xkb_x11_keymap_new_from_device (struct xkb_context *context, xcb_connection_t *connection, int32_t device_id, enum xkb_keymap_compile_flags flags) |
struct xkb_state * | xkb_state::xkb_x11_state_new_from_device (struct xkb_keymap *keymap, xcb_connection_t *connection, int32_t device_id) |
Additional X11 support for xkbcommon.
The xkbcommon-x11 module provides a means for creating an xkb_keymap corresponding to the currently active keymap on the X server. To do so, it queries the XKB X11 extension using the xcb-xkb library. It can be used as a replacement for Xlib's keyboard handling.
Following is an example workflow using xkbcommon-x11. A complete example may be found in the test/interactive-x11.c file in the xkbcommon source repository. On startup:
The XKB extension supports using separate keymaps and states for different keyboard devices. The devices are identified by an integer device ID and are managed by another X11 extension, XInput (or its successor, XInput2). The original X11 protocol only had one keyboard device, called the "core keyboard", which is still supported as a "virtual device".
Next, you need to react to state changes (e.g. a modifier was pressed, the layout was changed) and to keymap changes (e.g. a tool like xkbcomp, setxkbmap or xmodmap was used):
state
field to find the effective modifier and layout state, instead of using XkbStateNotify: Finally, when a key event is received, you can use ordinary xkbcommon functions, like xkb_state_key_get_one_sym() and xkb_state_key_get_utf8(), as you normally would.
Flags for the xkb_x11_setup_xkb_extension() function.
Enumerator | |
---|---|
XKB_X11_SETUP_XKB_EXTENSION_NO_FLAGS |
Do not apply any flags. |
int xkb_x11_setup_xkb_extension | ( | xcb_connection_t * | connection, |
uint16_t | major_xkb_version, | ||
uint16_t | minor_xkb_version, | ||
enum xkb_x11_setup_xkb_extension_flags | flags, | ||
uint16_t * | major_xkb_version_out, | ||
uint16_t * | minor_xkb_version_out, | ||
uint8_t * | base_event_out, | ||
uint8_t * | base_error_out | ||
) |
Setup the XKB X11 extension for this X client.
The xkbcommon-x11 library uses various XKB requests. Before doing so, an X client must notify the server that it will be using the extension. This function (or an XCB equivalent) must be called before any other function in this library is used.
Some X servers may not support or disable the XKB extension. If you want to support such servers, you need to use a different fallback.
You may call this function several times; it is idempotent.
connection | An XCB connection to the X server. | |
major_xkb_version | See minor_xkb_version . | |
minor_xkb_version | The XKB extension version to request. To operate correctly, you must have (major_xkb_version, minor_xkb_version) >= (XKB_X11_MIN_MAJOR_XKB_VERSION, XKB_X11_MIN_MINOR_XKB_VERSION), though this is not enforced. | |
flags | Optional flags, or 0. | |
[out] | major_xkb_version_out | See minor_xkb_version_out . |
[out] | minor_xkb_version_out | Backfilled with the compatible XKB extension version numbers picked by the server. Can be NULL. |
[out] | base_event_out | Backfilled with the XKB base (also known as first) event code, needed to distinguish XKB events. Can be NULL. |
[out] | base_error_out | Backfilled with the XKB base (also known as first) error code, needed to distinguish XKB errors. Can be NULL. |
int32_t xkb_x11_get_core_keyboard_device_id | ( | xcb_connection_t * | connection | ) |
Get the keyboard device ID of the core X11 keyboard.
connection | An XCB connection to the X server. |
struct xkb_keymap * xkb_x11_keymap_new_from_device | ( | struct xkb_context * | context, |
xcb_connection_t * | connection, | ||
int32_t | device_id, | ||
enum xkb_keymap_compile_flags | flags | ||
) |
Create a keymap from an X11 keyboard device.
This function queries the X server with various requests, fetches the details of the active keymap on a keyboard device, and creates an xkb_keymap from these details.
context | The context in which to create the keymap. |
connection | An XCB connection to the X server. |
device_id | An XInput 1 device ID (in the range 0-255) with input class KEY. Passing values outside of this range is an error. |
flags | Optional flags for the keymap, or 0. |
struct xkb_state * xkb_x11_state_new_from_device | ( | struct xkb_keymap * | keymap, |
xcb_connection_t * | connection, | ||
int32_t | device_id | ||
) |
Create a new keyboard state object from an X11 keyboard device.
This function is the same as xkb_state_new(), only pre-initialized with the state of the device at the time this function is called.
keymap | The keymap for which to create the state. |
connection | An XCB connection to the X server. |
device_id | An XInput 1 device ID (in the range 0-255) with input class KEY. Passing values outside of this range is an error. |