mirror of
https://github.com/qmk/qmk_firmware.git
synced 2025-01-16 06:39:25 +00:00
parent
4e4250063e
commit
c2480884aa
@ -53,6 +53,26 @@ void action_exec(keyevent_t event)
|
||||
#endif
|
||||
}
|
||||
|
||||
/*
|
||||
* Make sure the action triggered when the key is released is the same
|
||||
* one as the one triggered on press. It's important for the mod keys
|
||||
* when the layer is switched after the down event but before the up
|
||||
* event as they may get stuck otherwise.
|
||||
*/
|
||||
action_t store_or_get_action(bool pressed, keypos_t key)
|
||||
{
|
||||
#ifndef NO_ACTION_LAYER
|
||||
static action_t pressed_actions[MATRIX_ROWS][MATRIX_COLS];
|
||||
|
||||
if (pressed) {
|
||||
pressed_actions[key.row][key.col] = layer_switch_get_action(key);
|
||||
}
|
||||
return pressed_actions[key.row][key.col];
|
||||
#else
|
||||
return layer_switch_get_action(key);
|
||||
#endif
|
||||
}
|
||||
|
||||
void process_action(keyrecord_t *record)
|
||||
{
|
||||
keyevent_t event = record->event;
|
||||
@ -62,7 +82,7 @@ void process_action(keyrecord_t *record)
|
||||
|
||||
if (IS_NOEVENT(event)) { return; }
|
||||
|
||||
action_t action = layer_switch_get_action(event.key);
|
||||
action_t action = store_or_get_action(event.pressed, event.key);
|
||||
dprint("ACTION: "); debug_action(action);
|
||||
#ifndef NO_ACTION_LAYER
|
||||
dprint(" layer_state: "); layer_debug();
|
||||
|
Loading…
Reference in New Issue
Block a user