diff options
author | Ian Remmler <ian@remmler.org> | 2018-06-03 20:02:34 -0500 |
---|---|---|
committer | Aaron Marcher <me@drkhsh.at> | 2018-06-04 14:06:11 +0200 |
commit | 32e0a2bfcc7def9128fb7f385b603f2c5fe34e4d (patch) | |
tree | 41712d15b83986109135613234e7026fb9717a8c /components | |
parent | 005b5417179de9eff56a9ac5f2ed818ae9ad5817 (diff) |
Add flexible formatting to keyboard_indicators.
Updated for style.
Diffstat (limited to 'components')
-rw-r--r-- | components/keyboard_indicators.c | 38 |
1 files changed, 28 insertions, 10 deletions
diff --git a/components/keyboard_indicators.c b/components/keyboard_indicators.c index 73ba32e..b35eba1 100644 --- a/components/keyboard_indicators.c +++ b/components/keyboard_indicators.c @@ -1,14 +1,26 @@ /* See LICENSE file for copyright and license details. */ +#include <ctype.h> #include <stdio.h> +#include <string.h> #include <X11/Xlib.h> #include "../util.h" +/* + * fmt consists of uppercase or lowercase 'c' for caps lock and/or 'n' for num + * lock, each optionally followed by '?', in the order of indicators desired. + * If followed by '?', the letter with case preserved is included in the output + * if the corresponding indicator is on. Otherwise, the letter is always + * included, lowercase when off and uppercase when on. + */ const char * -keyboard_indicators(void) +keyboard_indicators(const char *fmt) { Display *dpy; XKeyboardState state; + size_t fmtlen, i, n; + int togglecase, isset; + char key; if (!(dpy = XOpenDisplay(NULL))) { warn("XOpenDisplay: Failed to open display"); @@ -17,14 +29,20 @@ keyboard_indicators(void) XGetKeyboardControl(dpy, &state); XCloseDisplay(dpy); - switch (state.led_mask) { - case 1: - return "c"; - case 2: - return "n"; - case 3: - return "cn"; - default: - return ""; + fmtlen = strnlen(fmt, 4); + for (i = n = 0; i < fmtlen; i++) { + key = tolower(fmt[i]); + if (key != 'c' && key != 'n') { + continue; + } + togglecase = (i + 1 >= fmtlen || fmt[i + 1] != '?'); + isset = (state.led_mask & (1 << (key == 'n'))); + if (togglecase) { + buf[n++] = isset ? toupper(key) : key; + } else if (isset) { + buf[n++] = fmt[i]; + } } + buf[n] = 0; + return buf; } |