update Achordion
This commit is contained in:
parent
ee341d225b
commit
0c9112bcad
|
@ -74,6 +74,16 @@ static void update_streak_timer(uint16_t keycode, keyrecord_t* record) {
|
||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
// Presses or releases eager_mods through process_action(), which skips the
|
||||||
|
// usual event handling pipeline. The action is considered as a mod-tap hold or
|
||||||
|
// release, with Retro Tapping if enabled.
|
||||||
|
static void process_eager_mods_action(void) {
|
||||||
|
action_t action;
|
||||||
|
action.code = ACTION_MODS_TAP_KEY(
|
||||||
|
eager_mods, QK_MOD_TAP_GET_TAP_KEYCODE(tap_hold_keycode));
|
||||||
|
process_action(&tap_hold_record, action);
|
||||||
|
}
|
||||||
|
|
||||||
// Calls `process_record()` with state set to RECURSING.
|
// Calls `process_record()` with state set to RECURSING.
|
||||||
static void recursively_process_record(keyrecord_t* record, uint8_t state) {
|
static void recursively_process_record(keyrecord_t* record, uint8_t state) {
|
||||||
achordion_state = STATE_RECURSING;
|
achordion_state = STATE_RECURSING;
|
||||||
|
@ -92,9 +102,11 @@ static void settle_as_hold(void) {
|
||||||
if (eager_mods) {
|
if (eager_mods) {
|
||||||
// If eager mods are being applied, nothing needs to be done besides
|
// If eager mods are being applied, nothing needs to be done besides
|
||||||
// updating the state.
|
// updating the state.
|
||||||
|
dprintln("Achordion: Settled eager mod as hold.");
|
||||||
achordion_state = STATE_HOLDING;
|
achordion_state = STATE_HOLDING;
|
||||||
} else {
|
} else {
|
||||||
// Create hold press event.
|
// Create hold press event.
|
||||||
|
dprintln("Achordion: Plumbing hold press.");
|
||||||
recursively_process_record(&tap_hold_record, STATE_HOLDING);
|
recursively_process_record(&tap_hold_record, STATE_HOLDING);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -102,14 +114,22 @@ static void settle_as_hold(void) {
|
||||||
// Sends tap press and release and settles the active tap-hold key as tapped.
|
// Sends tap press and release and settles the active tap-hold key as tapped.
|
||||||
static void settle_as_tap(void) {
|
static void settle_as_tap(void) {
|
||||||
if (eager_mods) { // Clear eager mods if set.
|
if (eager_mods) { // Clear eager mods if set.
|
||||||
|
#if defined(RETRO_TAPPING) || defined(RETRO_TAPPING_PER_KEY)
|
||||||
#ifdef DUMMY_MOD_NEUTRALIZER_KEYCODE
|
#ifdef DUMMY_MOD_NEUTRALIZER_KEYCODE
|
||||||
neutralize_flashing_modifiers(get_mods());
|
neutralize_flashing_modifiers(get_mods());
|
||||||
#endif // DUMMY_MOD_NEUTRALIZER_KEYCODE
|
#endif // DUMMY_MOD_NEUTRALIZER_KEYCODE
|
||||||
unregister_mods(eager_mods);
|
#endif // defined(RETRO_TAPPING) || defined(RETRO_TAPPING_PER_KEY)
|
||||||
|
tap_hold_record.event.pressed = false;
|
||||||
|
// To avoid falsely triggering Retro Tapping, process eager mods release as
|
||||||
|
// a regular mods release rather than a mod-tap release.
|
||||||
|
action_t action;
|
||||||
|
action.code = ACTION_MODS(eager_mods);
|
||||||
|
process_action(&tap_hold_record, action);
|
||||||
eager_mods = 0;
|
eager_mods = 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
dprintln("Achordion: Plumbing tap press.");
|
dprintln("Achordion: Plumbing tap press.");
|
||||||
|
tap_hold_record.event.pressed = true;
|
||||||
tap_hold_record.tap.count = 1; // Revise event as a tap.
|
tap_hold_record.tap.count = 1; // Revise event as a tap.
|
||||||
tap_hold_record.tap.interrupted = true;
|
tap_hold_record.tap.interrupted = true;
|
||||||
// Plumb tap press event.
|
// Plumb tap press event.
|
||||||
|
@ -155,9 +175,16 @@ bool process_achordion(uint16_t keycode, keyrecord_t* record) {
|
||||||
|
|
||||||
if (is_mt) { // Apply mods immediately if they are "eager."
|
if (is_mt) { // Apply mods immediately if they are "eager."
|
||||||
const uint8_t mod = mod_config(QK_MOD_TAP_GET_MODS(keycode));
|
const uint8_t mod = mod_config(QK_MOD_TAP_GET_MODS(keycode));
|
||||||
if (achordion_eager_mod(mod)) {
|
if (
|
||||||
eager_mods = ((mod & 0x10) == 0) ? mod : (mod << 4);
|
#if defined(CAPS_WORD_ENABLE) && defined(CAPS_WORD_INVERT_ON_SHIFT)
|
||||||
register_mods(eager_mods);
|
// Since eager mods bypass normal event handling, eager Shift does
|
||||||
|
// not work with CAPS_WORD_INVERT_ON_SHIFT. So if this option is
|
||||||
|
// enabled, we don't apply Shift eagerly when Caps Word is on.
|
||||||
|
!(is_caps_word_on() && (mod & MOD_LSFT) != 0) &&
|
||||||
|
#endif // defined(CAPS_WORD_ENABLE) && defined(CAPS_WORD_INVERT_ON_SHIFT)
|
||||||
|
achordion_eager_mod(mod)) {
|
||||||
|
eager_mods = mod;
|
||||||
|
process_eager_mods_action();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -180,18 +207,8 @@ bool process_achordion(uint16_t keycode, keyrecord_t* record) {
|
||||||
if (keycode == tap_hold_keycode && !record->event.pressed) {
|
if (keycode == tap_hold_keycode && !record->event.pressed) {
|
||||||
if (eager_mods) {
|
if (eager_mods) {
|
||||||
dprintln("Achordion: Key released. Clearing eager mods.");
|
dprintln("Achordion: Key released. Clearing eager mods.");
|
||||||
// If Retro Tapping and no other key was pressed, settle as tapped.
|
tap_hold_record.event.pressed = false;
|
||||||
#if defined(RETRO_TAPPING) || defined(RETRO_TAPPING_PER_KEY)
|
process_eager_mods_action();
|
||||||
if (!pressed_another_key_before_release
|
|
||||||
#ifdef RETRO_TAPPING_PER_KEY
|
|
||||||
&& get_retro_tapping(tap_hold_keycode, &tap_hold_record)
|
|
||||||
#endif // RETREO_TAPPING_PER_KEY
|
|
||||||
) {
|
|
||||||
settle_as_tap();
|
|
||||||
}
|
|
||||||
#endif // defined(RETRO_TAPPING) || defined(RETRO_TAPPING_PER_KEY)
|
|
||||||
|
|
||||||
unregister_mods(eager_mods);
|
|
||||||
} else if (achordion_state == STATE_HOLDING) {
|
} else if (achordion_state == STATE_HOLDING) {
|
||||||
dprintln("Achordion: Key released. Plumbing hold release.");
|
dprintln("Achordion: Key released. Plumbing hold release.");
|
||||||
tap_hold_record.event.pressed = false;
|
tap_hold_record.event.pressed = false;
|
||||||
|
@ -238,7 +255,6 @@ bool process_achordion(uint16_t keycode, keyrecord_t* record) {
|
||||||
(!is_key_event || (is_tap_hold && record->tap.count == 0) ||
|
(!is_key_event || (is_tap_hold && record->tap.count == 0) ||
|
||||||
achordion_chord(tap_hold_keycode, &tap_hold_record, keycode,
|
achordion_chord(tap_hold_keycode, &tap_hold_record, keycode,
|
||||||
record))) {
|
record))) {
|
||||||
dprintln("Achordion: Plumbing hold press.");
|
|
||||||
settle_as_hold();
|
settle_as_hold();
|
||||||
|
|
||||||
#ifdef REPEAT_KEY_ENABLE
|
#ifdef REPEAT_KEY_ENABLE
|
||||||
|
@ -285,7 +301,6 @@ bool process_achordion(uint16_t keycode, keyrecord_t* record) {
|
||||||
void achordion_task(void) {
|
void achordion_task(void) {
|
||||||
if (achordion_state == STATE_UNSETTLED &&
|
if (achordion_state == STATE_UNSETTLED &&
|
||||||
timer_expired(timer_read(), hold_timer)) {
|
timer_expired(timer_read(), hold_timer)) {
|
||||||
dprintln("Achordion: Timeout. Plumbing hold press.");
|
|
||||||
settle_as_hold(); // Timeout expired, settle the key as held.
|
settle_as_hold(); // Timeout expired, settle the key as held.
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue