aboutsummaryrefslogtreecommitdiff
path: root/users/gordon
diff options
context:
space:
mode:
authorDaniel Gordon <dgordon8765@gmail.com>2017-12-18 16:01:59 -0600
committerJack Humbert <jack.humb@gmail.com>2018-01-12 13:14:19 -0500
commit383a3c1e08d0f4e00b1c6f07e8468c5eac544eb4 (patch)
treeda3b144f92948ef92c0cd3dc4df43f755103b4b2 /users/gordon
parente2352d4fbf6b11cc70b578abadb322b2401017ef (diff)
downloadqmk_firmware-383a3c1e08d0f4e00b1c6f07e8468c5eac544eb4.tar.gz
qmk_firmware-383a3c1e08d0f4e00b1c6f07e8468c5eac544eb4.zip
Add Daniel Gordon's Ergodox Infinity and Chimera
* gordon.c defines many aliases for KC codes. * gordon.c defines many advanced tap dance functions. * This is a squashed commit of about 6 months of work on chimera and ergodox infinity changes. * Ignore the change-id below. Change-Id: I83927139e8a80fe08992ae91ec7d62571498f7f7
Diffstat (limited to 'users/gordon')
-rw-r--r--users/gordon/gordon.c275
-rw-r--r--users/gordon/gordon.h157
-rw-r--r--users/gordon/readme.md14
-rw-r--r--users/gordon/rules.mk1
4 files changed, 447 insertions, 0 deletions
diff --git a/users/gordon/gordon.c b/users/gordon/gordon.c
new file mode 100644
index 000000000..056012a21
--- /dev/null
+++ b/users/gordon/gordon.c
@@ -0,0 +1,275 @@
1#include "gordon.h"
2#include "quantum.h"
3#include "action.h"
4#include "process_keycode/process_tap_dance.h"
5
6#if (__has_include("secret.h"))
7#include "secret.h"
8#else
9const char secret[][64] = {
10 "test1",
11 "test2",
12 "test3",
13 "test4",
14 "test5"
15};
16#endif
17
18
19
20
21void register_hyper (void) { //Helper function to invoke Hyper
22 register_code (KC_LSFT);
23 register_code (KC_LCTL);
24 register_code (KC_LALT);
25 register_code (KC_LGUI);
26}
27void unregister_hyper (void) { //Helper function to invoke Hyper
28 unregister_code (KC_LSFT);
29 unregister_code (KC_LCTL);
30 unregister_code (KC_LALT);
31 unregister_code (KC_LGUI);
32}
33
34void register_ctrl_a (void) {
35 register_code(KC_LCTL);
36 register_code(KC_A);
37}
38
39void unregister_ctrl_a (void) {
40 unregister_code(KC_LCTL);
41 unregister_code(KC_A);
42}
43
44void register_alt_f7 (void) {
45 register_code (KC_LALT);
46 register_code (KC_F7);
47}
48
49void unregister_alt_f7 (void) {
50 unregister_code (KC_LALT);
51 unregister_code (KC_F7);
52}
53
54void register_shift_f6 (void) {
55 register_code (KC_LSFT);
56 register_code (KC_F6);
57}
58
59void unregister_shift_f6 (void) {
60 unregister_code (KC_LSFT);
61 unregister_code (KC_F6);
62}
63
64void register_ctrl_shift (void) {
65 register_code (KC_LSFT);
66 register_code (KC_LCTRL);
67}
68
69void unregister_ctrl_shift (void) {
70 unregister_code (KC_LSFT);
71 unregister_code (KC_LCTRL);
72}
73
74void register_alt_shift (void) {
75 register_code (KC_LSFT);
76 register_code (KC_LALT);
77}
78
79void unregister_alt_shift (void) {
80 unregister_code (KC_LSFT);
81 unregister_code (KC_LALT);
82}
83
84// To activate SINGLE_HOLD, you will need to hold for 200ms first.
85// This tap dance favors keys that are used frequently in typing like 'f'
86int cur_dance (qk_tap_dance_state_t *state) {
87 if (state->count == 1) {
88 //If count = 1, and it has been interrupted - it doesn't matter if it is pressed or not: Send SINGLE_TAP
89 if (state->interrupted) {
90 // if (!state->pressed) return SINGLE_TAP;
91 //need "permissive hold" here.
92 // else return SINsGLE_HOLD;
93 //If the interrupting key is released before the tap-dance key, then it is a single HOLD
94 //However, if the tap-dance key is released first, then it is a single TAP
95 //But how to get access to the state of the interrupting key????
96 return SINGLE_TAP;
97 }
98 else {
99 if (!state->pressed) return SINGLE_TAP;
100 else return SINGLE_HOLD;
101 }
102 }
103 //If count = 2, and it has been interrupted - assume that user is trying to type the letter associated
104 //with single tap.
105 else if (state->count == 2) {
106 if (state->interrupted) return DOUBLE_SINGLE_TAP;
107 else if (state->pressed) return DOUBLE_HOLD;
108 else return DOUBLE_TAP;
109 }
110 else if ((state->count == 3) && ((state->interrupted) || (!state->pressed))) return TRIPLE_TAP;
111 else if (state->count == 3) return TRIPLE_HOLD;
112 else return 8; //magic number. At some point this method will expand to work for more presses
113}
114
115//This works well if you want this key to work as a "fast modifier". It favors being held over being tapped.
116int hold_cur_dance (qk_tap_dance_state_t *state) {
117 if (state->count == 1) {
118 if (state->interrupted) {
119 if (!state->pressed) return SINGLE_TAP;
120 else return SINGLE_HOLD;
121 }
122 else {
123 if (!state->pressed) return SINGLE_TAP;
124 else return SINGLE_HOLD;
125 }
126 }
127 //If count = 2, and it has been interrupted - assume that user is trying to type the letter associated
128 //with single tap.
129 else if (state->count == 2) {
130 if (state->pressed) return DOUBLE_HOLD;
131 else return DOUBLE_TAP;
132 }
133 else if (state->count == 3) {
134 if (!state->pressed) return TRIPLE_TAP;
135 else return TRIPLE_HOLD;
136 }
137 else return 8; //magic number. At some point this method will expand to work for more presses
138}
139
140
141static xtap htap_state = {
142 .is_press_action = true,
143 .state = 0
144};
145
146void h_finished (qk_tap_dance_state_t *state, void *user_data) {
147 htap_state.state = cur_dance(state);
148 switch (htap_state.state) {
149 case SINGLE_TAP: register_code(KC_H); break;
150 case SINGLE_HOLD: layer_on(8); register_code(KC_LALT); break;
151 case DOUBLE_TAP: layer_invert(8); register_code(KC_LALT); break;
152 // case DOUBLE_HOLD: register_code(KC_LALT);
153 case DOUBLE_SINGLE_TAP: register_code(KC_H);unregister_code(KC_H);register_code(KC_H);
154 }
155}
156
157void h_reset (qk_tap_dance_state_t *state, void *user_data) {
158 switch (htap_state.state) {
159 case SINGLE_TAP: unregister_code(KC_H); break;
160 case SINGLE_HOLD: layer_off(8); unregister_code(KC_LALT); break;
161 case DOUBLE_TAP: unregister_code(KC_LALT);break;
162 // case DOUBLE_HOLD: unregister_code(KC_LALT);
163 case DOUBLE_SINGLE_TAP: unregister_code(KC_H);
164 }
165 htap_state.state = 0;
166}
167
168
169/**************** QUAD FUNCTION FOR TAB ****************/
170// TAB, ALT + SHIFT, TAB TAB, CTRL + SHIFT
171static xtap tab_state = {
172 .is_press_action = true,
173 .state = 0
174};
175
176void tab_finished (qk_tap_dance_state_t *state, void *user_data) {
177 tab_state.state = cur_dance(state);
178 switch (tab_state.state) {
179 case SINGLE_TAP: register_code(KC_TAB); break; //send tab on single press
180 case SINGLE_HOLD: register_ctrl_shift(); break;
181 case DOUBLE_HOLD: register_alt_shift(); break; //alt shift on single hold
182 case DOUBLE_TAP: register_code(KC_TAB); unregister_code(KC_TAB); register_code(KC_TAB); break; //tab tab
183 case TRIPLE_TAP: register_code(KC_LSHIFT) ;register_code(KC_ESC); break;
184 case TRIPLE_HOLD: register_code(KC_LSHIFT); register_code(KC_LGUI); break;
185 }
186}
187
188void tab_reset (qk_tap_dance_state_t *state, void *user_data) {
189 switch (tab_state.state) {
190 case SINGLE_TAP: unregister_code(KC_TAB); break; //unregister tab
191 case DOUBLE_HOLD: unregister_alt_shift(); break; //let go of alt shift
192 case DOUBLE_TAP: unregister_code(KC_TAB); break;
193 case SINGLE_HOLD: unregister_ctrl_shift(); break;
194 case TRIPLE_TAP: unregister_code(KC_LSHIFT); unregister_code(KC_ESC); break;
195 case TRIPLE_HOLD: unregister_code(KC_LSHIFT); unregister_code(KC_LGUI); break;
196 }
197 tab_state.state = 0;
198}
199/**************** QUAD FUNCTION FOR TAB ****************/
200
201//*************** SUPER COMMA *******************//
202// Assumption: we don't care about trying to hit ,, quickly
203//*************** SUPER COMMA *******************//
204static xtap comma_state = {
205 .is_press_action = true,
206 .state = 0
207};
208
209void comma_finished (qk_tap_dance_state_t *state, void *user_data) {
210 comma_state.state = hold_cur_dance(state); //Use the dance that favors being held
211 switch (comma_state.state) {
212 case SINGLE_TAP: register_code(KC_COMMA); break;
213 case SINGLE_HOLD: layer_on(1); break; //turn on symbols layer
214 case DOUBLE_TAP: layer_invert(4); break; //toggle numbers layer
215 case DOUBLE_HOLD: layer_on(2); break;
216 case TRIPLE_TAP: register_code(KC_CALCULATOR); break;
217 case TRIPLE_HOLD: layer_on(3);
218 }
219}
220
221void comma_reset (qk_tap_dance_state_t *state, void *user_data) {
222 switch (comma_state.state) {
223 case SINGLE_TAP: unregister_code(KC_COMMA); break; //unregister comma
224 case SINGLE_HOLD: layer_off(1); break;
225 case DOUBLE_TAP: ;break;
226 case DOUBLE_HOLD: layer_off(2); break;
227 case TRIPLE_TAP: unregister_code(KC_CALCULATOR); break;
228 case TRIPLE_HOLD: layer_off(3);
229 }
230 comma_state.state = 0;
231}
232//*************** SUPER COMMA *******************//
233//*************** SUPER COMMA *******************//
234
235
236//*************** F3 TAP DANCE *******************//
237//Good example for accessing multiple layers from the same key.
238static xtap S1_state = {
239 .is_press_action = true,
240 .state = 0
241};
242
243void bt_finished (qk_tap_dance_state_t *state, void *user_data) {
244 S1_state.state = cur_dance(state);
245 switch (S1_state.state) {
246 case SINGLE_TAP: register_code(KC_F3); break;
247 case SINGLE_HOLD: layer_on(4); break;
248 case DOUBLE_TAP: layer_invert(4); break;
249 case DOUBLE_HOLD: layer_on(5); break;
250 case DOUBLE_SINGLE_TAP: layer_invert(4); break;
251 }
252}
253
254void bt_reset (qk_tap_dance_state_t *state, void *user_data) {
255 switch (S1_state.state) {
256 case SINGLE_TAP: unregister_code(KC_F3); break;
257 case SINGLE_HOLD: layer_off(4); break;
258 case DOUBLE_TAP: break; //already inverted. Don't do anything.
259 case DOUBLE_HOLD: layer_off(5); break;
260 case DOUBLE_SINGLE_TAP: break;
261 }
262 S1_state.state = 0;
263}
264
265bool process_record_user(uint16_t keycode, keyrecord_t *record) {
266 switch (keycode) {
267 case KC_SECRET_1 ... KC_SECRET_5:
268 if (!record->event.pressed) {
269 send_string(secret[keycode - KC_SECRET_1]);
270 }
271 return false;
272 break;
273 }
274 return true;
275} \ No newline at end of file
diff --git a/users/gordon/gordon.h b/users/gordon/gordon.h
new file mode 100644
index 000000000..548c63049
--- /dev/null
+++ b/users/gordon/gordon.h
@@ -0,0 +1,157 @@
1#ifndef GORDON
2#define GORDON
3
4#include "quantum.h"
5#include "process_keycode/process_tap_dance.h"
6
7
8// Fillers to make layering more clear
9#define _______ KC_TRNS
10#define ________ KC_TRNS
11#define _________ KC_TRNS
12#define XXXXXXX KC_NO
13
14// KC codes that are too long
15#define DOLLAR KC_DOLLAR
16#define LSQUIGLY KC_LBRACKET
17#define RSQUIGLY KC_RBRACKET
18#define NUMLOCK KC_NUMLOCK
19#define CAPLOCK KC_CAPSLOCK
20#define BK_SLASH KC_BSLASH
21#define ASTERSK KC_KP_ASTERISK
22
23// Navigation
24#define SNAPLEFT LGUI(KC_LEFT)
25#define SNAPRGHT LGUI(KC_RIGHT)
26#define SNAPUP LGUI(KC_UP)
27#define SNAPDOWN LGUI(KC_DOWN)
28#define PREVTAB LCTL(LSFT(KC_TAB))
29#define NEXTTAB LCTL(KC_TAB)
30#define WORKRIGHT LCTL(LGUI(KC_RIGHT))
31#define WORKLEFT LCTL(LGUI(KC_LEFT))
32
33// KC/modifier hold
34#define CTRL_F CTL_T(KC_F)
35#define CTRL_J CTL_T(KC_J)
36#define CTRL_Z CTL_T(KC_Z)
37#define ALT_V ALT_T(KC_V)
38#define ALT_M ALT_T(KC_M)
39#define WIN_G GUI_T(KC_G)
40#define WIN_H GUI_T(KC_H)
41#define HYPER_X ALL_T(KC_X)
42#define HYPE_DOT ALL_T(KC_DOT)
43#define MEH_S MEH_T(KC_S)
44#define MEH_L MEH_T(KC_L)
45#define ALT_HOME ALT_T(KC_HOME)
46
47
48// KC/Layer Hold
49#define NAV_E LT(_NAV,KC_E)
50#define NUMPAD_D LT(_NUMPAD,KC_D)
51#define MOUSE_C LT(_MOUSE,KC_C)
52#define SYMB_BSP LT(_SYMBOLS,KC_BSPACE)
53#define COL_MOUS LT(_MOUSE,KC_SCOLON)
54#define SPAC_SYM LT(_SYMBOLS,KC_SPACE)
55
56// Double Modifier ONLY hold
57#define ALT_SHFT LSFT(KC_LALT)
58#define CTR_SHFT LSFT(KC_LCTL)
59
60// KC/Double modifier Hold
61#define CTR_SH_W MT(MOD_LCTL|MOD_LSFT,KC_W)
62#define CTR_AL_R MT(MOD_LCTL|MOD_LALT,KC_R)
63
64//MISC
65#define PRINTSCR KC_PSCREEN
66#define CALTDEL LCTL(LALT(KC_DEL))
67#define TSKMGR LCTL(LSFT(KC_ESC))
68
69
70typedef struct {
71 bool is_press_action;
72 int state;
73} xtap;
74
75enum {
76 SINGLE_TAP = 1,
77 SINGLE_HOLD = 2,
78 DOUBLE_TAP = 3,
79 DOUBLE_HOLD = 4,
80 DOUBLE_SINGLE_TAP = 5, //send two single taps
81 TRIPLE_TAP = 6,
82 TRIPLE_HOLD = 7
83};
84
85enum gordon_layers
86{
87 _QWERTY = 0,
88 _SYMBOLS,
89 _MOUSE,
90 _NUMPAD,
91 _NAV,
92 _MACROS,
93 _FUNCTION,
94 _TEXTNAV
95};
96
97
98
99void register_hyper (void);
100void unregister_hyper (void);
101
102void register_ctrl_a (void);
103void unregister_ctrl_a (void);
104
105void register_alt_f7 (void);
106void unregister_alt_f7 (void);
107
108void register_shift_f6 (void);
109void unregister_shift_f6 (void);
110
111void register_ctrl_shift (void);
112void unregister_ctrl_shift (void);
113
114void register_alt_shift (void);
115void unregister_alt_shift (void);
116
117int cur_dance (qk_tap_dance_state_t *state);
118int hold_cur_dance (qk_tap_dance_state_t *state);
119
120void x_finished (qk_tap_dance_state_t *state, void *user_data);
121void x_reset (qk_tap_dance_state_t *state, void *user_data);
122
123void h_finished (qk_tap_dance_state_t *state, void *user_data);
124void h_reset (qk_tap_dance_state_t *state, void *user_data);
125
126void tab_finished (qk_tap_dance_state_t *state, void *user_data);
127void tab_reset (qk_tap_dance_state_t *state, void *user_data);
128
129void comma_finished (qk_tap_dance_state_t *state, void *user_data);
130void comma_reset (qk_tap_dance_state_t *state, void *user_data);
131
132void bt_finished (qk_tap_dance_state_t *state, void *user_data);
133void bt_reset (qk_tap_dance_state_t *state, void *user_data);
134
135// Macro Declarations
136enum {
137 INFOQM,
138 TIL_SLASH,
139 DEREF,
140 EQRIGHT,
141 TILD3,
142 TICK3,
143 ALTTAB_START,
144 ALTTAB_END
145};
146
147enum secret_strings {
148 KC_SECRET_1 = SAFE_RANGE,
149 KC_SECRET_2,
150 KC_SECRET_3,
151 KC_SECRET_4,
152 KC_SECRET_5,
153};
154
155const macro_t *action_get_macro(keyrecord_t *record, uint8_t id, uint8_t opt);
156
157#endif \ No newline at end of file
diff --git a/users/gordon/readme.md b/users/gordon/readme.md
new file mode 100644
index 000000000..fdea33b67
--- /dev/null
+++ b/users/gordon/readme.md
@@ -0,0 +1,14 @@
1Copyright <year> <name> <email> @<github_username>
2
3This program is free software: you can redistribute it and/or modify
4it under the terms of the GNU General Public License as published by
5the Free Software Foundation, either version 2 of the License, or
6(at your option) any later version.
7
8This program is distributed in the hope that it will be useful,
9but WITHOUT ANY WARRANTY; without even the implied warranty of
10MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
11GNU General Public License for more details.
12
13You should have received a copy of the GNU General Public License
14along with this program. If not, see <http://www.gnu.org/licenses/>. \ No newline at end of file
diff --git a/users/gordon/rules.mk b/users/gordon/rules.mk
new file mode 100644
index 000000000..5dd62c200
--- /dev/null
+++ b/users/gordon/rules.mk
@@ -0,0 +1 @@
SRC += gordon.c \ No newline at end of file