diff options
author | Nick Choi <iinikchi@gmail.com> | 2017-05-25 16:26:30 -0400 |
---|---|---|
committer | Nick Choi <iinikchi@gmail.com> | 2017-05-25 16:26:30 -0400 |
commit | aeb3a34636c614cd392cfc6268491a51a461df31 (patch) | |
tree | 4395604c2c6bd7d9adb0f1eb0d99b2f536eec88f | |
parent | e695b5a33b97cfb4f9dd8bc8ecaff8aa7e0f14cc (diff) | |
download | qmk_firmware-aeb3a34636c614cd392cfc6268491a51a461df31.tar.gz qmk_firmware-aeb3a34636c614cd392cfc6268491a51a461df31.zip |
moved specific tap term to its own function
included custom_tapping_term in action struct
-rw-r--r-- | keyboards/frosty_flake/keymaps/nikchi/keymap.c | 8 | ||||
-rw-r--r-- | quantum/process_keycode/process_tap_dance.c | 6 | ||||
-rw-r--r-- | quantum/process_keycode/process_tap_dance.h | 12 |
3 files changed, 18 insertions, 8 deletions
diff --git a/keyboards/frosty_flake/keymaps/nikchi/keymap.c b/keyboards/frosty_flake/keymaps/nikchi/keymap.c index 3cfe0ede4..d522fdf1c 100644 --- a/keyboards/frosty_flake/keymaps/nikchi/keymap.c +++ b/keyboards/frosty_flake/keymaps/nikchi/keymap.c | |||
@@ -77,10 +77,10 @@ enum quick { | |||
77 | qk_tap_dance_action_t tap_dance_actions[] = { | 77 | qk_tap_dance_action_t tap_dance_actions[] = { |
78 | // Tap once for CTRL, twice for Caps Lock | 78 | // Tap once for CTRL, twice for Caps Lock |
79 | [TD_CTCPS] = ACTION_TAP_DANCE_DOUBLE(KC_LCTL, KC_CAPS), | 79 | [TD_CTCPS] = ACTION_TAP_DANCE_DOUBLE(KC_LCTL, KC_CAPS), |
80 | [EMOJIS] = ACTION_TAP_DANCE_FN_ADVANCED(cycleEmojis, NULL, NULL, 800), | 80 | [EMOJIS] = ACTION_TAP_DANCE_FN_ADVANCED_TIME(cycleEmojis, NULL, NULL, 800), |
81 | [ANIMAL] = ACTION_TAP_DANCE_FN_ADVANCED(cycleAnimals, NULL, NULL, 800), | 81 | [ANIMAL] = ACTION_TAP_DANCE_FN_ADVANCED_TIME(cycleAnimals, NULL, NULL, 800), |
82 | [HAND] = ACTION_TAP_DANCE_FN_ADVANCED(cycleHands, NULL, NULL, 800), | 82 | [HAND] = ACTION_TAP_DANCE_FN_ADVANCED_TIME(cycleHands, NULL, NULL, 800), |
83 | [MEMES] = ACTION_TAP_DANCE_FN_ADVANCED(cycleMemes, NULL, NULL, 800) | 83 | [MEMES] = ACTION_TAP_DANCE_FN_ADVANCED_TIME(cycleMemes, NULL, NULL, 800) |
84 | // Other declarations would go here, separated by commas, if you have them | 84 | // Other declarations would go here, separated by commas, if you have them |
85 | }; | 85 | }; |
86 | 86 | ||
diff --git a/quantum/process_keycode/process_tap_dance.c b/quantum/process_keycode/process_tap_dance.c index e58b6f2df..2c7f6e937 100644 --- a/quantum/process_keycode/process_tap_dance.c +++ b/quantum/process_keycode/process_tap_dance.c | |||
@@ -127,6 +127,8 @@ bool process_tap_dance(uint16_t keycode, keyrecord_t *record) { | |||
127 | return true; | 127 | return true; |
128 | } | 128 | } |
129 | 129 | ||
130 | |||
131 | |||
130 | void matrix_scan_tap_dance () { | 132 | void matrix_scan_tap_dance () { |
131 | if (highest_td == -1) | 133 | if (highest_td == -1) |
132 | return; | 134 | return; |
@@ -134,8 +136,8 @@ void matrix_scan_tap_dance () { | |||
134 | 136 | ||
135 | for (int i = 0; i <= highest_td; i++) { | 137 | for (int i = 0; i <= highest_td; i++) { |
136 | qk_tap_dance_action_t *action = &tap_dance_actions[i]; | 138 | qk_tap_dance_action_t *action = &tap_dance_actions[i]; |
137 | if(action->user_data != NULL ) { | 139 | if(action->custom_tapping_term > 0 ) { |
138 | tap_user_defined = (int)action->user_data; | 140 | tap_user_defined = action->custom_tapping_term; |
139 | } | 141 | } |
140 | else{ | 142 | else{ |
141 | tap_user_defined = TAPPING_TERM; | 143 | tap_user_defined = TAPPING_TERM; |
diff --git a/quantum/process_keycode/process_tap_dance.h b/quantum/process_keycode/process_tap_dance.h index 95d51f480..a020f7991 100644 --- a/quantum/process_keycode/process_tap_dance.h +++ b/quantum/process_keycode/process_tap_dance.h | |||
@@ -44,6 +44,7 @@ typedef struct | |||
44 | qk_tap_dance_user_fn_t on_reset; | 44 | qk_tap_dance_user_fn_t on_reset; |
45 | } fn; | 45 | } fn; |
46 | qk_tap_dance_state_t state; | 46 | qk_tap_dance_state_t state; |
47 | uint16_t custom_tapping_term; | ||
47 | void *user_data; | 48 | void *user_data; |
48 | } qk_tap_dance_action_t; | 49 | } qk_tap_dance_action_t; |
49 | 50 | ||
@@ -63,9 +64,16 @@ typedef struct | |||
63 | .user_data = NULL, \ | 64 | .user_data = NULL, \ |
64 | } | 65 | } |
65 | 66 | ||
66 | #define ACTION_TAP_DANCE_FN_ADVANCED(user_fn_on_each_tap, user_fn_on_dance_finished, user_fn_on_dance_reset, tap_specific_tapping_term) { \ | 67 | #define ACTION_TAP_DANCE_FN_ADVANCED(user_fn_on_each_tap, user_fn_on_dance_finished, user_fn_on_dance_reset) { \ |
67 | .fn = { user_fn_on_each_tap, user_fn_on_dance_finished, user_fn_on_dance_reset }, \ | 68 | .fn = { user_fn_on_each_tap, user_fn_on_dance_finished, user_fn_on_dance_reset }, \ |
68 | .user_data = (void *)(tap_specific_tapping_term), \ | 69 | .user_data = NULL, \ |
70 | .custom_tapping_term = -1, \ | ||
71 | } | ||
72 | |||
73 | #define ACTION_TAP_DANCE_FN_ADVANCED_TIME(user_fn_on_each_tap, user_fn_on_dance_finished, user_fn_on_dance_reset, tap_specific_tapping_term) { \ | ||
74 | .fn = { user_fn_on_each_tap, user_fn_on_dance_finished, user_fn_on_dance_reset }, \ | ||
75 | .user_data = NULL, \ | ||
76 | .custom_tapping_term = tap_specific_tapping_term, \ | ||
69 | } | 77 | } |
70 | 78 | ||
71 | extern qk_tap_dance_action_t tap_dance_actions[]; | 79 | extern qk_tap_dance_action_t tap_dance_actions[]; |