diff --git a/quantum/keymap_common.c b/quantum/keymap_common.c index da7527172..fc889a308 100644 --- a/quantum/keymap_common.c +++ b/quantum/keymap_common.c @@ -118,6 +118,10 @@ action_t action_for_key(uint8_t layer, keypos_t key) action_t action; action.code = ACTION_MODS_TAP_KEY((keycode >> 0x8) & 0xF, keycode & 0xFF); return action; + } else if (keycode >= 0x8000 && keycode < 0x9000) { + action_t action; + action.code = ACTION_LAYER_TAP_KEY((keycode >> 0x8) & 0xF, keycode & 0xFF); + return action; #ifdef UNICODE_ENABLE } else if (keycode >= 0x8000000) { action_t action; diff --git a/quantum/keymap_common.h b/quantum/keymap_common.h index 100300e81..e93e86483 100644 --- a/quantum/keymap_common.h +++ b/quantum/keymap_common.h @@ -177,13 +177,16 @@ extern const uint16_t fn_actions[]; #define MIDI(n) (n | 0x6000) -// H-old, T-ap - 256 keycode max -#define HT(mod, kc) (kc | 0x7000 | ((mod & 0xF) << 8)) +// M-od, T-ap - 256 keycode max +#define MT(mod, kc) (kc | 0x7000 | ((mod & 0xF) << 8)) #define CTL_T(kc) HT(0x1, kc) #define SFT_T(kc) HT(0x2, kc) #define ALT_T(kc) HT(0x4, kc) #define GUI_T(kc) HT(0x8, kc) +// L-ayer, T-ap - 256 keycode max, 16 layer max +#define LT(layer, kc) (kc | 0x7000 | ((layer & 0xF) << 8)) + // For sending unicode codes. // You may not send codes over 1FFF -- this supports most of UTF8. // To have a key that sends out Œ, go UC(0x0152)