Add dynamic key overrides support
This commit is contained in:
parent
0f73a109c6
commit
53a41dcfab
@ -555,6 +555,7 @@ ifeq ($(strip $(VIAL_ENABLE)), yes)
|
|||||||
QMK_SETTINGS ?= yes
|
QMK_SETTINGS ?= yes
|
||||||
TAP_DANCE_ENABLE ?= yes
|
TAP_DANCE_ENABLE ?= yes
|
||||||
COMBO_ENABLE ?= yes
|
COMBO_ENABLE ?= yes
|
||||||
|
KEY_OVERRIDE_ENABLE ?= yes
|
||||||
SRC += $(QUANTUM_DIR)/vial.c
|
SRC += $(QUANTUM_DIR)/vial.c
|
||||||
EXTRAINCDIRS += $(KEYMAP_OUTPUT)
|
EXTRAINCDIRS += $(KEYMAP_OUTPUT)
|
||||||
OPT_DEFS += -DVIAL_ENABLE -DNO_DEBUG -DSERIAL_NUMBER=\"vial:f64c2b3c\"
|
OPT_DEFS += -DVIAL_ENABLE -DNO_DEBUG -DSERIAL_NUMBER=\"vial:f64c2b3c\"
|
||||||
|
@ -101,9 +101,18 @@ static pin_t encoders_pad_a[] = ENCODERS_PAD_A;
|
|||||||
#define VIAL_COMBO_SIZE 0
|
#define VIAL_COMBO_SIZE 0
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
// Key overrides
|
||||||
|
#define VIAL_KEY_OVERRIDE_EEPROM_ADDR (VIAL_COMBO_EEPROM_ADDR + VIAL_COMBO_SIZE)
|
||||||
|
|
||||||
|
#ifdef VIAL_KEY_OVERRIDE_ENABLE
|
||||||
|
#define VIAL_KEY_OVERRIDE_SIZE (sizeof(vial_key_override_entry_t) * VIAL_KEY_OVERRIDE_ENTRIES)
|
||||||
|
#else
|
||||||
|
#define VIAL_KEY_OVERRIDE_SIZE 0
|
||||||
|
#endif
|
||||||
|
|
||||||
// Dynamic macro
|
// Dynamic macro
|
||||||
#ifndef DYNAMIC_KEYMAP_MACRO_EEPROM_ADDR
|
#ifndef DYNAMIC_KEYMAP_MACRO_EEPROM_ADDR
|
||||||
# define DYNAMIC_KEYMAP_MACRO_EEPROM_ADDR (VIAL_COMBO_EEPROM_ADDR + VIAL_COMBO_SIZE)
|
# define DYNAMIC_KEYMAP_MACRO_EEPROM_ADDR (VIAL_KEY_OVERRIDE_EEPROM_ADDR + VIAL_KEY_OVERRIDE_SIZE)
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
// Sanity check that dynamic keymaps fit in available EEPROM
|
// Sanity check that dynamic keymaps fit in available EEPROM
|
||||||
@ -246,6 +255,28 @@ int dynamic_keymap_set_combo(uint8_t index, const vial_combo_entry_t *entry) {
|
|||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
#ifdef VIAL_KEY_OVERRIDE_ENABLE
|
||||||
|
int dynamic_keymap_get_key_override(uint8_t index, vial_key_override_entry_t *entry) {
|
||||||
|
if (index >= VIAL_KEY_OVERRIDE_ENTRIES)
|
||||||
|
return -1;
|
||||||
|
|
||||||
|
void *address = (void*)(VIAL_KEY_OVERRIDE_EEPROM_ADDR + index * sizeof(vial_key_override_entry_t));
|
||||||
|
eeprom_read_block(entry, address, sizeof(vial_key_override_entry_t));
|
||||||
|
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
int dynamic_keymap_set_key_override(uint8_t index, const vial_key_override_entry_t *entry) {
|
||||||
|
if (index >= VIAL_KEY_OVERRIDE_ENTRIES)
|
||||||
|
return -1;
|
||||||
|
|
||||||
|
void *address = (void*)(VIAL_KEY_OVERRIDE_EEPROM_ADDR + index * sizeof(vial_key_override_entry_t));
|
||||||
|
eeprom_write_block(entry, address, sizeof(vial_key_override_entry_t));
|
||||||
|
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
|
||||||
#if defined(VIAL_ENCODERS_ENABLE) && defined(VIAL_ENCODER_DEFAULT)
|
#if defined(VIAL_ENCODERS_ENABLE) && defined(VIAL_ENCODER_DEFAULT)
|
||||||
static const uint16_t PROGMEM vial_encoder_default[] = VIAL_ENCODER_DEFAULT;
|
static const uint16_t PROGMEM vial_encoder_default[] = VIAL_ENCODER_DEFAULT;
|
||||||
_Static_assert(sizeof(vial_encoder_default)/sizeof(*vial_encoder_default) == 2 * DYNAMIC_KEYMAP_LAYER_COUNT * NUMBER_OF_ENCODERS,
|
_Static_assert(sizeof(vial_encoder_default)/sizeof(*vial_encoder_default) == 2 * DYNAMIC_KEYMAP_LAYER_COUNT * NUMBER_OF_ENCODERS,
|
||||||
@ -299,6 +330,14 @@ void dynamic_keymap_reset(void) {
|
|||||||
dynamic_keymap_set_combo(i, &combo);
|
dynamic_keymap_set_combo(i, &combo);
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
#ifdef VIAL_KEY_OVERRIDE_ENABLE
|
||||||
|
vial_key_override_entry_t ko = { 0 };
|
||||||
|
ko.layers = ~0;
|
||||||
|
ko.options = vial_ko_option_activation_negative_mod_up | vial_ko_option_activation_required_mod_down | vial_ko_option_activation_trigger_down;
|
||||||
|
for (size_t i = 0; i < VIAL_KEY_OVERRIDE_ENTRIES; ++i)
|
||||||
|
dynamic_keymap_set_key_override(i, &ko);
|
||||||
|
#endif
|
||||||
|
|
||||||
#ifdef VIAL_ENABLE
|
#ifdef VIAL_ENABLE
|
||||||
/* re-lock the keyboard */
|
/* re-lock the keyboard */
|
||||||
vial_unlocked = vial_unlocked_prev;
|
vial_unlocked = vial_unlocked_prev;
|
||||||
|
@ -46,6 +46,10 @@ int dynamic_keymap_set_tap_dance(uint8_t index, const vial_tap_dance_entry_t *en
|
|||||||
int dynamic_keymap_get_combo(uint8_t index, vial_combo_entry_t *entry);
|
int dynamic_keymap_get_combo(uint8_t index, vial_combo_entry_t *entry);
|
||||||
int dynamic_keymap_set_combo(uint8_t index, const vial_combo_entry_t *entry);
|
int dynamic_keymap_set_combo(uint8_t index, const vial_combo_entry_t *entry);
|
||||||
#endif
|
#endif
|
||||||
|
#ifdef VIAL_KEY_OVERRIDE_ENABLE
|
||||||
|
int dynamic_keymap_get_key_override(uint8_t index, vial_key_override_entry_t *entry);
|
||||||
|
int dynamic_keymap_set_key_override(uint8_t index, const vial_key_override_entry_t *entry);
|
||||||
|
#endif
|
||||||
void dynamic_keymap_reset(void);
|
void dynamic_keymap_reset(void);
|
||||||
// These get/set the keycodes as stored in the EEPROM buffer
|
// These get/set the keycodes as stored in the EEPROM buffer
|
||||||
// Data is big-endian 16-bit values (the keycodes)
|
// Data is big-endian 16-bit values (the keycodes)
|
||||||
|
@ -58,6 +58,10 @@ static void reload_tap_dance(void);
|
|||||||
static void reload_combo(void);
|
static void reload_combo(void);
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
#ifdef VIAL_KEY_OVERRIDE_ENABLE
|
||||||
|
static void reload_key_override(void);
|
||||||
|
#endif
|
||||||
|
|
||||||
void vial_init(void) {
|
void vial_init(void) {
|
||||||
#ifdef VIAL_TAP_DANCE_ENABLE
|
#ifdef VIAL_TAP_DANCE_ENABLE
|
||||||
reload_tap_dance();
|
reload_tap_dance();
|
||||||
@ -65,6 +69,9 @@ void vial_init(void) {
|
|||||||
#ifdef VIAL_COMBO_ENABLE
|
#ifdef VIAL_COMBO_ENABLE
|
||||||
reload_combo();
|
reload_combo();
|
||||||
#endif
|
#endif
|
||||||
|
#ifdef VIAL_KEY_OVERRIDE_ENABLE
|
||||||
|
reload_key_override();
|
||||||
|
#endif
|
||||||
}
|
}
|
||||||
|
|
||||||
void vial_handle_cmd(uint8_t *msg, uint8_t length) {
|
void vial_handle_cmd(uint8_t *msg, uint8_t length) {
|
||||||
@ -214,6 +221,7 @@ void vial_handle_cmd(uint8_t *msg, uint8_t length) {
|
|||||||
memset(msg, 0, length);
|
memset(msg, 0, length);
|
||||||
msg[0] = VIAL_TAP_DANCE_ENTRIES;
|
msg[0] = VIAL_TAP_DANCE_ENTRIES;
|
||||||
msg[1] = VIAL_COMBO_ENTRIES;
|
msg[1] = VIAL_COMBO_ENTRIES;
|
||||||
|
msg[2] = VIAL_KEY_OVERRIDE_ENTRIES;
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
#ifdef VIAL_TAP_DANCE_ENABLE
|
#ifdef VIAL_TAP_DANCE_ENABLE
|
||||||
@ -249,6 +257,23 @@ void vial_handle_cmd(uint8_t *msg, uint8_t length) {
|
|||||||
reload_combo();
|
reload_combo();
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
#endif
|
||||||
|
#ifdef VIAL_KEY_OVERRIDE_ENABLE
|
||||||
|
case dynamic_vial_key_override_get: {
|
||||||
|
uint8_t idx = msg[3];
|
||||||
|
vial_key_override_entry_t entry = { 0 };
|
||||||
|
msg[0] = dynamic_keymap_get_key_override(idx, &entry);
|
||||||
|
memcpy(&msg[1], &entry, sizeof(entry));
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
case dynamic_vial_key_override_set: {
|
||||||
|
uint8_t idx = msg[3];
|
||||||
|
vial_key_override_entry_t entry;
|
||||||
|
memcpy(&entry, &msg[4], sizeof(entry));
|
||||||
|
msg[0] = dynamic_keymap_set_key_override(idx, &entry);
|
||||||
|
reload_key_override();
|
||||||
|
break;
|
||||||
|
}
|
||||||
#endif
|
#endif
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -544,3 +569,48 @@ bool process_record_vial(uint16_t keycode, keyrecord_t *record) {
|
|||||||
|
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#ifdef VIAL_KEY_OVERRIDE_ENABLE
|
||||||
|
static bool vial_key_override_disabled = 0;
|
||||||
|
static key_override_t overrides[VIAL_KEY_OVERRIDE_ENTRIES] = { 0 };
|
||||||
|
static key_override_t *override_ptrs[VIAL_KEY_OVERRIDE_ENTRIES + 1] = { 0 };
|
||||||
|
const key_override_t **key_overrides = (const key_override_t**)override_ptrs;
|
||||||
|
|
||||||
|
static int vial_get_key_override(uint8_t index, key_override_t *out) {
|
||||||
|
vial_key_override_entry_t entry;
|
||||||
|
int ret;
|
||||||
|
if ((ret = dynamic_keymap_get_key_override(index, &entry)) != 0)
|
||||||
|
return ret;
|
||||||
|
|
||||||
|
memset(out, 0, sizeof(*out));
|
||||||
|
out->trigger = entry.trigger;
|
||||||
|
out->trigger_mods = entry.trigger_mods;
|
||||||
|
out->layers = entry.layers;
|
||||||
|
out->negative_mod_mask = entry.negative_mod_mask;
|
||||||
|
out->suppressed_mods = entry.suppressed_mods;
|
||||||
|
out->replacement = entry.replacement;
|
||||||
|
out->options = 0;
|
||||||
|
uint8_t opt = entry.options;
|
||||||
|
if (opt & vial_ko_enabled)
|
||||||
|
out->enabled = NULL;
|
||||||
|
else
|
||||||
|
out->enabled = &vial_key_override_disabled;
|
||||||
|
/* right now these options match one-to-one so this isn't strictly necessary,
|
||||||
|
nevertheless future-proof the code by parsing them out to ensure "stable" abi */
|
||||||
|
if (opt & vial_ko_option_activation_trigger_down) out->options |= ko_option_activation_trigger_down;
|
||||||
|
if (opt & vial_ko_option_activation_required_mod_down) out->options |= ko_option_activation_required_mod_down;
|
||||||
|
if (opt & vial_ko_option_activation_negative_mod_up) out->options |= ko_option_activation_negative_mod_up;
|
||||||
|
if (opt & vial_ko_option_one_mod) out->options |= ko_option_one_mod;
|
||||||
|
if (opt & vial_ko_option_no_reregister_trigger) out->options |= ko_option_no_reregister_trigger;
|
||||||
|
if (opt & vial_ko_option_no_unregister_on_other_key_down) out->options |= ko_option_no_unregister_on_other_key_down;
|
||||||
|
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
static void reload_key_override(void) {
|
||||||
|
for (size_t i = 0; i < VIAL_KEY_OVERRIDE_ENTRIES; ++i) {
|
||||||
|
override_ptrs[i] = &overrides[i];
|
||||||
|
vial_get_key_override(i, &overrides[i]);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
@ -59,14 +59,16 @@ enum {
|
|||||||
dynamic_vial_tap_dance_set = 0x02,
|
dynamic_vial_tap_dance_set = 0x02,
|
||||||
dynamic_vial_combo_get = 0x03,
|
dynamic_vial_combo_get = 0x03,
|
||||||
dynamic_vial_combo_set = 0x04,
|
dynamic_vial_combo_set = 0x04,
|
||||||
|
dynamic_vial_key_override_get = 0x05,
|
||||||
|
dynamic_vial_key_override_set = 0x06,
|
||||||
};
|
};
|
||||||
|
|
||||||
/* Fake position in keyboard matrix, can't use 255 as that is immediately rejected by IS_NOEVENT
|
/* Fake position in keyboard matrix, can't use 255 as that is immediately rejected by IS_NOEVENT
|
||||||
used to send arbitrary keycodes thru process_record_quantum_helper */
|
used to send arbitrary keycodes thru process_record_quantum_helper */
|
||||||
#define VIAL_MATRIX_MAGIC 254
|
#define VIAL_MATRIX_MAGIC 254
|
||||||
|
|
||||||
#ifdef TAP_DANCE_ENABLE
|
|
||||||
|
|
||||||
|
#ifdef TAP_DANCE_ENABLE
|
||||||
#define VIAL_TAP_DANCE_ENABLE
|
#define VIAL_TAP_DANCE_ENABLE
|
||||||
|
|
||||||
#ifndef VIAL_TAP_DANCE_ENTRIES
|
#ifndef VIAL_TAP_DANCE_ENTRIES
|
||||||
@ -95,6 +97,7 @@ _Static_assert(sizeof(vial_tap_dance_entry_t) == 10, "Unexpected size of the via
|
|||||||
#define VIAL_TAP_DANCE_ENTRIES 0
|
#define VIAL_TAP_DANCE_ENTRIES 0
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
|
||||||
#ifdef COMBO_ENABLE
|
#ifdef COMBO_ENABLE
|
||||||
#define VIAL_COMBO_ENABLE
|
#define VIAL_COMBO_ENABLE
|
||||||
|
|
||||||
@ -127,3 +130,49 @@ _Static_assert(sizeof(vial_combo_entry_t) == 10, "Unexpected size of the vial_co
|
|||||||
#undef VIAL_COMBO_ENTRIES
|
#undef VIAL_COMBO_ENTRIES
|
||||||
#define VIAL_COMBO_ENTRIES 0
|
#define VIAL_COMBO_ENTRIES 0
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
|
||||||
|
#ifdef KEY_OVERRIDE_ENABLE
|
||||||
|
#define VIAL_KEY_OVERRIDE_ENABLE
|
||||||
|
|
||||||
|
#include "process_key_override.h"
|
||||||
|
|
||||||
|
#ifndef VIAL_KEY_OVERRIDE_ENTRIES
|
||||||
|
#if DYNAMIC_KEYMAP_EEPROM_MAX_ADDR > 4000
|
||||||
|
#define VIAL_KEY_OVERRIDE_ENTRIES 32
|
||||||
|
#elif DYNAMIC_KEYMAP_EEPROM_MAX_ADDR > 2000
|
||||||
|
#define VIAL_KEY_OVERRIDE_ENTRIES 16
|
||||||
|
#elif DYNAMIC_KEYMAP_EEPROM_MAX_ADDR > 1000
|
||||||
|
#define VIAL_KEY_OVERRIDE_ENTRIES 8
|
||||||
|
#else
|
||||||
|
#define VIAL_KEY_OVERRIDE_ENTRIES 4
|
||||||
|
#endif
|
||||||
|
#endif
|
||||||
|
|
||||||
|
/* the key override structure as it is stored in eeprom and transferred to vial-gui;
|
||||||
|
it is deserialized into key_override_t by vial_get_key_override */
|
||||||
|
typedef struct {
|
||||||
|
uint16_t trigger;
|
||||||
|
uint16_t replacement;
|
||||||
|
uint16_t layers;
|
||||||
|
uint8_t trigger_mods;
|
||||||
|
uint8_t negative_mod_mask;
|
||||||
|
uint8_t suppressed_mods;
|
||||||
|
uint8_t options;
|
||||||
|
} vial_key_override_entry_t;
|
||||||
|
_Static_assert(sizeof(vial_key_override_entry_t) == 10, "Unexpected size of the vial_key_override_entry_t structure");
|
||||||
|
|
||||||
|
enum {
|
||||||
|
vial_ko_option_activation_trigger_down = (1 << 0),
|
||||||
|
vial_ko_option_activation_required_mod_down = (1 << 1),
|
||||||
|
vial_ko_option_activation_negative_mod_up = (1 << 2),
|
||||||
|
vial_ko_option_one_mod = (1 << 3),
|
||||||
|
vial_ko_option_no_reregister_trigger = (1 << 4),
|
||||||
|
vial_ko_option_no_unregister_on_other_key_down = (1 << 5),
|
||||||
|
vial_ko_enabled = (1 << 7),
|
||||||
|
};
|
||||||
|
|
||||||
|
#else
|
||||||
|
#undef VIAL_KEY_OVERRIDE_ENTRIES
|
||||||
|
#define VIAL_KEY_OVERRIDE_ENTRIES 0
|
||||||
|
#endif
|
||||||
|
Loading…
Reference in New Issue
Block a user