Add flexible formatting to keyboard_indicators.
authorIan Remmler <ian@remmler.org>
Mon, 4 Jun 2018 01:02:34 +0000 (20:02 -0500)
committerAaron Marcher <me@drkhsh.at>
Mon, 4 Jun 2018 12:06:11 +0000 (14:06 +0200)
Updated for style.

components/keyboard_indicators.c
config.def.h

index 73ba32e0e4b556d459d382bd6ad7dabb20ad1f76..b35eba1cc2dbad2bde4816adaf1e8e776da9ed34 100644 (file)
@@ -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;
 }
index 58e935a8a454b6c707b768fa8d4993eb97dbd615..44745080b332f9f0cadd722f706b85a597478a39 100644 (file)
@@ -31,7 +31,8 @@ static const char unknown_str[] = "n/a";
  * ipv4                 IPv4 address                    interface name (eth0)
  * ipv6                 IPv6 address                    interface name (eth0)
  * kernel_release       `uname -r`                      NULL
- * keyboard_indicators  caps/num lock indicators        NULL
+ * keyboard_indicators  caps/num lock indicators        format string (c?n?)
+ *                                                      see keyboard_indicators.c
  * keymap               layout (variant) of current     NULL
  *                      keymap
  * load_avg             load average                    NULL