aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorErez Zukerman <bulk@ezuk.org>2016-10-31 21:40:58 -0400
committerGitHub <noreply@github.com>2016-10-31 21:40:58 -0400
commita6401076d51a6858940131b97858ac71ce668893 (patch)
tree142b248ab669fa9a17e856e189f2cf09fe6ca1ac
parentbd40844e4eea74c8cb1fba25aff0b21584b0ebf5 (diff)
parent055247f35da4fb6c2e8c944292210240cd2d6ec5 (diff)
downloadqmk_firmware-a6401076d51a6858940131b97858ac71ce668893.tar.gz
qmk_firmware-a6401076d51a6858940131b97858ac71ce668893.zip
Merge pull request #843 from lucwastiaux/master
Adding Ergodox Dvorak Programmer layout
-rw-r--r--.gitignore3
-rw-r--r--keyboards/ergodox/keymaps/dvorak_programmer/Makefile8
-rw-r--r--keyboards/ergodox/keymaps/dvorak_programmer/README.md15
-rw-r--r--keyboards/ergodox/keymaps/dvorak_programmer/keymap.c403
4 files changed, 428 insertions, 1 deletions
diff --git a/.gitignore b/.gitignore
index 1abaeb217..f66a961fd 100644
--- a/.gitignore
+++ b/.gitignore
@@ -30,4 +30,5 @@ CMakeLists.txt
30.browse.VC.db* 30.browse.VC.db*
31*.stackdump 31*.stackdump
32util/Win_Check_Output.txt 32util/Win_Check_Output.txt
33.vscode \ No newline at end of file 33.vscode
34.stfolder
diff --git a/keyboards/ergodox/keymaps/dvorak_programmer/Makefile b/keyboards/ergodox/keymaps/dvorak_programmer/Makefile
new file mode 100644
index 000000000..1fd6cb9ff
--- /dev/null
+++ b/keyboards/ergodox/keymaps/dvorak_programmer/Makefile
@@ -0,0 +1,8 @@
1BOOTMAGIC_ENABLE=no
2COMMAND_ENABLE=no
3SLEEP_LED_ENABLE=no
4FORCE_NKRO ?= yes
5DEBUG_ENABLE = no
6CONSOLE_ENABLE = no
7TAP_DANCE_ENABLE = yes
8MOUSEKEY_ENABLE = no
diff --git a/keyboards/ergodox/keymaps/dvorak_programmer/README.md b/keyboards/ergodox/keymaps/dvorak_programmer/README.md
new file mode 100644
index 000000000..a4580fe06
--- /dev/null
+++ b/keyboards/ergodox/keymaps/dvorak_programmer/README.md
@@ -0,0 +1,15 @@
1Dvorak Programmer Layout
2========================
3
4This is a dvorak-only layout. The overall philosophy is that the left hand contains a number of layer-switching shortcuts, and the right hand key codes vary based on the layer selected.
5
6Layers
7------
8
9* BASE: this is where you type.
10* SHELL_NAV: hold down the Tab key to access shell/terminal navigation shorcuts such as forward/backward word, history, Ctrl+C, screen tab movement.
11* KEY_NAV: arrow key movement with backward/forward word support, and copy/paste.
12* KEY_SEL: same as above, but every movement shift-selects.
13* NUMBER: keypad layer.
14* SYMBOL: all the symbols as well as brackets at the bottom.
15* SHORTCUTS: sends Hyper keys for Autohotkey to interpret. I use this to switch between specific apps.
diff --git a/keyboards/ergodox/keymaps/dvorak_programmer/keymap.c b/keyboards/ergodox/keymaps/dvorak_programmer/keymap.c
new file mode 100644
index 000000000..5100115a6
--- /dev/null
+++ b/keyboards/ergodox/keymaps/dvorak_programmer/keymap.c
@@ -0,0 +1,403 @@
1
2#include "ergodox.h"
3#include "led.h"
4#include "debug.h"
5#include "action_layer.h"
6#include "action_code.h"
7
8#define BASE 0 // default layer
9#define SHELL_NAV 1
10#define KEY_NAV 3 // key navigation layer
11#define KEY_SEL 4 // key selection layer
12#define NUMBER 5 // number layer
13#define SYMBOL 6
14#define BRACKETS 7
15#define SHORTCUTS 8
16
17// macros
18#define MC_COPY_LINE 0
19#define MC_CUT_LINE 1
20#define MC_PASTE_LINE 2
21#define MC_NEW_SEARCH_TAB 3
22#define SCREEN_TAB_LEFT 4
23#define SCREEN_TAB_RIGHT 5
24#define SCREEN_NEW_TAB 6
25#define SWITCH_NDS 7
26#define SCREEN_COPY_MODE 8
27#define SCREEN_PASTE 9
28#define OPEN_CLOSE_PAREN 10
29#define OPEN_CLOSE_BRACKET 11
30#define OPEN_CLOSE_CURLY 12
31#define OPEN_CLOSE_SINGLE_QUOTE 13
32#define OPEN_CLOSE_DOUBLE_QUOTE 14
33#define SHELL_RECALL_LAST_ARG_REMOVE_FIRST_COMMAND 15
34#define SEMICOLON_NEWLINE 16
35#define END_NEWLINE 17
36
37
38const uint16_t PROGMEM fn_actions[] = {
39 [1] = ACTION_LAYER_TAP_TOGGLE(KEY_NAV), // FN1 - keynav layer
40 [2] = ACTION_LAYER_TAP_TOGGLE(NUMBER), // FN2 - number layer
41 [3] = ACTION_MODS_ONESHOT(MOD_LSFT), // FN3 - shift modifier / oneshot
42 [4] = ACTION_MODS_ONESHOT(MOD_LCTL), // FN4 - ctrl modifier / oneshot
43 [5] = ACTION_MODS_ONESHOT(MOD_LALT), // FN5 - alt modifier / oneshot
44};
45
46//Tap Dance Declarations
47enum {
48 TD_SHIFT_CAPSLOCK = 0,
49 TD_BRK_LEFT = 1,
50 TD_BRK_RIGHT = 2
51};
52
53
54
55const uint16_t PROGMEM keymaps[][MATRIX_ROWS][MATRIX_COLS] = {
56// base layer
57[BASE] = KEYMAP( // layer 0 : default
58 // left hand
59 KC_ESC, KC_F1, KC_F2, KC_F3, KC_F4, KC_F5, KC_F6,
60 LT(BRACKETS,KC_TAB), KC_QUOT, KC_COMM, KC_DOT, KC_P, KC_Y, MO(KEY_SEL),
61 MO(SHELL_NAV), KC_A, KC_O, KC_E, KC_U, KC_I,
62 KC_FN3, KC_SCLN, KC_Q, KC_J, KC_K, KC_X, MO(KEY_NAV),
63 OSL(SHORTCUTS),KC_FN4, KC_FN5,OSL(SYMBOL),MO(NUMBER),
64 // thumb cluster
65 RCTL(KC_F), RCTL(KC_S),
66 RCTL(KC_DEL),
67 KC_BSPC,RCTL(KC_BSPC),KC_DEL,
68 // right hand
69 KC_F7, KC_F8, KC_F9, KC_F10, KC_F11, KC_F12, KC_BSLS,
70 KC_PGUP, KC_F, KC_G, KC_C, KC_R, KC_L, KC_SLSH,
71 KC_D, KC_H, KC_T, KC_N, KC_S, KC_MINS,
72 KC_PGDN, KC_B, KC_M, KC_W, KC_V, KC_Z, TD(TD_SHIFT_CAPSLOCK),
73 // lower keys - browser tab control
74 RSFT(RCTL(KC_TAB)), RCTL(KC_TAB), RCTL(KC_T), RCTL(KC_K), RCTL(KC_W),
75 // thumb cluster
76 M(SEMICOLON_NEWLINE), M(END_NEWLINE),
77 KC_UP,
78 KC_DOWN,KC_ENT, KC_SPC
79 ),
80
81
82// shell navigation layer
83[SHELL_NAV] = KEYMAP(
84 // left hand
85 KC_TRNS,KC_TRNS,KC_TRNS,KC_TRNS,KC_TRNS,KC_TRNS,KC_TRNS,
86 KC_TRNS,KC_TRNS,KC_TRNS,KC_TRNS,KC_TRNS,KC_TRNS,KC_TRNS,
87 KC_TRNS,KC_TRNS,KC_TRNS,KC_TRNS,KC_TRNS,KC_TRNS,
88 KC_TRNS,KC_TRNS,KC_TRNS,KC_TRNS,KC_TRNS,KC_TRNS,KC_TRNS,
89 // bottom row
90 KC_TRNS,KC_TRNS,KC_TRNS,KC_TRNS,KC_TRNS,
91 // thumb cluster
92 KC_TRNS,KC_TRNS,
93 LALT(KC_D),
94 KC_TRNS,RCTL(KC_W),KC_TRNS,
95 // right hand
96 KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS,
97 RCTL(KC_L), RCTL(KC_W), KC_HOME, KC_UP, KC_END, LALT(KC_D), RCTL(KC_R),
98 LALT(KC_B), KC_LEFT, KC_DOWN, KC_RIGHT, LALT(KC_F), LALT(KC_DOT),
99 RCTL(KC_C), RCTL(KC_U), M(SCREEN_COPY_MODE), M(SCREEN_PASTE), HYPR(KC_V), RCTL(KC_K), M(SHELL_RECALL_LAST_ARG_REMOVE_FIRST_COMMAND),
100 // bottom row
101 M(SCREEN_TAB_LEFT), M(SCREEN_TAB_RIGHT), M(SCREEN_NEW_TAB), KC_TRNS, KC_TRNS,
102 // thumb cluster
103 KC_TRNS, KC_TRNS,
104 KC_TRNS,
105 KC_TRNS, KC_TRNS, KC_TRNS
106),
107
108
109// key navigation layer
110[KEY_NAV] = KEYMAP(
111 // left hand
112 KC_TRNS,KC_TRNS,KC_TRNS,KC_TRNS,KC_TRNS,KC_TRNS,KC_TRNS,
113 KC_TRNS,KC_TRNS,KC_TRNS,KC_TRNS,KC_TRNS,KC_TRNS,KC_TRNS,
114 KC_TRNS,KC_TRNS,KC_TRNS,KC_TRNS,KC_TRNS,KC_TRNS,
115 KC_TRNS,KC_TRNS,KC_TRNS,KC_TRNS,KC_TRNS,KC_TRNS,KC_TRNS,
116 // bottom row
117 KC_TRNS,KC_TRNS,KC_TRNS,KC_TRNS,KC_TRNS,
118 // thumb cluster
119 KC_TRNS,KC_TRNS,
120 KC_TRNS,
121 KC_TRNS,KC_TRNS,KC_TRNS,
122 // right hand
123 KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS,
124 KC_TRNS, KC_PGDN, KC_HOME, KC_UP, KC_END, KC_PGUP, M(MC_COPY_LINE),
125 RCTL(KC_LEFT), KC_LEFT, KC_DOWN, KC_RIGHT, RCTL(KC_RIGHT), M(MC_CUT_LINE),
126 KC_TRNS, KC_TRNS, RCTL(KC_C), RCTL(KC_X), RCTL(KC_V), KC_TRNS, M(MC_PASTE_LINE),
127 // bottom row
128 KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS,
129 // thumb cluster
130 KC_TRNS, KC_TRNS,
131 KC_TRNS,
132 KC_TRNS, KC_TRNS, KC_TRNS
133),
134
135// key selection layer
136[KEY_SEL] = KEYMAP(
137 // left hand
138 KC_TRNS,KC_TRNS,KC_TRNS,KC_TRNS,KC_TRNS,KC_TRNS,KC_TRNS,
139 KC_TRNS,KC_TRNS,KC_TRNS,KC_TRNS,KC_TRNS,KC_TRNS,KC_TRNS,
140 KC_TRNS,KC_TRNS,KC_TRNS,KC_TRNS,KC_TRNS,KC_TRNS,
141 KC_TRNS,KC_TRNS,KC_TRNS,KC_TRNS,KC_TRNS,KC_TRNS,KC_TRNS,
142 // bottom row
143 KC_TRNS,KC_TRNS,KC_TRNS,KC_TRNS,KC_TRNS,
144 // thumb cluster
145 KC_TRNS,KC_TRNS,
146 KC_TRNS,
147 KC_TRNS,KC_TRNS,KC_TRNS,
148 // right hand
149 KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS,
150 RSFT(KC_PGUP), RSFT(KC_PGDN), RSFT(KC_HOME), RSFT(KC_UP), RSFT(KC_END), RSFT(KC_PGUP), M(MC_COPY_LINE),
151 RSFT(RCTL(KC_LEFT)), RSFT(KC_LEFT), RSFT(KC_DOWN), RSFT(KC_RIGHT), RSFT(RCTL(KC_RIGHT)), M(MC_CUT_LINE),
152 RSFT(KC_PGDN), KC_TRNS, RCTL(KC_C), RCTL(KC_X), RCTL(KC_V), KC_TRNS, M(MC_PASTE_LINE),
153 // bottom row
154 KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS,
155 // thumb cluster
156 KC_TRNS, KC_TRNS,
157 KC_TRNS,
158 KC_TRNS, KC_TRNS, KC_TRNS
159),
160
161// number layer
162[NUMBER] = KEYMAP(
163 // left hand
164 KC_TRNS,KC_TRNS,KC_TRNS,KC_TRNS,KC_TRNS,KC_TRNS,KC_TRNS,
165 KC_TRNS,KC_TRNS,KC_TRNS,KC_TRNS,KC_TRNS,KC_TRNS,KC_TRNS,
166 KC_TRNS,KC_TRNS,KC_TRNS,KC_TRNS,KC_TRNS,KC_TRNS,
167 KC_TRNS,KC_TRNS,KC_TRNS,KC_TRNS,KC_TRNS,KC_TRNS,KC_TRNS,
168 // bottom row
169 KC_TRNS,KC_TRNS,KC_TRNS,KC_TRNS,KC_TRNS,
170 // thumb cluster
171 KC_TRNS,KC_TRNS,
172 KC_TRNS,
173 KC_TRNS,KC_TRNS,KC_TRNS,
174 // right hand
175 KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS,
176 KC_TRNS, KC_PLUS, KC_7, KC_8, KC_9, KC_ASTR, KC_TRNS,
177 KC_MINS, KC_4, KC_5, KC_6, KC_SLSH, KC_TRNS,
178 KC_TRNS, KC_EQUAL, KC_1, KC_2, KC_3, KC_COLN, KC_TRNS,
179 // bottom row
180 KC_0, KC_DOT, KC_COMMA, KC_TRNS, KC_TRNS,
181 // thumb cluster
182 KC_TRNS, KC_TRNS,
183 KC_TRNS,
184 KC_TRNS, KC_TRNS, KC_TRNS
185),
186
187
188[SYMBOL] = KEYMAP(
189 // left hand
190 KC_NO,KC_F1, KC_F2, KC_F3, KC_F4, KC_F5, KC_F6,
191 KC_TRNS,KC_TRNS, M(OPEN_CLOSE_PAREN), KC_LPRN, KC_RPRN, KC_TRNS, KC_TRNS,
192 KC_TRNS,KC_TRNS, M(OPEN_CLOSE_BRACKET), KC_LBRC, KC_RBRC, M(OPEN_CLOSE_DOUBLE_QUOTE),
193 KC_TRNS,M(SEMICOLON_NEWLINE),M(OPEN_CLOSE_CURLY), KC_LCBR, KC_RCBR, M(OPEN_CLOSE_SINGLE_QUOTE),KC_TRNS,
194 KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS,
195 KC_TRNS,KC_TRNS,
196 KC_TRNS,
197 KC_TRNS,KC_TRNS,KC_TRNS,
198 // right hand
199 KC_LPRN, KC_RPRN, KC_LBRC, KC_RBRC, KC_LCBR, KC_RCBR, KC_TRNS,
200 KC_TRNS, KC_PLUS, KC_AMPR, KC_ASTR, KC_GRAVE,KC_TILD, KC_TRNS,
201 KC_MINS, KC_DLR, KC_PERC, KC_CIRC, KC_PIPE, KC_TRNS,
202 KC_TRNS, KC_EQUAL,KC_EXLM, KC_AT, KC_HASH, KC_TRNS, KC_TRNS,
203 KC_LBRC, KC_RBRC, TD(TD_BRK_LEFT), TD(TD_BRK_RIGHT), KC_TRNS,
204 KC_TRNS, KC_TRNS,
205 KC_TRNS,
206 KC_TRNS, KC_TRNS, KC_TRNS
207),
208
209[BRACKETS] = KEYMAP(
210 // left hand
211 KC_TRNS,KC_TRNS,KC_TRNS,KC_TRNS,KC_TRNS,KC_TRNS,KC_TRNS,
212 KC_TRNS,KC_TRNS,KC_TRNS,KC_TRNS,KC_TRNS,KC_TRNS,KC_TRNS,
213 KC_TRNS,KC_TRNS,KC_TRNS,KC_TRNS,KC_TRNS,KC_TRNS,
214 KC_TRNS,KC_TRNS,KC_TRNS,KC_TRNS,KC_TRNS,KC_TRNS,KC_TRNS,
215 KC_TRNS,KC_TRNS,KC_TRNS,KC_TRNS,KC_TRNS,
216 KC_TRNS,KC_TRNS,
217 KC_TRNS,
218 KC_TRNS,KC_TRNS,KC_TRNS,
219 // right hand
220 KC_TRNS,KC_TRNS,KC_TRNS,KC_TRNS,KC_TRNS,KC_TRNS,KC_TRNS,
221 KC_TRNS, KC_TRNS, M(OPEN_CLOSE_BRACKET),M(OPEN_CLOSE_PAREN),M(OPEN_CLOSE_CURLY),KC_TRNS,KC_TRNS,
222 KC_TRNS, KC_LBRC, KC_RBRC, KC_LPRN, KC_RPRN, KC_TRNS,
223 KC_TRNS, KC_TRNS, KC_LCBR, KC_RCBR, KC_TRNS, KC_TRNS, KC_TRNS,
224 KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS,
225 KC_TRNS, KC_TRNS,
226 KC_TRNS,
227 KC_TRNS, KC_TRNS, KC_TRNS
228),
229
230[SHORTCUTS] = KEYMAP(
231 // left hand
232 KC_NO, HYPR(KC_F1), HYPR(KC_F2), HYPR(KC_F3), HYPR(KC_F4), HYPR(KC_F5), HYPR(KC_F6),
233 KC_TRNS,KC_TRNS,KC_TRNS,KC_TRNS,KC_TRNS,KC_TRNS,KC_TRNS,
234 KC_TRNS,KC_TRNS,KC_TRNS,KC_TRNS,KC_TRNS,KC_TRNS,
235 KC_TRNS,KC_TRNS,KC_TRNS,KC_TRNS,KC_TRNS,KC_TRNS,KC_TRNS,
236 KC_TRNS,KC_TRNS,KC_TRNS,KC_TRNS,KC_TRNS,
237 KC_TRNS,KC_TRNS,
238 KC_TRNS,
239 KC_TRNS,KC_TRNS,KC_TRNS,
240 // right hand
241 HYPR(KC_F7), HYPR(KC_F8), HYPR(KC_F9), HYPR(KC_F10), HYPR(KC_F11), HYPR(KC_F12), M(SWITCH_NDS),
242 KC_TRNS, HYPR(KC_A), HYPR(KC_B), HYPR(KC_C), HYPR(KC_D), HYPR(KC_E), HYPR(KC_F),
243 HYPR(KC_G), HYPR(KC_H), HYPR(KC_I), HYPR(KC_J), HYPR(KC_K), HYPR(KC_L),
244 KC_TRNS, HYPR(KC_M), HYPR(KC_N), HYPR(KC_O), HYPR(KC_P), HYPR(KC_Q), HYPR(KC_R),
245 LALT(KC_LEFT),LALT(KC_RIGHT),KC_F5, LCTL(LGUI(KC_LEFT)), LCTL(LGUI(KC_RIGHT)),
246 KC_TRNS, KC_TRNS,
247 KC_TRNS,
248 KC_TRNS, KC_TRNS, KC_TRNS
249),
250
251
252};
253
254
255
256const macro_t *action_get_macro(keyrecord_t *record, uint8_t id, uint8_t opt)
257{
258 // MACRODOWN only works in this function
259 switch(id) {
260 case MC_COPY_LINE:
261 if (record->event.pressed) {
262 return MACRO( T(HOME), D(LSFT), T(END), U(LSFT), D(LCTL), T(C), U(LCTL), END);
263 }
264 break;
265 case MC_CUT_LINE:
266 if (record->event.pressed) {
267 return MACRO( T(HOME), D(LSFT), T(END), U(LSFT), D(LCTL), T(X), U(LCTL), END);
268 }
269 break;
270 case MC_PASTE_LINE:
271 if (record->event.pressed) {
272 return MACRO( T(END), T(ENTER), D(LCTL), T(V), U(LCTL), END);
273 }
274 break;
275 case MC_NEW_SEARCH_TAB:
276 if (record->event.pressed) {
277 return MACRO( D(LCTL), T(T), T(K), U(LCTL), END);
278 }
279 break;
280 case SCREEN_TAB_LEFT:
281 if (record->event.pressed) {
282 return MACRO( D(LCTL), T(A), U(LCTL), T(P), END);
283 }
284 break;
285 case SCREEN_TAB_RIGHT:
286 if (record->event.pressed) {
287 return MACRO( D(LCTL), T(A), U(LCTL), T(N), END);
288 }
289 break;
290 case SCREEN_NEW_TAB:
291 if (record->event.pressed) {
292 return MACRO( D(LCTL), T(A), U(LCTL), T(C), END);
293 }
294 break;
295 case SCREEN_COPY_MODE:
296 if (record->event.pressed) {
297 return MACRO( D(LCTL), T(A), U(LCTL), T(ESC), END);
298 }
299 break;
300 case SCREEN_PASTE:
301 if (record->event.pressed) {
302 return MACRO( D(LCTL), T(A), U(LCTL), T(RBRC), END);
303 }
304 break;
305 case SWITCH_NDS:
306 if (record->event.pressed) {
307 return MACRO( D(LSFT), T(F11), U(LSFT), W(500), D(LALT), T(TAB), U(LALT), END);
308 }
309 break;
310 case OPEN_CLOSE_PAREN:
311 if (record->event.pressed) {
312 return MACRO( D(LSFT), T(LPRN), T(RPRN), U(LSFT), T(LEFT), END);
313 }
314 break;
315 case OPEN_CLOSE_BRACKET:
316 if (record->event.pressed) {
317 return MACRO( T(LBRC), T(RBRC), T(LEFT), END);
318 }
319 break;
320 case OPEN_CLOSE_CURLY:
321 if (record->event.pressed) {
322 return MACRO( D(LSFT), T(LCBR), T(RCBR), U(LSFT), T(LEFT), END);
323 }
324 break;
325 case OPEN_CLOSE_SINGLE_QUOTE:
326 if (record->event.pressed) {
327 return MACRO( T(QUOT), T(QUOT), T(LEFT), END);
328 }
329 break;
330 case OPEN_CLOSE_DOUBLE_QUOTE:
331 if (record->event.pressed) {
332 return MACRO( D(LSFT), T(QUOT), T(QUOT), U(LSFT), T(LEFT), END);
333 }
334 break;
335 case SHELL_RECALL_LAST_ARG_REMOVE_FIRST_COMMAND:
336 if (record->event.pressed) {
337 return MACRO( T(UP), T(HOME), D(LALT), T(D), U(LALT), END);
338 }
339 break;
340 case SEMICOLON_NEWLINE:
341 if (record->event.pressed) {
342 return MACRO( T(END), T(SCLN), T(ENTER), END);
343 }
344 break;
345 case END_NEWLINE:
346 if (record->event.pressed) {
347 return MACRO( T(END), T(ENTER), END);
348 }
349 break;
350
351 }
352 return MACRO_NONE;
353};
354
355// Runs just one time when the keyboard initializes.
356void matrix_init_user(void) {
357
358 return;
359};
360
361void led_set_user(uint8_t usb_led) {
362 if (usb_led & (1<<USB_LED_CAPS_LOCK)) {
363 ergodox_right_led_1_on();
364 } else {
365 ergodox_right_led_1_off();
366 }
367}
368
369qk_tap_dance_action_t tap_dance_actions[] = {
370 [TD_SHIFT_CAPSLOCK] = ACTION_TAP_DANCE_DOUBLE(KC_LSFT, KC_CAPSLOCK),
371 [TD_BRK_LEFT] = ACTION_TAP_DANCE_DOUBLE (KC_LPRN, KC_LCBR),
372 [TD_BRK_RIGHT] = ACTION_TAP_DANCE_DOUBLE (KC_RPRN, KC_RCBR)
373
374};
375
376
377// Runs constantly in the background, in a loop.
378void matrix_scan_user(void) {
379
380 uint8_t layer = biton32(layer_state);
381
382 ergodox_board_led_off();
383 ergodox_right_led_2_off();
384 ergodox_right_led_3_off();
385 switch (layer) {
386 case NUMBER:
387 case SYMBOL:
388 ergodox_right_led_2_on();
389 break;
390 case KEY_NAV:
391 case KEY_SEL:
392 ergodox_right_led_3_on();
393 break;
394 case SHORTCUTS:
395 ergodox_right_led_2_on();
396 ergodox_right_led_3_on();
397 break;
398 default:
399 // none
400 break;
401 }
402 return;
403};