sxhkd-rc

[fork] simple X hotkey daemon (but for the rc shell)
Log | Files | Refs | README | LICENSE

commit 6988a37ae8179db217b5c9936fcb32896b1d9182
parent 2ce0813b07b7e410089be950a082e9f8412890f3
Author: Bastien Dejean <nihilhill@gmail.com>
Date:   Mon,  2 Oct 2017 11:00:03 +0200

A locked hotkey should catch everything

Fixes #105.

Diffstat:
Msrc/sxhkd.c | 3++-
Msrc/sxhkd.h | 3++-
Msrc/types.c | 15++++++++-------
3 files changed, 12 insertions(+), 9 deletions(-)

diff --git a/src/sxhkd.c b/src/sxhkd.c @@ -121,7 +121,8 @@ int main(int argc, char *argv[]) fd_set descriptors; - reload = toggle_grab = bell = chained = locked = false; + reload = toggle_grab = bell = chained = false; + locked = NULL; running = true; xcb_flush(dpy); diff --git a/src/sxhkd.h b/src/sxhkd.h @@ -58,7 +58,8 @@ int mapping_count; int timeout; hotkey_t *hotkeys_head, *hotkeys_tail; -bool running, grabbed, toggle_grab, reload, bell, chained, locked; +bool running, grabbed, toggle_grab, reload, bell, chained; +hotkey_t *locked; chord_t *escape_chord; uint16_t num_lock; diff --git a/src/types.c b/src/types.c @@ -37,8 +37,9 @@ hotkey_t *find_hotkey(xcb_keysym_t keysym, xcb_button_t button, uint16_t modfiel for (hotkey_t *hk = hotkeys_head; hk != NULL; hk = hk->next) { chain_t *c = hk->chain; - if (chained && c->state == c->head) + if ((chained && c->state == c->head) || (locked != NULL && hk != locked)) { continue; + } if (match_chord(c->state, event_type, keysym, button, modfield)) { if (status_fifo != NULL && num_active == 0) { if (!chained) { @@ -51,8 +52,8 @@ hotkey_t *find_hotkey(xcb_keysym_t keysym, xcb_button_t button, uint16_t modfiel } if (replay_event != NULL && c->state->replay_event) *replay_event = true; - if (!locked && c->state->lock_chain) { - locked = true; + if (locked == NULL && c->state->lock_chain) { + locked = hk; if (timeout > 0) alarm(0); } @@ -64,7 +65,7 @@ hotkey_t *find_hotkey(xcb_keysym_t keysym, xcb_button_t button, uint16_t modfiel result = hk; continue; } - if (chained && !locked) + if (chained && locked == NULL) abort_chain(); return hk; } else { @@ -73,7 +74,7 @@ hotkey_t *find_hotkey(xcb_keysym_t keysym, xcb_button_t button, uint16_t modfiel grab_chord(c->state); } } else if (chained) { - if (!locked && c->state->event_type == event_type) + if (locked == NULL && c->state->event_type == event_type) c->state = c->head; else num_active++; @@ -93,7 +94,7 @@ hotkey_t *find_hotkey(xcb_keysym_t keysym, xcb_button_t button, uint16_t modfiel abort_chain(); return find_hotkey(keysym, button, modfield, event_type, replay_event); } - if (chained && !locked && timeout > 0) + if (chained && locked == NULL && timeout > 0) alarm(timeout); PRINTF("num active %i\n", num_active); @@ -223,7 +224,7 @@ void abort_chain(void) for (hotkey_t *hk = hotkeys_head; hk != NULL; hk = hk->next) hk->chain->state = hk->chain->head; chained = false; - locked = false; + locked = NULL; if (timeout > 0) alarm(0); ungrab();