From 6ce94e3e3b8cccab0a5cc23c7538ad19626c1c1d Mon Sep 17 00:00:00 2001 From: N-R-K <79544946+N-R-K@users.noreply.github.com> Date: Thu, 7 Oct 2021 06:37:34 +0600 Subject: add statusbar message upon key-hander activation (#98) Currently when running the key-handler the statusbar shows a "Running key-handler..." message, but there's no indication of the prefix key being pressed. There's a slight functional benefit of this patch in the sense that users can visually tell if the key-handler is listening on input or if the key-handler has been aborted or not. --- main.c | 18 +++++++++++++++++- 1 file changed, 17 insertions(+), 1 deletion(-) (limited to 'main.c') diff --git a/main.c b/main.c index 220743b..f3eeb0a 100644 --- a/main.c +++ b/main.c @@ -469,6 +469,22 @@ Bool is_input_ev(Display *dpy, XEvent *ev, XPointer arg) return ev->type == ButtonPress || ev->type == KeyPress; } +void handle_key_handler(bool init) +{ + extprefix = init; + if (win.bar.h == 0) + return; + if (init) { + close_info(); + snprintf(win.bar.l.buf, win.bar.l.size, "Getting key handler input " + "(%s to abort)...", XKeysymToString(keyhandler_abort)); + } else { /* abort */ + open_info(); + update_info(); + } + win_draw(&win); +} + void run_key_handler(const char *key, unsigned int mask) { pid_t pid; @@ -588,7 +604,7 @@ void on_keypress(XKeyEvent *kev) if (IsModifierKey(ksym)) return; if (extprefix && ksym == keyhandler_abort && MODMASK(kev->state) == 0) { - extprefix = False; + handle_key_handler(false); } else if (extprefix) { run_key_handler(XKeysymToString(ksym), kev->state & ~sh); extprefix = False; -- cgit v1.2.3-54-g00ecf