diff options
author | Fabian Topfstedt <topfstedt@schneevonmorgen.com> | 2017-06-27 09:22:05 +0200 |
---|---|---|
committer | Fabian Topfstedt <topfstedt@schneevonmorgen.com> | 2017-06-27 09:22:05 +0200 |
commit | fe3d75922b2356cd812f0d22ebef8b25b31e9eb4 (patch) | |
tree | f3e5893baf3ace0a5b4b6ffde384223aea5ce259 /quantum/keycode_config.c | |
parent | 7d0a471051551c3ef9d8a60dbf4bc5b1b2d70cea (diff) | |
parent | 61cdc9aaa462afbcbaf57f2c5991e06924caed0e (diff) |
Merge https://github.com/qmk/qmk_firmware
Diffstat (limited to 'quantum/keycode_config.c')
-rw-r--r-- | quantum/keycode_config.c | 28 |
1 files changed, 28 insertions, 0 deletions
diff --git a/quantum/keycode_config.c b/quantum/keycode_config.c index 4f7bc525ec..eb39c8fe00 100644 --- a/quantum/keycode_config.c +++ b/quantum/keycode_config.c @@ -88,3 +88,31 @@ uint16_t keycode_config(uint16_t keycode) { return keycode; } } + +uint8_t mod_config(uint8_t mod) { + keymap_config.raw = eeconfig_read_keymap(); + if (keymap_config.swap_lalt_lgui) { + if ((mod & MOD_RGUI) == MOD_LGUI) { + mod &= ~MOD_LGUI; + mod |= MOD_LALT; + } else if ((mod & MOD_RALT) == MOD_LALT) { + mod &= ~MOD_LALT; + mod |= MOD_LGUI; + } + } + if (keymap_config.swap_ralt_rgui) { + if ((mod & MOD_RGUI) == MOD_RGUI) { + mod &= ~MOD_RGUI; + mod |= MOD_RALT; + } else if ((mod & MOD_RALT) == MOD_RALT) { + mod &= ~MOD_RALT; + mod |= MOD_RGUI; + } + } + if (keymap_config.no_gui) { + mod &= ~MOD_LGUI; + mod &= ~MOD_RGUI; + } + + return mod; +}
\ No newline at end of file |