Merge remote-tracking branch 'origin/develop' into xap

This commit is contained in:
QMK Bot 2024-07-05 23:58:26 +00:00
commit 35961796b5
7 changed files with 60 additions and 12 deletions

View File

@ -109,3 +109,26 @@ __attribute__((weak)) combo_t* combo_get(uint16_t combo_idx) {
} }
#endif // defined(COMBO_ENABLE) #endif // defined(COMBO_ENABLE)
////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////
// Tap Dance
#if defined(TAP_DANCE_ENABLE)
uint16_t tap_dance_count_raw(void) {
return sizeof(tap_dance_actions) / sizeof(tap_dance_action_t);
}
uint16_t tap_dance_count(void) {
return tap_dance_count_raw();
}
tap_dance_action_t* tap_dance_get_raw(uint16_t tap_dance_idx) {
return &tap_dance_actions[tap_dance_idx];
}
tap_dance_action_t* tap_dance_get(uint16_t tap_dance_idx) {
return tap_dance_get_raw(tap_dance_idx);
}
#endif // defined(TAP_DANCE_ENABLE)

View File

@ -61,9 +61,30 @@ uint16_t combo_count_raw(void);
// Get the number of combos defined in the user's keymap, potentially stored dynamically // Get the number of combos defined in the user's keymap, potentially stored dynamically
uint16_t combo_count(void); uint16_t combo_count(void);
// Get the keycode for the encoder mapping location, stored in firmware rather than any other persistent storage // Get the combo definition, stored in firmware rather than any other persistent storage
combo_t* combo_get_raw(uint16_t combo_idx); combo_t* combo_get_raw(uint16_t combo_idx);
// Get the keycode for the encoder mapping location, potentially stored dynamically // Get the combo definition, potentially stored dynamically
combo_t* combo_get(uint16_t combo_idx); combo_t* combo_get(uint16_t combo_idx);
#endif // defined(COMBO_ENABLE) #endif // defined(COMBO_ENABLE)
////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////
// Tap Dance
#if defined(TAP_DANCE_ENABLE)
// Forward declaration of tap_dance_action_t so we don't need to deal with header reordering
struct tap_dance_action_t;
typedef struct tap_dance_action_t tap_dance_action_t;
// Get the number of tap dances defined in the user's keymap, stored in firmware rather than any other persistent storage
uint16_t tap_dance_count_raw(void);
// Get the number of tap dances defined in the user's keymap, potentially stored dynamically
uint16_t tap_dance_count(void);
// Get the tap dance definitions, stored in firmware rather than any other persistent storage
tap_dance_action_t* tap_dance_get_raw(uint16_t tap_dance_idx);
// Get the tap dance definitions, potentially stored dynamically
tap_dance_action_t* tap_dance_get(uint16_t tap_dance_idx);
#endif // defined(TAP_DANCE_ENABLE)

View File

