diff options
author | Jack Humbert <jack.humb@gmail.com> | 2017-06-26 18:54:01 -0400 |
---|---|---|
committer | GitHub <noreply@github.com> | 2017-06-26 18:54:01 -0400 |
commit | 61cdc9aaa462afbcbaf57f2c5991e06924caed0e (patch) | |
tree | 0076143e7bbb1e88818ecde430c8bc5be57e6743 | |
parent | d1fb8d2296889ee1aaa08988c8951eb5f12d930b (diff) | |
download | qmk_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.c | 28 | ||||
-rw-r--r-- | quantum/keycode_config.h | 2 | ||||
-rw-r--r-- | quantum/keymap_common.c | 3 |
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 | |||
92 | uint8_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 | ||
23 | uint16_t keycode_config(uint16_t keycode); | 24 | uint16_t keycode_config(uint16_t keycode); |
25 | uint8_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 */ |
26 | typedef union { | 28 | typedef 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: |