summaryrefslogtreecommitdiff
path: root/components/keyboard_indicators.c
diff options
context:
space:
mode:
authorIan Remmler <ian@remmler.org>2018-06-03 20:02:34 -0500
committerAaron Marcher <me@drkhsh.at>2018-06-04 14:06:11 +0200
commit32e0a2bfcc7def9128fb7f385b603f2c5fe34e4d (patch)
tree41712d15b83986109135613234e7026fb9717a8c /components/keyboard_indicators.c
parent005b5417179de9eff56a9ac5f2ed818ae9ad5817 (diff)
Add flexible formatting to keyboard_indicators.
Updated for style.
Diffstat (limited to 'components/keyboard_indicators.c')
-rw-r--r--components/keyboard_indicators.c38
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;
}