Merge pull request #558 from psychon/xkb-detectable-autorepeat
Xkb detectable autorepeat Closes https://github.com/awesomeWM/awesome/pull/558.
This commit is contained in:
commit
c9c60810cc
39
xkb.c
39
xkb.c
|
@ -129,7 +129,7 @@ xkb_fill_state(void)
|
||||||
int32_t device_id = xkb_x11_get_core_keyboard_device_id(conn);
|
int32_t device_id = xkb_x11_get_core_keyboard_device_id(conn);
|
||||||
if (device_id == -1)
|
if (device_id == -1)
|
||||||
fatal("Failed while getting XKB device id");
|
fatal("Failed while getting XKB device id");
|
||||||
|
|
||||||
struct xkb_keymap *xkb_keymap = xkb_x11_keymap_new_from_device(
|
struct xkb_keymap *xkb_keymap = xkb_x11_keymap_new_from_device(
|
||||||
globalconf.xkb_ctx,
|
globalconf.xkb_ctx,
|
||||||
conn,
|
conn,
|
||||||
|
@ -139,7 +139,7 @@ xkb_fill_state(void)
|
||||||
|
|
||||||
if (!xkb_keymap)
|
if (!xkb_keymap)
|
||||||
fatal("Failed while getting XKB keymap from device");
|
fatal("Failed while getting XKB keymap from device");
|
||||||
|
|
||||||
globalconf.xkb_state = xkb_x11_state_new_from_device(xkb_keymap,
|
globalconf.xkb_state = xkb_x11_state_new_from_device(xkb_keymap,
|
||||||
conn,
|
conn,
|
||||||
device_id);
|
device_id);
|
||||||
|
@ -160,7 +160,7 @@ xkb_init_keymap(void)
|
||||||
globalconf.xkb_ctx = xkb_context_new(XKB_CONTEXT_NO_FLAGS);
|
globalconf.xkb_ctx = xkb_context_new(XKB_CONTEXT_NO_FLAGS);
|
||||||
if (!globalconf.xkb_ctx)
|
if (!globalconf.xkb_ctx)
|
||||||
fatal("Failed while getting XKB context");
|
fatal("Failed while getting XKB context");
|
||||||
|
|
||||||
xkb_fill_state();
|
xkb_fill_state();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -220,7 +220,7 @@ event_handle_xkb_notify(xcb_generic_event_t* event)
|
||||||
{
|
{
|
||||||
xcb_xkb_state_notify_event_t *state_notify_event = (void*)event;
|
xcb_xkb_state_notify_event_t *state_notify_event = (void*)event;
|
||||||
|
|
||||||
xkb_state_update_mask(globalconf.xkb_state,
|
xkb_state_update_mask(globalconf.xkb_state,
|
||||||
state_notify_event->baseMods,
|
state_notify_event->baseMods,
|
||||||
state_notify_event->latchedMods,
|
state_notify_event->latchedMods,
|
||||||
state_notify_event->lockedMods,
|
state_notify_event->lockedMods,
|
||||||
|
@ -272,17 +272,28 @@ xkb_init(void)
|
||||||
XCB_XKB_MAP_PART_EXPLICIT_COMPONENTS |
|
XCB_XKB_MAP_PART_EXPLICIT_COMPONENTS |
|
||||||
XCB_XKB_MAP_PART_KEY_ACTIONS |
|
XCB_XKB_MAP_PART_KEY_ACTIONS |
|
||||||
XCB_XKB_MAP_PART_KEY_BEHAVIORS |
|
XCB_XKB_MAP_PART_KEY_BEHAVIORS |
|
||||||
XCB_XKB_MAP_PART_VIRTUAL_MODS |
|
XCB_XKB_MAP_PART_VIRTUAL_MODS |
|
||||||
XCB_XKB_MAP_PART_VIRTUAL_MOD_MAP;
|
XCB_XKB_MAP_PART_VIRTUAL_MOD_MAP;
|
||||||
|
|
||||||
xcb_xkb_select_events_checked(globalconf.connection,
|
/* Enable detectable auto-repeat, but ignore failures */
|
||||||
XCB_XKB_ID_USE_CORE_KBD,
|
xcb_discard_reply(globalconf.connection,
|
||||||
map,
|
xcb_xkb_per_client_flags(globalconf.connection,
|
||||||
0,
|
XCB_XKB_ID_USE_CORE_KBD,
|
||||||
map,
|
XCB_XKB_PER_CLIENT_FLAG_DETECTABLE_AUTO_REPEAT,
|
||||||
map_parts,
|
XCB_XKB_PER_CLIENT_FLAG_DETECTABLE_AUTO_REPEAT,
|
||||||
map_parts,
|
0,
|
||||||
0);
|
0,
|
||||||
|
0)
|
||||||
|
.sequence);
|
||||||
|
|
||||||
|
xcb_xkb_select_events(globalconf.connection,
|
||||||
|
XCB_XKB_ID_USE_CORE_KBD,
|
||||||
|
map,
|
||||||
|
0,
|
||||||
|
map,
|
||||||
|
map_parts,
|
||||||
|
map_parts,
|
||||||
|
0);
|
||||||
|
|
||||||
/* load keymap to use when resolving keypresses */
|
/* load keymap to use when resolving keypresses */
|
||||||
xkb_init_keymap();
|
xkb_init_keymap();
|
||||||
|
@ -294,7 +305,7 @@ void
|
||||||
xkb_free(void)
|
xkb_free(void)
|
||||||
{
|
{
|
||||||
// unsubscribe from all events
|
// unsubscribe from all events
|
||||||
xcb_xkb_select_events_checked(globalconf.connection,
|
xcb_xkb_select_events(globalconf.connection,
|
||||||
XCB_XKB_ID_USE_CORE_KBD,
|
XCB_XKB_ID_USE_CORE_KBD,
|
||||||
0,
|
0,
|
||||||
0,
|
0,
|
||||||
|
|
Loading…
Reference in New Issue