aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorJack Humbert <jack.humb@gmail.com>2017-06-26 18:54:01 -0400
committerGitHub <noreply@github.com>2017-06-26 18:54:01 -0400
commit61cdc9aaa462afbcbaf57f2c5991e06924caed0e (patch)
tree0076143e7bbb1e88818ecde430c8bc5be57e6743
parentd1fb8d2296889ee1aaa08988c8951eb5f12d930b (diff)
downloadqmk_firmware-61cdc9aaa462afbcbaf57f2c5991e06924caed0e.tar.gz
qmk_firmware-61cdc9aaa462afbcbaf57f2c5991e06924caed0e.zip
Allow mod swapping for mod tap (MT) (#1202)
* allow mod swapping for mod tap * quick include * fix the mod swapping * make changes consistent with action code * fix bug * re-enable no gui, etc * fix binary comps * solid logic
-rw-r--r--quantum/keycode_config.c28
-rw-r--r--quantum/keycode_config.h2
-rw-r--r--quantum/keymap_common.c3
3 files changed, 32 insertions, 1 deletions
diff --git a/quantum/keycode_config.c b/quantum/keycode_config.c
index 4f7bc525e..eb39c8fe0 100644
--- a/quantum/keycode_config.c
+++ b/quantum/keycode_config.c
@@ -88,3 +88,31 @@ uint16_t keycode_config(uint16_t keycode) {
88 return keycode; 88 return keycode;
89 } 89 }
90} 90}
91
92uint8_t mod_config(uint8_t mod) {
93 keymap_config.raw = eeconfig_read_keymap();
94 if (keymap_config.swap_lalt_lgui) {
95 if ((mod & MOD_RGUI) == MOD_LGUI) {
96 mod &= ~MOD_LGUI;
97 mod |= MOD_LALT;
98 } else if ((mod & MOD_RALT) == MOD_LALT) {
99 mod &= ~MOD_LALT;
100 mod |= MOD_LGUI;
101 }
102 }
103 if (keymap_config.swap_ralt_rgui) {
104 if ((mod & MOD_RGUI) == MOD_RGUI) {
105 mod &= ~MOD_RGUI;
106 mod |= MOD_RALT;
107 } else if ((mod & MOD_RALT) == MOD_RALT) {
108 mod &= ~MOD_RALT;
109 mod |= MOD_RGUI;
110 }
111 }
112 if (keymap_config.no_gui) {
113 mod &= ~MOD_LGUI;
114 mod &= ~MOD_RGUI;
115 }
116
117 return mod;
118} \ No newline at end of file
diff --git a/quantum/keycode_config.h b/quantum/keycode_config.h
index 293fefecf..022f4bd19 100644
--- a/quantum/keycode_config.h
+++ b/quantum/keycode_config.h
@@ -16,11 +16,13 @@
16 16
17#include "eeconfig.h" 17#include "eeconfig.h"
18#include "keycode.h" 18#include "keycode.h"
19#include "action_code.h"
19 20
20#ifndef KEYCODE_CONFIG_H 21#ifndef KEYCODE_CONFIG_H
21#define KEYCODE_CONFIG_H 22#define KEYCODE_CONFIG_H
22 23
23uint16_t keycode_config(uint16_t keycode); 24uint16_t keycode_config(uint16_t keycode);
25uint8_t mod_config(uint8_t mod);
24 26
25/* NOTE: Not portable. Bit field order depends on implementation */ 27/* NOTE: Not portable. Bit field order depends on implementation */
26typedef union { 28typedef union {
diff --git a/quantum/keymap_common.c b/quantum/keymap_common.c
index 9dafc8b51..b1460c53c 100644
--- a/quantum/keymap_common.c
+++ b/quantum/keymap_common.c
@@ -123,7 +123,8 @@ action_t action_for_key(uint8_t layer, keypos_t key)
123 action.code = ACTION_LAYER_TAP_TOGGLE(keycode & 0xFF); 123 action.code = ACTION_LAYER_TAP_TOGGLE(keycode & 0xFF);
124 break; 124 break;
125 case QK_MOD_TAP ... QK_MOD_TAP_MAX: 125 case QK_MOD_TAP ... QK_MOD_TAP_MAX:
126 action.code = ACTION_MODS_TAP_KEY((keycode >> 0x8) & 0x1F, keycode & 0xFF); 126 mod = mod_config((keycode >> 0x8) & 0x1F);
127 action.code = ACTION_MODS_TAP_KEY(mod, keycode & 0xFF);
127 break; 128 break;
128 #ifdef BACKLIGHT_ENABLE 129 #ifdef BACKLIGHT_ENABLE
129 case BL_0 ... BL_15: 130 case BL_0 ... BL_15: