diff options
| -rw-r--r-- | keyboards/ergodox/keymaps/dvorak_programmer/Makefile | 2 | ||||
| -rw-r--r-- | keyboards/ergodox/keymaps/dvorak_programmer/README.md | 3 | ||||
| -rw-r--r-- | keyboards/ergodox/keymaps/dvorak_programmer/keymap.c | 49 |
3 files changed, 9 insertions, 45 deletions
diff --git a/keyboards/ergodox/keymaps/dvorak_programmer/Makefile b/keyboards/ergodox/keymaps/dvorak_programmer/Makefile index 3c65e25e1..91b1ae597 100644 --- a/keyboards/ergodox/keymaps/dvorak_programmer/Makefile +++ b/keyboards/ergodox/keymaps/dvorak_programmer/Makefile | |||
| @@ -4,5 +4,5 @@ SLEEP_LED_ENABLE=no | |||
| 4 | FORCE_NKRO ?= yes | 4 | FORCE_NKRO ?= yes |
| 5 | DEBUG_ENABLE = no | 5 | DEBUG_ENABLE = no |
| 6 | CONSOLE_ENABLE = no | 6 | CONSOLE_ENABLE = no |
| 7 | TAP_DANCE_ENABLE = yes | 7 | TAP_DANCE_ENABLE = no |
| 8 | MOUSEKEY_ENABLE = yes | 8 | MOUSEKEY_ENABLE = yes |
diff --git a/keyboards/ergodox/keymaps/dvorak_programmer/README.md b/keyboards/ergodox/keymaps/dvorak_programmer/README.md index 09f30c04f..42723ea17 100644 --- a/keyboards/ergodox/keymaps/dvorak_programmer/README.md +++ b/keyboards/ergodox/keymaps/dvorak_programmer/README.md | |||
| @@ -19,6 +19,9 @@ Layers | |||
| 19 | Updates | 19 | Updates |
| 20 | ------- | 20 | ------- |
| 21 | 21 | ||
| 22 | 2017/02/10: | ||
| 23 | * Made left shift an MO for SHELL_NAV, and symbol+right shift CAPSLOCK | ||
| 24 | |||
| 22 | 2017/01/28: | 25 | 2017/01/28: |
| 23 | * Made the capslock key a dual momentary layer activation for BRACKETS and SHELL_NAV. One keypress held down for BRACKETS, one keypress, released and then held down for SHELL_NAV | 26 | * Made the capslock key a dual momentary layer activation for BRACKETS and SHELL_NAV. One keypress held down for BRACKETS, one keypress, released and then held down for SHELL_NAV |
| 24 | 27 | ||
diff --git a/keyboards/ergodox/keymaps/dvorak_programmer/keymap.c b/keyboards/ergodox/keymaps/dvorak_programmer/keymap.c index 4594a7698..2fef048b5 100644 --- a/keyboards/ergodox/keymaps/dvorak_programmer/keymap.c +++ b/keyboards/ergodox/keymaps/dvorak_programmer/keymap.c | |||
| @@ -34,24 +34,6 @@ | |||
| 34 | #define SHELL_RECALL_LAST_ARG_REMOVE_FIRST_COMMAND 15 | 34 | #define SHELL_RECALL_LAST_ARG_REMOVE_FIRST_COMMAND 15 |
| 35 | #define SEMICOLON_NEWLINE 16 | 35 | #define SEMICOLON_NEWLINE 16 |
| 36 | #define END_NEWLINE 17 | 36 | #define END_NEWLINE 17 |
| 37 | #define DUAL_CAPSLOCK 18 | ||
| 38 | |||
| 39 | static uint16_t capslock_timer; | ||
| 40 | |||
| 41 | const uint16_t PROGMEM fn_actions[] = { | ||
| 42 | [1] = ACTION_LAYER_TAP_TOGGLE(KEY_NAV), // FN1 - keynav layer | ||
| 43 | [2] = ACTION_LAYER_TAP_TOGGLE(NUMBER), // FN2 - number layer | ||
| 44 | [3] = ACTION_MODS_ONESHOT(MOD_LSFT), // FN3 - shift modifier / oneshot | ||
| 45 | [4] = ACTION_MODS_ONESHOT(MOD_LCTL), // FN4 - ctrl modifier / oneshot | ||
| 46 | [5] = ACTION_MODS_ONESHOT(MOD_LALT), // FN5 - alt modifier / oneshot | ||
| 47 | }; | ||
| 48 | |||
| 49 | //Tap Dance Declarations | ||
| 50 | enum { | ||
| 51 | TD_SHIFT_CAPSLOCK = 0, | ||
| 52 | TD_BRK_LEFT = 1, | ||
| 53 | TD_BRK_RIGHT = 2 | ||
| 54 | }; | ||
| 55 | 37 | ||
| 56 | 38 | ||
| 57 | 39 | ||
| @@ -61,9 +43,9 @@ const uint16_t PROGMEM keymaps[][MATRIX_ROWS][MATRIX_COLS] = { | |||
| 61 | // left hand | 43 | // left hand |
| 62 | KC_ESC, KC_F1, KC_F2, KC_F3, KC_F4, KC_F5, KC_F6, | 44 | KC_ESC, KC_F1, KC_F2, KC_F3, KC_F4, KC_F5, KC_F6, |
| 63 | KC_TAB, KC_QUOT, KC_COMM, KC_DOT, KC_P, KC_Y, MO(KEY_SEL), | 45 | KC_TAB, KC_QUOT, KC_COMM, KC_DOT, KC_P, KC_Y, MO(KEY_SEL), |
| 64 | M(DUAL_CAPSLOCK), KC_A, KC_O, KC_E, KC_U, KC_I, | 46 | MO(BRACKETS), KC_A, KC_O, KC_E, KC_U, KC_I, |
| 65 | OSM(MOD_LSFT), KC_SCLN, KC_Q, KC_J, KC_K, KC_X, MO(KEY_NAV), | 47 | MO(SHELL_NAV), KC_SCLN, KC_Q, KC_J, KC_K, KC_X, MO(KEY_NAV), |
| 66 | OSL(SHORTCUTS),KC_FN4, KC_FN5,OSL(SYMBOL),MO(NUMBER), | 48 | OSL(SHORTCUTS),OSM(MOD_LCTL), OSM(MOD_LALT),OSL(SYMBOL),MO(NUMBER), |
| 67 | // thumb cluster | 49 | // thumb cluster |
| 68 | MO(MOUSE), RCTL(KC_S), | 50 | MO(MOUSE), RCTL(KC_S), |
| 69 | RCTL(KC_DEL), | 51 | RCTL(KC_DEL), |
| @@ -72,7 +54,7 @@ const uint16_t PROGMEM keymaps[][MATRIX_ROWS][MATRIX_COLS] = { | |||
| 72 | KC_F7, KC_F8, KC_F9, KC_F10, KC_F11, KC_F12, KC_BSLS, | 54 | KC_F7, KC_F8, KC_F9, KC_F10, KC_F11, KC_F12, KC_BSLS, |
| 73 | KC_PGUP, KC_F, KC_G, KC_C, KC_R, KC_L, KC_SLSH, | 55 | KC_PGUP, KC_F, KC_G, KC_C, KC_R, KC_L, KC_SLSH, |
| 74 | KC_D, KC_H, KC_T, KC_N, KC_S, KC_MINS, | 56 | KC_D, KC_H, KC_T, KC_N, KC_S, KC_MINS, |
| 75 | KC_PGDN, KC_B, KC_M, KC_W, KC_V, KC_Z, TD(TD_SHIFT_CAPSLOCK), | 57 | KC_PGDN, KC_B, KC_M, KC_W, KC_V, KC_Z, OSM(MOD_LSFT), |
| 76 | // lower keys - browser tab control | 58 | // lower keys - browser tab control |
| 77 | RSFT(RCTL(KC_TAB)), RCTL(KC_TAB), RCTL(KC_T), LALT(KC_LEFT), RCTL(KC_W), | 59 | RSFT(RCTL(KC_TAB)), RCTL(KC_TAB), RCTL(KC_T), LALT(KC_LEFT), RCTL(KC_W), |
| 78 | // thumb cluster | 60 | // thumb cluster |
| @@ -246,7 +228,7 @@ const uint16_t PROGMEM keymaps[][MATRIX_ROWS][MATRIX_COLS] = { | |||
| 246 | MEH(KC_F7), MEH(KC_F8), MEH(KC_F9), MEH(KC_F10), MEH(KC_F11), MEH(KC_F12), M(SWITCH_NDS), | 228 | MEH(KC_F7), MEH(KC_F8), MEH(KC_F9), MEH(KC_F10), MEH(KC_F11), MEH(KC_F12), M(SWITCH_NDS), |
| 247 | KC_TRNS, MEH(KC_A), MEH(KC_B), MEH(KC_C), MEH(KC_D), MEH(KC_E), MEH(KC_F), | 229 | KC_TRNS, MEH(KC_A), MEH(KC_B), MEH(KC_C), MEH(KC_D), MEH(KC_E), MEH(KC_F), |
| 248 | MEH(KC_G), MEH(KC_H), MEH(KC_I), MEH(KC_J), MEH(KC_K), MEH(KC_L), | 230 | MEH(KC_G), MEH(KC_H), MEH(KC_I), MEH(KC_J), MEH(KC_K), MEH(KC_L), |
| 249 | KC_TRNS, MEH(KC_M), MEH(KC_N), MEH(KC_O), MEH(KC_P), MEH(KC_Q), MEH(KC_R), | 231 | KC_TRNS, MEH(KC_M), MEH(KC_N), MEH(KC_O), MEH(KC_P), MEH(KC_Q), KC_CAPSLOCK, |
| 250 | MEH(KC_S), MEH(KC_T), MEH(KC_U), MEH(KC_V), MEH(KC_X), | 232 | MEH(KC_S), MEH(KC_T), MEH(KC_U), MEH(KC_V), MEH(KC_X), |
| 251 | MEH(KC_6), MEH(KC_7), | 233 | MEH(KC_6), MEH(KC_7), |
| 252 | MEH(KC_8), | 234 | MEH(KC_8), |
| @@ -372,20 +354,6 @@ const macro_t *action_get_macro(keyrecord_t *record, uint8_t id, uint8_t opt) | |||
| 372 | return MACRO( T(END), T(ENTER), END); | 354 | return MACRO( T(END), T(ENTER), END); |
| 373 | } | 355 | } |
| 374 | break; | 356 | break; |
| 375 | case DUAL_CAPSLOCK: | ||
| 376 | if (record->event.pressed) { | ||
| 377 | if(timer_elapsed(capslock_timer) < 300) { | ||
| 378 | // activate SHELL_NAV | ||
| 379 | layer_on(SHELL_NAV); | ||
| 380 | } else { | ||
| 381 | layer_on(BRACKETS); | ||
| 382 | } | ||
| 383 | } else { | ||
| 384 | layer_off(SHELL_NAV); | ||
| 385 | layer_off(BRACKETS); | ||
| 386 | capslock_timer = timer_read(); | ||
| 387 | } | ||
| 388 | break; | ||
| 389 | 357 | ||
| 390 | 358 | ||
| 391 | } | 359 | } |
| @@ -406,13 +374,6 @@ void led_set_user(uint8_t usb_led) { | |||
| 406 | } | 374 | } |
| 407 | } | 375 | } |
| 408 | 376 | ||
| 409 | qk_tap_dance_action_t tap_dance_actions[] = { | ||
| 410 | [TD_SHIFT_CAPSLOCK] = ACTION_TAP_DANCE_DOUBLE(KC_LSFT, KC_CAPSLOCK), | ||
| 411 | [TD_BRK_LEFT] = ACTION_TAP_DANCE_DOUBLE (KC_LPRN, KC_LCBR), | ||
| 412 | [TD_BRK_RIGHT] = ACTION_TAP_DANCE_DOUBLE (KC_RPRN, KC_RCBR) | ||
| 413 | |||
| 414 | }; | ||
| 415 | |||
| 416 | 377 | ||
| 417 | // Runs constantly in the background, in a loop. | 378 | // Runs constantly in the background, in a loop. |
| 418 | void matrix_scan_user(void) { | 379 | void matrix_scan_user(void) { |