@ -21,6 +21,7 @@
#include "action_util.h" #include "action_util.h"
#include "timer.h" #include "timer.h"
#include "wait.h" #include "wait.h"
#include "keymap_introspection.h"
static uint16_t active_td; static uint16_t active_td;
static uint16_t last_tap_time; static uint16_t last_tap_time;
@ -133,7 +134,7 @@ bool preprocess_tap_dance(uint16_t keycode, keyrecord_t *record) {
if (!active_td || keycode == active_td) return false; if (!active_td || keycode == active_td) return false;
action = &tap_dance_actions[QK_TAP_DANCE_GET_INDEX(active_td)]; action = tap_dance_get(QK_TAP_DANCE_GET_INDEX(active_td));
action->state.interrupted = true; action->state.interrupted = true;
action->state.interrupting_keycode = keycode; action->state.interrupting_keycode = keycode;
process_tap_dance_action_on_dance_finished(action); process_tap_dance_action_on_dance_finished(action);
@ -150,11 +151,16 @@ bool preprocess_tap_dance(uint16_t keycode, keyrecord_t *record) {
} }
bool process_tap_dance(uint16_t keycode, keyrecord_t *record) { bool process_tap_dance(uint16_t keycode, keyrecord_t *record) {
int td_index;
tap_dance_action_t *action; tap_dance_action_t *action;
switch (keycode) { switch (keycode) {
case QK_TAP_DANCE ... QK_TAP_DANCE_MAX: case QK_TAP_DANCE ... QK_TAP_DANCE_MAX:
action = &tap_dance_actions[QK_TAP_DANCE_GET_INDEX(keycode)]; td_index = QK_TAP_DANCE_GET_INDEX(keycode);
if (td_index >= tap_dance_count()) {
return false;
}
action = tap_dance_get(td_index);
action->state.pressed = record->event.pressed; action->state.pressed = record->event.pressed;
if (record->event.pressed) { if (record->event.pressed) {
@ -182,7 +188,7 @@ void tap_dance_task(void) {
if (!active_td || timer_elapsed(last_tap_time) <= GET_TAPPING_TERM(active_td, &(keyrecord_t){})) return; if (!active_td || timer_elapsed(last_tap_time) <= GET_TAPPING_TERM(active_td, &(keyrecord_t){})) return;
action = &tap_dance_actions[QK_TAP_DANCE_GET_INDEX(active_td)]; action = tap_dance_get(QK_TAP_DANCE_GET_INDEX(active_td));
if (!action->state.interrupted) { if (!action->state.interrupted) {
process_tap_dance_action_on_dance_finished(action); process_tap_dance_action_on_dance_finished(action);
} }

View File

@ -35,7 +35,7 @@ typedef struct {
typedef void (*tap_dance_user_fn_t)(tap_dance_state_t *state, void *user_data); typedef void (*tap_dance_user_fn_t)(tap_dance_state_t *state, void *user_data);
typedef struct { typedef struct tap_dance_action_t {
tap_dance_state_t state; tap_dance_state_t state;
struct { struct {
tap_dance_user_fn_t on_each_tap; tap_dance_user_fn_t on_each_tap;
@ -78,8 +78,6 @@ typedef struct {
#define TD_INDEX(code) QK_TAP_DANCE_GET_INDEX(code) #define TD_INDEX(code) QK_TAP_DANCE_GET_INDEX(code)
#define TAP_DANCE_KEYCODE(state) TD(((tap_dance_action_t *)state) - tap_dance_actions) #define TAP_DANCE_KEYCODE(state) TD(((tap_dance_action_t *)state) - tap_dance_actions)
extern tap_dance_action_t tap_dance_actions[];
void reset_tap_dance(tap_dance_state_t *state); void reset_tap_dance(tap_dance_state_t *state);
/* To be used internally */ /* To be used internally */

View File

@ -16,6 +16,7 @@
#include "quantum.h" #include "quantum.h"
#include "examples.h" #include "examples.h"
#include "keymap_introspection.h"
// Example code from the tap dance documentation, adapted for testing // Example code from the tap dance documentation, adapted for testing
@ -83,7 +84,7 @@ bool process_record_user(uint16_t keycode, keyrecord_t *record) {
switch (keycode) { switch (keycode) {
case TD(CT_CLN): case TD(CT_CLN):
action = &tap_dance_actions[QK_TAP_DANCE_GET_INDEX(keycode)]; action = tap_dance_get(QK_TAP_DANCE_GET_INDEX(keycode));
if (!record->event.pressed && action->state.count && !action->state.finished) { if (!record->event.pressed && action->state.count && !action->state.finished) {
tap_dance_tap_hold_t *tap_hold = (tap_dance_tap_hold_t *)action->user_data; tap_dance_tap_hold_t *tap_hold = (tap_dance_tap_hold_t *)action->user_data;
tap_code16(tap_hold->tap); tap_code16(tap_hold->tap);

View File

@ -7,4 +7,4 @@
TAP_DANCE_ENABLE = yes TAP_DANCE_ENABLE = yes
SRC += tap_dance_defs.c INTROSPECTION_KEYMAP_C = tap_dance_defs.c

View File

@ -18,5 +18,4 @@
# -------------------------------------------------------------------------------- # --------------------------------------------------------------------------------
TAP_DANCE_ENABLE = yes TAP_DANCE_ENABLE = yes
INTROSPECTION_KEYMAP_C = examples.c
SRC += examples.c