aboutsummaryrefslogtreecommitdiff
path: root/quantum/process_keycode/process_tap_dance.h
diff options
context:
space:
mode:
authorscauligi <scauligi@eng.ucsd.edu>2018-02-04 10:45:19 -0800
committerJack Humbert <jack.humb@gmail.com>2018-02-04 13:45:19 -0500
commit9fcda95363568156887c76867e843a86f8f75757 (patch)
treed9677c75a66589f5a32453003ba814458bb50b8e /quantum/process_keycode/process_tap_dance.h
parent2908c0f9277d021d35133940d6a4d77569229ecf (diff)
downloadqmk_firmware-9fcda95363568156887c76867e843a86f8f75757.tar.gz
qmk_firmware-9fcda95363568156887c76867e843a86f8f75757.zip
Fixes to get tap dance to fire at proper places (#2272)
* tap dance fixes: fire immediately upon completion and also get properly interrupted before macros * bugfix for tapdance improvement * fix build
Diffstat (limited to 'quantum/process_keycode/process_tap_dance.h')
-rw-r--r--quantum/process_keycode/process_tap_dance.h7
1 files changed, 5 insertions, 2 deletions
diff --git a/quantum/process_keycode/process_tap_dance.h b/quantum/process_keycode/process_tap_dance.h
index ab20ea04e..8b0a47c49 100644
--- a/quantum/process_keycode/process_tap_dance.h
+++ b/quantum/process_keycode/process_tap_dance.h
@@ -62,12 +62,12 @@ typedef struct
62} qk_tap_dance_dual_role_t; 62} qk_tap_dance_dual_role_t;
63 63
64#define ACTION_TAP_DANCE_DOUBLE(kc1, kc2) { \ 64#define ACTION_TAP_DANCE_DOUBLE(kc1, kc2) { \
65 .fn = { NULL, qk_tap_dance_pair_finished, qk_tap_dance_pair_reset }, \ 65 .fn = { qk_tap_dance_pair_on_each_tap, qk_tap_dance_pair_finished, qk_tap_dance_pair_reset }, \
66 .user_data = (void *)&((qk_tap_dance_pair_t) { kc1, kc2 }), \ 66 .user_data = (void *)&((qk_tap_dance_pair_t) { kc1, kc2 }), \
67 } 67 }
68 68
69#define ACTION_TAP_DANCE_DUAL_ROLE(kc, layer) { \ 69#define ACTION_TAP_DANCE_DUAL_ROLE(kc, layer) { \
70 .fn = { NULL, qk_tap_dance_dual_role_finished, qk_tap_dance_dual_role_reset }, \ 70 .fn = { qk_tap_dance_dual_role_on_each_tap, qk_tap_dance_dual_role_finished, qk_tap_dance_dual_role_reset }, \
71 .user_data = (void *)&((qk_tap_dance_dual_role_t) { kc, layer }), \ 71 .user_data = (void *)&((qk_tap_dance_dual_role_t) { kc, layer }), \
72 } 72 }
73 73
@@ -91,13 +91,16 @@ extern qk_tap_dance_action_t tap_dance_actions[];
91 91
92/* To be used internally */ 92/* To be used internally */
93 93
94void preprocess_tap_dance(uint16_t keycode, keyrecord_t *record);
94bool process_tap_dance(uint16_t keycode, keyrecord_t *record); 95bool process_tap_dance(uint16_t keycode, keyrecord_t *record);
95void matrix_scan_tap_dance (void); 96void matrix_scan_tap_dance (void);
96void reset_tap_dance (qk_tap_dance_state_t *state); 97void reset_tap_dance (qk_tap_dance_state_t *state);
97 98
99void qk_tap_dance_pair_on_each_tap (qk_tap_dance_state_t *state, void *user_data);
98void qk_tap_dance_pair_finished (qk_tap_dance_state_t *state, void *user_data); 100void qk_tap_dance_pair_finished (qk_tap_dance_state_t *state, void *user_data);
99void qk_tap_dance_pair_reset (qk_tap_dance_state_t *state, void *user_data); 101void qk_tap_dance_pair_reset (qk_tap_dance_state_t *state, void *user_data);
100 102
103void qk_tap_dance_dual_role_on_each_tap (qk_tap_dance_state_t *state, void *user_data);
101void qk_tap_dance_dual_role_finished (qk_tap_dance_state_t *state, void *user_data); 104void qk_tap_dance_dual_role_finished (qk_tap_dance_state_t *state, void *user_data);
102void qk_tap_dance_dual_role_reset (qk_tap_dance_state_t *state, void *user_data); 105void qk_tap_dance_dual_role_reset (qk_tap_dance_state_t *state, void *user_data);
103 106