Optimizing the key lookup to the X11 function key. It is still possible to
authorChristoph Lohmann <20h@r-36.net>
Thu, 15 Nov 2012 19:19:35 +0000 (20:19 +0100)
committerChristoph Lohmann <20h@r-36.net>
Thu, 15 Nov 2012 19:19:35 +0000 (20:19 +0100)
remap other keys.

config.def.h
st.c

index 7a7262cc532c3504634856956193130f8eaf1fb4..c0519a8dd6368b8c7cfc0f01eedde11684141fbf 100644 (file)
@@ -88,6 +88,12 @@ static Shortcut shortcuts[] = {
  * position for a key.
  */
 
+/*
+ * If you want something else but the function keys of X11 (0xFF00 - 0xFFFF)
+ * mapped below, add them to this array.
+ */
+static KeySym mappedkeys[] = { -1 };
+
 /* key, mask, output, keypad, cursor, crlf */
 static Key key[] = {
        /* keysym             mask         string         keypad cursor crlf */
diff --git a/st.c b/st.c
index 477a8f8beb4c73fd045be35a556df9b5388c7b42..02ef411e25d4a761543ee9d6e5cb9e84195d9260 100644 (file)
--- a/st.c
+++ b/st.c
@@ -2711,6 +2711,20 @@ char*
 kmap(KeySym k, uint state) {
        uint mask;
        Key *kp;
+       int i;
+
+       /* Check for mapped keys out of X11 function keys. */
+       for(i = 0; i < LEN(mappedkeys); i++) {
+               if(mappedkeys[i] == k) {
+                       fprintf(stderr, "mapped function key.\n");
+                       break;
+               }
+       }
+       if(i == LEN(mappedkeys)) {
+               if((k & 0xFFFF) < 0xFF00)
+                       return NULL;
+       }
+       fprintf(stderr, "Function key.\n");
 
        for(kp = key; kp < key + LEN(key); kp++) {
                mask = kp->mask;