mirror of
https://github.com/qmk/qmk_firmware
synced 2024-11-13 23:44:54 +00:00
Merge pull request #1082 from priyadi/right-side-dual-function
Implement tap mod dual role for right side mods.
This commit is contained in:
commit
3f0b491fc0
3 changed files with 24 additions and 10 deletions
|
@ -120,7 +120,7 @@ action_t action_for_key(uint8_t layer, keypos_t key)
|
||||||
action.code = ACTION_MODS_ONESHOT(mod);
|
action.code = ACTION_MODS_ONESHOT(mod);
|
||||||
break;
|
break;
|
||||||
case QK_MOD_TAP ... QK_MOD_TAP_MAX:
|
case QK_MOD_TAP ... QK_MOD_TAP_MAX:
|
||||||
action.code = ACTION_MODS_TAP_KEY((keycode >> 0x8) & 0xF, keycode & 0xFF);
|
action.code = ACTION_MODS_TAP_KEY((keycode >> 0x8) & 0x1F, keycode & 0xFF);
|
||||||
break;
|
break;
|
||||||
#ifdef BACKLIGHT_ENABLE
|
#ifdef BACKLIGHT_ENABLE
|
||||||
case BL_0 ... BL_15:
|
case BL_0 ... BL_15:
|
||||||
|
|
|
@ -139,7 +139,7 @@ void unicode_map_input_error() {}
|
||||||
bool process_unicode_map(uint16_t keycode, keyrecord_t *record) {
|
bool process_unicode_map(uint16_t keycode, keyrecord_t *record) {
|
||||||
if ((keycode & QK_UNICODE_MAP) == QK_UNICODE_MAP && record->event.pressed) {
|
if ((keycode & QK_UNICODE_MAP) == QK_UNICODE_MAP && record->event.pressed) {
|
||||||
const uint32_t* map = unicode_map;
|
const uint32_t* map = unicode_map;
|
||||||
uint16_t index = keycode & 0x7FF;
|
uint16_t index = keycode - QK_UNICODE_MAP;
|
||||||
uint32_t code = pgm_read_dword_far(&map[index]);
|
uint32_t code = pgm_read_dword_far(&map[index]);
|
||||||
if (code > 0xFFFF && code <= 0x10ffff && input_mode == UC_OSX) {
|
if (code > 0xFFFF && code <= 0x10ffff && input_mode == UC_OSX) {
|
||||||
// Convert to UTF-16 surrogate pair
|
// Convert to UTF-16 surrogate pair
|
||||||
|
|
|
@ -39,14 +39,14 @@ enum quantum_keycodes {
|
||||||
QK_CHORDING = 0x5600,
|
QK_CHORDING = 0x5600,
|
||||||
QK_CHORDING_MAX = 0x56FF,
|
QK_CHORDING_MAX = 0x56FF,
|
||||||
#endif
|
#endif
|
||||||
QK_MOD_TAP = 0x6000,
|
QK_TAP_DANCE = 0x5700,
|
||||||
QK_MOD_TAP_MAX = 0x6FFF,
|
QK_TAP_DANCE_MAX = 0x57FF,
|
||||||
QK_TAP_DANCE = 0x7100,
|
|
||||||
QK_TAP_DANCE_MAX = 0x71FF,
|
|
||||||
#ifdef UNICODEMAP_ENABLE
|
#ifdef UNICODEMAP_ENABLE
|
||||||
QK_UNICODE_MAP = 0x7800,
|
QK_UNICODE_MAP = 0x5800,
|
||||||
QK_UNICODE_MAP_MAX = 0x7FFF,
|
QK_UNICODE_MAP_MAX = 0x5BFF,
|
||||||
#endif
|
#endif
|
||||||
|
QK_MOD_TAP = 0x6000,
|
||||||
|
QK_MOD_TAP_MAX = 0x7FFF,
|
||||||
#ifdef UNICODE_ENABLE
|
#ifdef UNICODE_ENABLE
|
||||||
QK_UNICODE = 0x8000,
|
QK_UNICODE = 0x8000,
|
||||||
QK_UNICODE_MAX = 0xFFFF,
|
QK_UNICODE_MAX = 0xFFFF,
|
||||||
|
@ -54,7 +54,7 @@ enum quantum_keycodes {
|
||||||
|
|
||||||
// Loose keycodes - to be used directly
|
// Loose keycodes - to be used directly
|
||||||
|
|
||||||
RESET = 0x7000,
|
RESET = 0x5C00,
|
||||||
DEBUG,
|
DEBUG,
|
||||||
MAGIC_SWAP_CONTROL_CAPSLOCK,
|
MAGIC_SWAP_CONTROL_CAPSLOCK,
|
||||||
MAGIC_CAPSLOCK_TO_CONTROL,
|
MAGIC_CAPSLOCK_TO_CONTROL,
|
||||||
|
@ -298,15 +298,29 @@ enum quantum_keycodes {
|
||||||
#define OSM(mod) (mod | QK_ONE_SHOT_MOD)
|
#define OSM(mod) (mod | QK_ONE_SHOT_MOD)
|
||||||
|
|
||||||
// M-od, T-ap - 256 keycode max
|
// M-od, T-ap - 256 keycode max
|
||||||
#define MT(mod, kc) (kc | QK_MOD_TAP | ((mod & 0xF) << 8))
|
#define MT(mod, kc) (kc | QK_MOD_TAP | ((mod & 0x1F) << 8))
|
||||||
|
|
||||||
#define CTL_T(kc) MT(MOD_LCTL, kc)
|
#define CTL_T(kc) MT(MOD_LCTL, kc)
|
||||||
|
#define LCTL_T(kc) MT(MOD_LCTL, kc)
|
||||||
|
#define RCTL_T(kc) MT(MOD_RCTL, kc)
|
||||||
|
|
||||||
#define SFT_T(kc) MT(MOD_LSFT, kc)
|
#define SFT_T(kc) MT(MOD_LSFT, kc)
|
||||||
|
#define LSFT_T(kc) MT(MOD_LSFT, kc)
|
||||||
|
#define RSFT_T(kc) MT(MOD_RSFT, kc)
|
||||||
|
|
||||||
#define ALT_T(kc) MT(MOD_LALT, kc)
|
#define ALT_T(kc) MT(MOD_LALT, kc)
|
||||||
|
#define LALT_T(kc) MT(MOD_LALT, kc)
|
||||||
|
#define RALT_T(kc) MT(MOD_RALT, kc)
|
||||||
#define ALGR_T(kc) MT(MOD_RALT, kc) // dual-function AltGR
|
#define ALGR_T(kc) MT(MOD_RALT, kc) // dual-function AltGR
|
||||||
|
|
||||||
#define GUI_T(kc) MT(MOD_LGUI, kc)
|
#define GUI_T(kc) MT(MOD_LGUI, kc)
|
||||||
|
#define LGUI_T(kc) MT(MOD_LGUI, kc)
|
||||||
|
#define RGUI_T(kc) MT(MOD_RGUI, kc)
|
||||||
|
|
||||||
#define C_S_T(kc) MT((MOD_LCTL | MOD_LSFT), kc) // Control + Shift e.g. for gnome-terminal
|
#define C_S_T(kc) MT((MOD_LCTL | MOD_LSFT), kc) // Control + Shift e.g. for gnome-terminal
|
||||||
#define MEH_T(kc) MT((MOD_LCTL | MOD_LSFT | MOD_LALT), kc) // Meh is a less hyper version of the Hyper key -- doesn't include Win or Cmd, so just alt+shift+ctrl
|
#define MEH_T(kc) MT((MOD_LCTL | MOD_LSFT | MOD_LALT), kc) // Meh is a less hyper version of the Hyper key -- doesn't include Win or Cmd, so just alt+shift+ctrl
|
||||||
#define LCAG_T(kc) MT((MOD_LCTL | MOD_LALT | MOD_LGUI), kc) // Left control alt and gui
|
#define LCAG_T(kc) MT((MOD_LCTL | MOD_LALT | MOD_LGUI), kc) // Left control alt and gui
|
||||||
|
#define RCAG_T(kc) MT((MOD_RCTL | MOD_RALT | MOD_RGUI), kc) // Right control alt and gui
|
||||||
#define ALL_T(kc) MT((MOD_LCTL | MOD_LSFT | MOD_LALT | MOD_LGUI), kc) // see http://brettterpstra.com/2012/12/08/a-useful-caps-lock-key/
|
#define ALL_T(kc) MT((MOD_LCTL | MOD_LSFT | MOD_LALT | MOD_LGUI), kc) // see http://brettterpstra.com/2012/12/08/a-useful-caps-lock-key/
|
||||||
#define SCMD_T(kc) MT((MOD_LGUI | MOD_LSFT), kc)
|
#define SCMD_T(kc) MT((MOD_LGUI | MOD_LSFT), kc)
|
||||||
#define SWIN_T(kc) SCMD_T(kc)
|
#define SWIN_T(kc) SCMD_T(kc)
|
||||||
|
|
Loading…
Reference in a new issue