diff options
| -rw-r--r-- | .travis.yml | 7 | ||||
| -rw-r--r-- | keyboards/ergodox/keymaps/dvorak_programmer/Makefile | 2 | ||||
| -rw-r--r-- | keyboards/ergodox/keymaps/dvorak_programmer/README.md | 7 | ||||
| -rw-r--r-- | keyboards/ergodox/keymaps/dvorak_programmer/keymap.c | 70 | ||||
| -rw-r--r-- | keyboards/handwired/promethium/keymaps/priyadi/config.h | 2 | ||||
| -rw-r--r-- | keyboards/handwired/promethium/keymaps/priyadi/keymap.c | 78 | ||||
| -rw-r--r-- | keyboards/handwired/promethium/promethium.h | 1 | ||||
| -rw-r--r-- | keyboards/planck/keymaps/priyadi/keymap.c | 512 | ||||
| -rw-r--r-- | keyboards/planck/rev3/Makefile | 3 | ||||
| -rw-r--r-- | keyboards/tv44/keymaps/smt/Makefile | 21 | ||||
| -rw-r--r-- | keyboards/tv44/keymaps/smt/config.h | 36 | ||||
| -rw-r--r-- | keyboards/tv44/keymaps/smt/keyboard-layout-minivan.png | bin | 0 -> 66567 bytes | |||
| -rw-r--r-- | keyboards/tv44/keymaps/smt/keymap.c | 232 | ||||
| -rw-r--r-- | keyboards/tv44/keymaps/smt/readme.md | 126 | ||||
| -rw-r--r-- | readme.md | 2 |
15 files changed, 844 insertions, 255 deletions
diff --git a/.travis.yml b/.travis.yml index 18ecde7e3..6c26e4112 100644 --- a/.travis.yml +++ b/.travis.yml | |||
| @@ -30,3 +30,10 @@ addons: | |||
| 30 | - diffutils | 30 | - diffutils |
| 31 | after_success: | 31 | after_success: |
| 32 | bash util/travis_compiled_push.sh | 32 | bash util/travis_compiled_push.sh |
| 33 | notifications: | ||
| 34 | webhooks: | ||
| 35 | urls: | ||
| 36 | - https://webhooks.gitter.im/e/cca31de3d44b9adb617b | ||
| 37 | on_success: change # options: [always|never|change] default: always | ||
| 38 | on_failure: always # options: [always|never|change] default: always | ||
| 39 | on_start: never # options: [always|never|change] default: always \ No newline at end of file | ||
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 54da74f7f..36722469f 100644 --- a/keyboards/ergodox/keymaps/dvorak_programmer/README.md +++ b/keyboards/ergodox/keymaps/dvorak_programmer/README.md | |||
| @@ -7,7 +7,6 @@ Layers | |||
| 7 | ------ | 7 | ------ |
| 8 | 8 | ||
| 9 | * BASE: this is where you type. | 9 | * BASE: this is where you type. |
| 10 | * SHELL_LAYER: this is a permanent layer which I use when I don't need the F keys and gives me bash shortcuts on the top row. | ||
| 11 | * SHELL_NAV: hold down the Tab key to access shell/terminal navigation shorcuts such as forward/backward word, history, Ctrl+C, screen tab movement. | 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. |
| 12 | * KEY_NAV: arrow key movement with backward/forward word support, and copy/paste. | 11 | * KEY_NAV: arrow key movement with backward/forward word support, and copy/paste. |
| 13 | * KEY_SEL: same as above, but every movement shift-selects. | 12 | * KEY_SEL: same as above, but every movement shift-selects. |
| @@ -20,6 +19,12 @@ Layers | |||
| 20 | Updates | 19 | Updates |
| 21 | ------- | 20 | ------- |
| 22 | 21 | ||
| 22 | 2017/02/10: | ||
| 23 | * Made left shift an MO for SHELL_NAV, and symbol+right shift CAPSLOCK. Made all modifiers OSM. | ||
| 24 | |||
| 25 | 2017/01/28: | ||
| 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 | ||
| 27 | |||
| 23 | 2017/01/22: | 28 | 2017/01/22: |
| 24 | * Made brackets toggle an OSL on the left capslock | 29 | * Made brackets toggle an OSL on the left capslock |
| 25 | * Added SHELL_LAYER | 30 | * Added SHELL_LAYER |
diff --git a/keyboards/ergodox/keymaps/dvorak_programmer/keymap.c b/keyboards/ergodox/keymaps/dvorak_programmer/keymap.c index 7ed0c7f12..ae4fd444d 100644 --- a/keyboards/ergodox/keymaps/dvorak_programmer/keymap.c +++ b/keyboards/ergodox/keymaps/dvorak_programmer/keymap.c | |||
| @@ -6,7 +6,6 @@ | |||
| 6 | #include "action_code.h" | 6 | #include "action_code.h" |
| 7 | 7 | ||
| 8 | #define BASE 0 // default layer | 8 | #define BASE 0 // default layer |
| 9 | #define SHELL_LAYER 1 | ||
| 10 | #define SHELL_NAV 2 | 9 | #define SHELL_NAV 2 |
| 11 | #define KEY_NAV 3 // key navigation layer | 10 | #define KEY_NAV 3 // key navigation layer |
| 12 | #define KEY_SEL 4 // key selection layer | 11 | #define KEY_SEL 4 // key selection layer |
| @@ -37,41 +36,25 @@ | |||
| 37 | #define END_NEWLINE 17 | 36 | #define END_NEWLINE 17 |
| 38 | 37 | ||
| 39 | 38 | ||
| 40 | const uint16_t PROGMEM fn_actions[] = { | ||
| 41 | [1] = ACTION_LAYER_TAP_TOGGLE(KEY_NAV), // FN1 - keynav layer | ||
| 42 | [2] = ACTION_LAYER_TAP_TOGGLE(NUMBER), // FN2 - number layer | ||
| 43 | [3] = ACTION_MODS_ONESHOT(MOD_LSFT), // FN3 - shift modifier / oneshot | ||
| 44 | [4] = ACTION_MODS_ONESHOT(MOD_LCTL), // FN4 - ctrl modifier / oneshot | ||
| 45 | [5] = ACTION_MODS_ONESHOT(MOD_LALT), // FN5 - alt modifier / oneshot | ||
| 46 | }; | ||
| 47 | |||
| 48 | //Tap Dance Declarations | ||
| 49 | enum { | ||
| 50 | TD_SHIFT_CAPSLOCK = 0, | ||
| 51 | TD_BRK_LEFT = 1, | ||
| 52 | TD_BRK_RIGHT = 2 | ||
| 53 | }; | ||
| 54 | |||
| 55 | |||
| 56 | 39 | ||
| 57 | const uint16_t PROGMEM keymaps[][MATRIX_ROWS][MATRIX_COLS] = { | 40 | const uint16_t PROGMEM keymaps[][MATRIX_ROWS][MATRIX_COLS] = { |
| 58 | // base layer | 41 | // base layer |
| 59 | [BASE] = KEYMAP( // layer 0 : default | 42 | [BASE] = KEYMAP( // layer 0 : default |
| 60 | // left hand | 43 | // left hand |
| 61 | 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, |
| 62 | LT(SHELL_NAV,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), |
| 63 | OSL(BRACKETS), KC_A, KC_O, KC_E, KC_U, KC_I, | 46 | MO(BRACKETS), KC_A, KC_O, KC_E, KC_U, KC_I, |
| 64 | 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), |
| 65 | OSL(SHORTCUTS),KC_FN4, KC_FN5,OSL(SYMBOL),MO(NUMBER), | 48 | OSL(SHORTCUTS),OSM(MOD_LCTL), OSM(MOD_LALT),OSL(SYMBOL),MO(NUMBER), |
| 66 | // thumb cluster | 49 | // thumb cluster |
| 67 | MO(MOUSE), RCTL(KC_S), | 50 | OSM(MOD_LSFT), RCTL(KC_S), |
| 68 | RCTL(KC_DEL), | 51 | RCTL(KC_DEL), |
| 69 | KC_BSPC,RCTL(KC_BSPC),KC_DEL, | 52 | KC_BSPC,RCTL(KC_BSPC),KC_DEL, |
| 70 | // right hand | 53 | // right hand |
| 71 | 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, |
| 72 | 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, |
| 73 | 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, |
| 74 | 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), |
| 75 | // lower keys - browser tab control | 58 | // lower keys - browser tab control |
| 76 | 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), |
| 77 | // thumb cluster | 60 | // thumb cluster |
| @@ -82,31 +65,6 @@ const uint16_t PROGMEM keymaps[][MATRIX_ROWS][MATRIX_COLS] = { | |||
| 82 | 65 | ||
| 83 | 66 | ||
| 84 | 67 | ||
| 85 | // permanent shell layer - meant to be used while in a terminal. only the top keys are overriden | ||
| 86 | [SHELL_LAYER] = KEYMAP( | ||
| 87 | // left hand | ||
| 88 | KC_TRNS,KC_TRNS,KC_TRNS,KC_TRNS,LALT(KC_DOT),RCTL(KC_R),RCTL(KC_C), | ||
| 89 | KC_TRNS,KC_TRNS,KC_TRNS,KC_TRNS,KC_TRNS,KC_TRNS,KC_TRNS, | ||
| 90 | KC_TRNS,KC_TRNS,KC_TRNS,KC_TRNS,KC_TRNS,KC_TRNS, | ||
| 91 | KC_TRNS,KC_TRNS,KC_TRNS,KC_TRNS,KC_TRNS,KC_TRNS,KC_TRNS, | ||
| 92 | // bottom row | ||
| 93 | KC_TRNS,KC_TRNS,KC_TRNS,KC_TRNS,KC_TRNS, | ||
| 94 | // thumb cluster | ||
| 95 | KC_TRNS,KC_TRNS, | ||
| 96 | KC_TRNS, | ||
| 97 | KC_TRNS,KC_TRNS,KC_TRNS, | ||
| 98 | // right hand | ||
| 99 | RCTL(KC_W), LALT(KC_B),LALT(KC_F), KC_LEFT, KC_RIGHT, LALT(KC_D), KC_TRNS, | ||
| 100 | KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, | ||
| 101 | KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, | ||
| 102 | KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, | ||
| 103 | // bottom row | ||
| 104 | KC_TRNS,KC_TRNS,KC_TRNS,KC_TRNS,KC_TRNS, | ||
| 105 | // thumb cluster | ||
| 106 | KC_TRNS, KC_TRNS, | ||
| 107 | KC_TRNS, | ||
| 108 | KC_TRNS, KC_TRNS, KC_TRNS | ||
| 109 | ), | ||
| 110 | 68 | ||
| 111 | // shell navigation layer | 69 | // shell navigation layer |
| 112 | [SHELL_NAV] = KEYMAP( | 70 | [SHELL_NAV] = KEYMAP( |
| @@ -270,11 +228,11 @@ const uint16_t PROGMEM keymaps[][MATRIX_ROWS][MATRIX_COLS] = { | |||
| 270 | 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), |
| 271 | 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), |
| 272 | 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), |
| 273 | 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, |
| 274 | 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), |
| 275 | MEH(KC_6), MEH(KC_7), | 233 | MEH(KC_6), MEH(KC_7), |
| 276 | MEH(KC_8), | 234 | MEH(KC_8), |
| 277 | MEH(KC_9), TO(BASE), TO(SHELL_LAYER) | 235 | MEH(KC_9), MEH(KC_Y), MEH(KC_Z) |
| 278 | ), | 236 | ), |
| 279 | 237 | ||
| 280 | 238 | ||
| @@ -395,7 +353,8 @@ const macro_t *action_get_macro(keyrecord_t *record, uint8_t id, uint8_t opt) | |||
| 395 | if (record->event.pressed) { | 353 | if (record->event.pressed) { |
| 396 | return MACRO( T(END), T(ENTER), END); | 354 | return MACRO( T(END), T(ENTER), END); |
| 397 | } | 355 | } |
| 398 | break; | 356 | break; |
| 357 | |||
| 399 | 358 | ||
| 400 | } | 359 | } |
| 401 | return MACRO_NONE; | 360 | return MACRO_NONE; |
| @@ -415,13 +374,6 @@ void led_set_user(uint8_t usb_led) { | |||
| 415 | } | 374 | } |
| 416 | } | 375 | } |
| 417 | 376 | ||
| 418 | qk_tap_dance_action_t tap_dance_actions[] = { | ||
| 419 | [TD_SHIFT_CAPSLOCK] = ACTION_TAP_DANCE_DOUBLE(KC_LSFT, KC_CAPSLOCK), | ||
| 420 | [TD_BRK_LEFT] = ACTION_TAP_DANCE_DOUBLE (KC_LPRN, KC_LCBR), | ||
| 421 | [TD_BRK_RIGHT] = ACTION_TAP_DANCE_DOUBLE (KC_RPRN, KC_RCBR) | ||
| 422 | |||
| 423 | }; | ||
| 424 | |||
| 425 | 377 | ||
| 426 | // Runs constantly in the background, in a loop. | 378 | // Runs constantly in the background, in a loop. |
| 427 | void matrix_scan_user(void) { | 379 | void matrix_scan_user(void) { |
diff --git a/keyboards/handwired/promethium/keymaps/priyadi/config.h b/keyboards/handwired/promethium/keymaps/priyadi/config.h index 53059ca7d..6c9d2195e 100644 --- a/keyboards/handwired/promethium/keymaps/priyadi/config.h +++ b/keyboards/handwired/promethium/keymaps/priyadi/config.h | |||
| @@ -14,6 +14,8 @@ | |||
| 14 | #define RGB_DI_PIN B5 | 14 | #define RGB_DI_PIN B5 |
| 15 | #define RGBSPS_NUM 57 | 15 | #define RGBSPS_NUM 57 |
| 16 | 16 | ||
| 17 | #define UNICODE_TYPE_DELAY 0 | ||
| 18 | |||
| 17 | #define LAYOUT_DVORAK | 19 | #define LAYOUT_DVORAK |
| 18 | #define LAYOUT_COLEMAK | 20 | #define LAYOUT_COLEMAK |
| 19 | #define LAYOUT_NORMAN | 21 | #define LAYOUT_NORMAN |
diff --git a/keyboards/handwired/promethium/keymaps/priyadi/keymap.c b/keyboards/handwired/promethium/keymaps/priyadi/keymap.c index 1ad34612e..a24a79aa1 100644 --- a/keyboards/handwired/promethium/keymaps/priyadi/keymap.c +++ b/keyboards/handwired/promethium/keymaps/priyadi/keymap.c | |||
| @@ -41,6 +41,7 @@ enum glow_modes { | |||
| 41 | }; | 41 | }; |
| 42 | uint8_t glow_mode = GLOW_MIN; | 42 | uint8_t glow_mode = GLOW_MIN; |
| 43 | 43 | ||
| 44 | void turn_off_capslock(void); | ||
| 44 | extern keymap_config_t keymap_config; | 45 | extern keymap_config_t keymap_config; |
| 45 | 46 | ||
| 46 | enum layers { | 47 | enum layers { |
| @@ -49,6 +50,7 @@ enum layers { | |||
| 49 | _COLEMAK, | 50 | _COLEMAK, |
| 50 | _WORKMAN, | 51 | _WORKMAN, |
| 51 | _NORMAN, | 52 | _NORMAN, |
| 53 | _DEFAULT_LAYER_MAX = _NORMAN, | ||
| 52 | 54 | ||
| 53 | _PUNC, | 55 | _PUNC, |
| 54 | _NUM, | 56 | _NUM, |
| @@ -444,7 +446,7 @@ void led_set_layer_indicator(void) { | |||
| 444 | 446 | ||
| 445 | oldlayer = layer; | 447 | oldlayer = layer; |
| 446 | 448 | ||
| 447 | if (layer <= _NORMAN) { | 449 | if (layer <= _DEFAULT_LAYER_MAX) { |
| 448 | rgbsps_send(); | 450 | rgbsps_send(); |
| 449 | return; | 451 | return; |
| 450 | } | 452 | } |
| @@ -461,7 +463,7 @@ void led_set_layer_indicator(void) { | |||
| 461 | break; | 463 | break; |
| 462 | default: | 464 | default: |
| 463 | rgbsps_set(LED_IND_FUNC, 3, 3, 3); | 465 | rgbsps_set(LED_IND_FUNC, 3, 3, 3); |
| 464 | rgbsps_set(LED_IND_NUM, 3, 3, 3); | 466 | // rgbsps_set(LED_IND_NUM, 3, 3, 3); |
| 465 | rgbsps_set(LED_IND_EMOJI, 3, 3, 3); | 467 | rgbsps_set(LED_IND_EMOJI, 3, 3, 3); |
| 466 | } | 468 | } |
| 467 | 469 | ||
| @@ -753,6 +755,32 @@ void persistant_default_layer_set(uint16_t default_layer) { | |||
| 753 | default_layer_set(default_layer); | 755 | default_layer_set(default_layer); |
| 754 | } | 756 | } |
| 755 | 757 | ||
| 758 | #ifdef DOUBLESPACE_LAYER_ENABLE | ||
| 759 | void process_doublespace(bool pressed, bool *isactive, bool *otheractive, bool *isemitted) { | ||
| 760 | if (pressed) { | ||
| 761 | *isactive = true; | ||
| 762 | if (*otheractive) { | ||
| 763 | layer_on(_SPACE); | ||
| 764 | space_layer_entered = true; | ||
| 765 | } | ||
| 766 | } else { | ||
| 767 | *isactive = false; | ||
| 768 | if (space_layer_entered) { | ||
| 769 | layer_off(_SPACE); | ||
| 770 | if (!*otheractive) { | ||
| 771 | space_layer_entered = false; | ||
| 772 | } | ||
| 773 | } else { | ||
| 774 | if (!*isemitted) { | ||
| 775 | register_code(KC_SPC); | ||
| 776 | unregister_code(KC_SPC); | ||
| 777 | } | ||
| 778 | *isemitted = false; | ||
| 779 | } | ||
| 780 | } | ||
| 781 | } | ||
| 782 | #endif | ||
| 783 | |||
| 756 | bool process_record_user(uint16_t keycode, keyrecord_t *record) { | 784 | bool process_record_user(uint16_t keycode, keyrecord_t *record) { |
| 757 | bool lshift = keyboard_report->mods & MOD_BIT(KC_LSFT); | 785 | bool lshift = keyboard_report->mods & MOD_BIT(KC_LSFT); |
| 758 | bool rshift = keyboard_report->mods & MOD_BIT(KC_RSFT); | 786 | bool rshift = keyboard_report->mods & MOD_BIT(KC_RSFT); |
| @@ -786,51 +814,11 @@ bool process_record_user(uint16_t keycode, keyrecord_t *record) { | |||
| 786 | #ifdef DOUBLESPACE_LAYER_ENABLE | 814 | #ifdef DOUBLESPACE_LAYER_ENABLE |
| 787 | // double-space enter space layer | 815 | // double-space enter space layer |
| 788 | case LSPACE: | 816 | case LSPACE: |
| 789 | if (record->event.pressed) { | 817 | process_doublespace(record->event.pressed, &lspace_active, &rspace_active, &lspace_emitted); |
| 790 | lspace_active = true; | ||
| 791 | if (rspace_active) { | ||
| 792 | layer_on(_SPACE); | ||
| 793 | space_layer_entered = true; | ||
| 794 | } | ||
| 795 | } else { | ||
| 796 | lspace_active = false; | ||
| 797 | if (space_layer_entered) { | ||
| 798 | layer_off(_SPACE); | ||
| 799 | if (!rspace_active) { | ||
| 800 | space_layer_entered = false; | ||
| 801 | } | ||
| 802 | } else { | ||
| 803 | if (!lspace_emitted) { | ||
| 804 | register_code(KC_SPC); | ||
| 805 | unregister_code(KC_SPC); | ||
| 806 | } | ||
| 807 | lspace_emitted = false; | ||
| 808 | } | ||
| 809 | } | ||
| 810 | return false; | 818 | return false; |
| 811 | break; | 819 | break; |
| 812 | case RSPACE: | 820 | case RSPACE: |
| 813 | if (record->event.pressed) { | 821 | process_doublespace(record->event.pressed, &rspace_active, &lspace_active, &rspace_emitted); |
| 814 | rspace_active = true; | ||
| 815 | if (lspace_active) { | ||
| 816 | layer_on(_SPACE); | ||
| 817 | space_layer_entered = true; | ||
| 818 | } | ||
| 819 | } else { | ||
| 820 | rspace_active = false; | ||
| 821 | if (space_layer_entered) { | ||
| 822 | layer_off(_SPACE); | ||
| 823 | if (!lspace_active) { | ||
| 824 | space_layer_entered = false; | ||
| 825 | } | ||
| 826 | } else { | ||
| 827 | if (!rspace_emitted) { | ||
| 828 | register_code(KC_SPC); | ||
| 829 | unregister_code(KC_SPC); | ||
| 830 | } | ||
| 831 | rspace_emitted = false; | ||
| 832 | } | ||
| 833 | } | ||
| 834 | return false; | 822 | return false; |
| 835 | break; | 823 | break; |
| 836 | #endif | 824 | #endif |
| @@ -1072,7 +1060,7 @@ void battery_poll(uint8_t level) { | |||
| 1072 | void led_set_user(uint8_t usb_led) { | 1060 | void led_set_user(uint8_t usb_led) { |
| 1073 | bool new_capslock = usb_led & (1<<USB_LED_CAPS_LOCK); | 1061 | bool new_capslock = usb_led & (1<<USB_LED_CAPS_LOCK); |
| 1074 | if (new_capslock ^ capslock) { // capslock state is different | 1062 | if (new_capslock ^ capslock) { // capslock state is different |
| 1075 | if (capslock = new_capslock) { | 1063 | if ((capslock = new_capslock)) { |
| 1076 | rgbsps_set(LED_IND_NUM, 15, 0, 0); | 1064 | rgbsps_set(LED_IND_NUM, 15, 0, 0); |
| 1077 | } else { | 1065 | } else { |
| 1078 | rgbsps_set(LED_IND_NUM, 0, 0, 0); | 1066 | rgbsps_set(LED_IND_NUM, 0, 0, 0); |
diff --git a/keyboards/handwired/promethium/promethium.h b/keyboards/handwired/promethium/promethium.h index da37e5c56..d6fea76ce 100644 --- a/keyboards/handwired/promethium/promethium.h +++ b/keyboards/handwired/promethium/promethium.h | |||
| @@ -4,7 +4,6 @@ | |||
| 4 | #include "quantum.h" | 4 | #include "quantum.h" |
| 5 | 5 | ||
| 6 | #define PS2_INIT_DELAY 2000 | 6 | #define PS2_INIT_DELAY 2000 |
| 7 | #define UNICODE_TYPE_DELAY 0 | ||
| 8 | #define BATTERY_PIN 9 | 7 | #define BATTERY_PIN 9 |
| 9 | #define BATTERY_POLL 30000 | 8 | #define BATTERY_POLL 30000 |
| 10 | #define MAX_VOLTAGE 4.2 | 9 | #define MAX_VOLTAGE 4.2 |
diff --git a/keyboards/planck/keymaps/priyadi/keymap.c b/keyboards/planck/keymaps/priyadi/keymap.c index 13668fd10..2c215702b 100644 --- a/keyboards/planck/keymaps/priyadi/keymap.c +++ b/keyboards/planck/keymaps/priyadi/keymap.c | |||
| @@ -10,29 +10,76 @@ | |||
| 10 | #include "eeconfig.h" | 10 | #include "eeconfig.h" |
| 11 | #include "process_unicode.h" | 11 | #include "process_unicode.h" |
| 12 | #include "quantum.h" | 12 | #include "quantum.h" |
| 13 | |||
| 14 | // #define TOLELOT_ENABLE | 13 | // #define TOLELOT_ENABLE |
| 14 | #define DOUBLESPACE_LAYER_ENABLE | ||
| 15 | |||
| 16 | // so i can copy & paste stuff from my other planck-like keyboards | ||
| 17 | #define KEYMAP( \ | ||
| 18 | k11, k12, k13, k14, k15, k16, k17, k18, k19, k1a, k1b, k1c, \ | ||
| 19 | k21, k22, k23, k24, k25, k26, k27, k28, k29, k2a, k2b, k2c, \ | ||
| 20 | k31, k32, k33, k34, k35, k36, k37, k38, k39, k3a, k3b, k3c, \ | ||
| 21 | k41, k42, k43, k44, k45, k46, k47, k48, k49, k4a, k4b, k4c \ | ||
| 22 | ) \ | ||
| 23 | { \ | ||
| 24 | {k11, k12, k13, k14, k15, k16, k17, k18, k19, k1a, k1b, k1c}, \ | ||
| 25 | {k21, k22, k23, k24, k25, k26, k27, k28, k29, k2a, k2b, k2c}, \ | ||
| 26 | {k31, k32, k33, k34, k35, k36, k37, k38, k39, k3a, k3b, k3c}, \ | ||
| 27 | {k41, k42, k43, k44, k45, k46, k47, k48, k49, k4a, k4b, k4c} \ | ||
| 28 | } | ||
| 29 | |||
| 30 | // Fillers to make layering clearer | ||
| 31 | #define _______ KC_TRNS | ||
| 32 | #define XXXXXXX KC_NO | ||
| 33 | #define G(x) LGUI(x) | ||
| 34 | #define KC_WWWB KC_WWW_BACK | ||
| 35 | #define KC_WWWF KC_WWW_FORWARD | ||
| 36 | |||
| 37 | // hybrid right-alt & scroll lock (mapped to Compose in OS) | ||
| 38 | #undef KC_RALT | ||
| 39 | #define KC_RALT MT(MOD_RALT, KC_SLCK) | ||
| 40 | |||
| 41 | bool capslock = false; | ||
| 42 | #ifdef DOUBLESPACE_LAYER_ENABLE | ||
| 43 | bool lspace_active = false; | ||
| 44 | bool rspace_active = false; | ||
| 45 | bool lspace_emitted = false; | ||
| 46 | bool rspace_emitted = false; | ||
| 47 | bool space_layer_entered = false; | ||
| 48 | #endif | ||
| 15 | 49 | ||
| 50 | void turn_off_capslock(void); | ||
| 16 | extern keymap_config_t keymap_config; | 51 | extern keymap_config_t keymap_config; |
| 17 | 52 | ||
| 18 | enum layers { | 53 | enum layers { |
| 19 | _QWERTY, | 54 | _QWERTY, |
| 55 | _DVORAK, | ||
| 20 | _COLEMAK, | 56 | _COLEMAK, |
| 21 | _WORKMAN, | 57 | _WORKMAN, |
| 58 | _NORMAN, | ||
| 59 | _DEFAULT_LAYER_MAX = _NORMAN, | ||
| 60 | |||
| 22 | _PUNC, | 61 | _PUNC, |
| 23 | _NUM, | 62 | _NUM, |
| 24 | _FUNC, | 63 | _FUNC, |
| 25 | _EMOJI, | 64 | |
| 26 | _GREEKU, | 65 | _GREEKU, |
| 27 | _GREEKL, | 66 | _GREEKL, |
| 67 | |||
| 68 | _EMOJI, | ||
| 28 | _GUI, | 69 | _GUI, |
| 70 | _SYS, | ||
| 29 | }; | 71 | }; |
| 30 | 72 | ||
| 73 | // double-space layer | ||
| 74 | #define _SPACE _GUI | ||
| 75 | |||
| 31 | enum planck_keycodes { | 76 | enum planck_keycodes { |
| 32 | // layouts | 77 | // layouts |
| 33 | QWERTY = SAFE_RANGE, | 78 | QWERTY = SAFE_RANGE, |
| 79 | DVORAK, | ||
| 34 | COLEMAK, | 80 | COLEMAK, |
| 35 | WORKMAN, | 81 | WORKMAN, |
| 82 | NORMAN, | ||
| 36 | 83 | ||
| 37 | // layer switchers | 84 | // layer switchers |
| 38 | PUNC, | 85 | PUNC, |
| @@ -46,12 +93,16 @@ enum planck_keycodes { | |||
| 46 | LINUX, | 93 | LINUX, |
| 47 | WIN, | 94 | WIN, |
| 48 | OSX, | 95 | OSX, |
| 49 | }; | ||
| 50 | 96 | ||
| 51 | // Fillers to make layering clearer | 97 | // others |
| 98 | LSPACE, | ||
| 99 | RSPACE, | ||
| 100 | GLOW, | ||
| 101 | AUDIO, | ||
| 52 | 102 | ||
| 53 | #define _______ KC_TRNS | 103 | // stubs |
| 54 | #define XXXXXXX KC_NO | 104 | OUT_BLE |
| 105 | }; | ||
| 55 | 106 | ||
| 56 | // unicode map | 107 | // unicode map |
| 57 | 108 | ||
| @@ -259,14 +310,6 @@ const uint32_t PROGMEM unicode_map[] = { | |||
| 259 | [FSIGM] = 0x03C2, | 310 | [FSIGM] = 0x03C2, |
| 260 | }; | 311 | }; |
| 261 | 312 | ||
| 262 | |||
| 263 | // hybrid shift - = | ||
| 264 | // #undef KC_LSFT | ||
| 265 | // #define KC_LSFT MT(MOD_LSFT, KC_MINS) | ||
| 266 | // #undef KC_RSFT | ||
| 267 | // #define KC_RSFT MT(MOD_LSFT, KC_EQL) | ||
| 268 | |||
| 269 | |||
| 270 | // hybrid right-gui & scroll lock (mapped to Compose in OS) | 313 | // hybrid right-gui & scroll lock (mapped to Compose in OS) |
| 271 | #undef KC_RALT | 314 | #undef KC_RALT |
| 272 | #define KC_RALT MT(MOD_RALT, KC_SLCK) | 315 | #define KC_RALT MT(MOD_RALT, KC_SLCK) |
| @@ -279,127 +322,138 @@ const uint16_t PROGMEM keymaps[][MATRIX_ROWS][MATRIX_COLS] = { | |||
| 279 | * ,-----------------------------------------------------------------------------------. | 322 | * ,-----------------------------------------------------------------------------------. |
| 280 | * | Tab | Q | W | E | R | T | Y | U | I | O | P | Bksp | | 323 | * | Tab | Q | W | E | R | T | Y | U | I | O | P | Bksp | |
| 281 | * |------+------+------+------+------+-------------+------+------+------+------+------| | 324 | * |------+------+------+------+------+-------------+------+------+------+------+------| |
| 282 | * | Esc | A | S | D | F | G | H | J | K | L | ; |Enter | | 325 | * | Esc | A | S | D | F | G | H | J | K | L | ' |Enter | |
| 283 | * |------+------+------+------+------+------|------+------+------+------+------+------| | 326 | * |------+------+------+------+------+------|------+------+------+------+------+------| |
| 284 | * | Shift| Z | X | C | V | B | N | M | , | . | / |Shift | | 327 | * | Shift| Z | X | C | V | B | N | M | , | . | / |Shift | |
| 285 | * |------+------+------+------+------+------+------+------+------+------+------+------| | 328 | * |------+------+------+------+------+------+------+------+------+------+------+------| |
| 286 | * | Ctrl | GUI | Alt | Punc | Num | Space | Func |Emoji |Greek |AltGr | Ctrl | | 329 | * | Ctrl | Alt | GUI | Punc | Num | Space | Func |Greek | GUI |AltGr | Ctrl | |
| 287 | * `-----------------------------------------------------------------------------------' | 330 | * `-----------------------------------------------------------------------------------' |
| 288 | */ | 331 | */ |
| 289 | [_QWERTY] = { | 332 | [_QWERTY] = KEYMAP( |
| 290 | {KC_TAB, KC_Q, KC_W, KC_E, KC_R, KC_T, KC_Y, KC_U, KC_I, KC_O, KC_P, KC_BSPC}, | 333 | KC_TAB, KC_Q, KC_W, KC_E, KC_R, KC_T, KC_Y, KC_U, KC_I, KC_O, KC_P, KC_BSPC, |
| 291 | {KC_ESC, KC_A, KC_S, KC_D, KC_F, KC_G, KC_H, KC_J, KC_K, KC_L, KC_QUOT, KC_ENT }, | 334 | KC_ESC, KC_A, KC_S, KC_D, KC_F, KC_G, KC_H, KC_J, KC_K, KC_L, KC_QUOT, KC_ENT , |
| 292 | {KC_LSFT, KC_Z, KC_X, KC_C, KC_V, KC_B, KC_N, KC_M, KC_COMM, KC_DOT, KC_SLSH, KC_RSFT}, | 335 | KC_LSFT, KC_Z, KC_X, KC_C, KC_V, KC_B, KC_N, KC_M, KC_COMM, KC_DOT, KC_SLSH, KC_RSFT, |
| 293 | {KC_LCTL, KC_LALT, KC_LGUI, PUNC, NUM, KC_SPC, KC_SPC, FUNC, EMOJI, GREEK, KC_RALT, KC_RCTL} | 336 | KC_LCTL, KC_LALT, KC_LGUI, PUNC, NUM, LSPACE, RSPACE, FUNC, GREEK, KC_RGUI, KC_RALT, KC_RCTL |
| 294 | }, | 337 | ), |
| 295 | 338 | ||
| 296 | /* Colemak | 339 | /* Dvorak |
| 297 | * ,-----------------------------------------------------------------------------------. | 340 | * ,-----------------------------------------------------------------------------------. |
| 298 | * | Tab | Q | W | F | P | G | J | L | U | Y | ; | Bksp | | 341 | * | Tab | ' | , | . | P | Y | F | G | C | R | L | Bksp | |
| 299 | * |------+------+------+------+------+-------------+------+------+------+------+------| | 342 | * |------+------+------+------+------+-------------+------+------+------+------+------| |
| 300 | * | Esc | A | R | S | T | D | H | N | E | I | O |Enter | | 343 | * | Esc | A | O | E | U | I | D | H | T | N | S |Enter | |
| 301 | * |------+------+------+------+------+------|------+------+------+------+------+------| | 344 | * |------+------+------+------+------+------|------+------+------+------+------+------| |
| 302 | * | Shift| Z | X | C | V | B | K | M | , | . | / |Shift | | 345 | * | Shift| / | Q | J | K | X | B | M | W | V | Z |Shift | |
| 303 | * |------+------+------+------+------+------+------+------+------+------+------+------| | 346 | * |------+------+------+------+------+------+------+------+------+------+------+------| |
| 304 | * | Ctrl | GUI | Alt | Punc | Num | Space | Func |Emoji |AltGr | GUI | Ctrl | | 347 | * | Ctrl | Alt | GUI | Punc | Num | Space | Func |Greek | GUI |AltGr | Ctrl | |
| 305 | * `-----------------------------------------------------------------------------------' | 348 | * `-----------------------------------------------------------------------------------' |
| 306 | */ | 349 | */ |
| 307 | [_COLEMAK] = { | 350 | #ifdef LAYOUT_DVORAK |
| 308 | {_______, KC_Q, KC_W, KC_F, KC_P, KC_G, KC_J, KC_L, KC_U, KC_Y, KC_QUOT, _______}, | 351 | [_DVORAK] = KEYMAP( |
| 309 | {_______, KC_A, KC_R, KC_S, KC_T, KC_D, KC_H, KC_N, KC_E, KC_I, KC_O, _______}, | 352 | _______, KC_QUOT, KC_COMM, KC_DOT, KC_P, KC_Y, KC_F, KC_G, KC_C, KC_R, KC_L, _______, |
| 310 | {_______, KC_Z, KC_X, KC_C, KC_V, KC_B, KC_K, KC_M, KC_COMM, KC_DOT, KC_SLSH, _______}, | 353 | _______, KC_A, KC_O, KC_E, KC_U, KC_I, KC_D, KC_H, KC_T, KC_N, KC_S, _______, |
| 311 | {_______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______} | 354 | _______, KC_SLSH, KC_Q, KC_J, KC_K, KC_X, KC_B, KC_M, KC_W, KC_V, KC_Z, _______, |
| 312 | }, | 355 | _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______ |
| 356 | ), | ||
| 357 | #endif | ||
| 313 | 358 | ||
| 314 | /* Workman | 359 | /* Colemak |
| 315 | * ,-----------------------------------------------------------------------------------. | 360 | * ,-----------------------------------------------------------------------------------. |
| 316 | * | Tab | Q | D | R | W | B | J | F | U | P | ; | Bksp | | 361 | * | Tab | Q | W | F | P | G | J | L | U | Y | ; | Bksp | |
| 317 | * |------+------+------+------+------+-------------+------+------+------+------+------| | 362 | * |------+------+------+------+------+-------------+------+------+------+------+------| |
| 318 | * | Esc | A | S | H | T | G | Y | N | E | O | I |Enter | | 363 | * | Esc | A | R | S | T | D | H | N | E | I | O |Enter | |
| 319 | * |------+------+------+------+------+------|------+------+------+------+------+------| | 364 | * |------+------+------+------+------+------|------+------+------+------+------+------| |
| 320 | * | Shift| Z | X | M | C | V | K | K | , | . | / |Shift | | 365 | * | Shift| Z | X | C | V | B | K | M | , | . | / |Shift | |
| 321 | * |------+------+------+------+------+------+------+------+------+------+------+------| | 366 | * |------+------+------+------+------+------+------+------+------+------+------+------| |
| 322 | * | Ctrl | GUI | Alt | Punc | Num | Space | Func |Emoji |AltGr | GUI | Ctrl | | 367 | * | Ctrl | Alt | GUI | Punc | Num | Space | Func |Greek | GUI |AltGr | Ctrl | |
| 323 | * `-----------------------------------------------------------------------------------' | 368 | * `-----------------------------------------------------------------------------------' |
| 324 | */ | 369 | */ |
| 325 | [_WORKMAN] = { | ||
| 326 | {_______, KC_Q, KC_D, KC_R, KC_W, KC_B, KC_J, KC_F, KC_U, KC_P, KC_QUOT, _______}, | ||
| 327 | {_______, KC_A, KC_S, KC_H, KC_T, KC_G, KC_Y, KC_N, KC_E, KC_O, KC_I, _______}, | ||
| 328 | {_______, KC_Z, KC_X, KC_M, KC_C, KC_V, KC_K, KC_L, KC_COMM, KC_DOT, KC_SLSH, _______}, | ||
| 329 | {_______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______} | ||
| 330 | }, | ||
| 331 | 370 | ||
| 332 | /* Uppercase Greek | 371 | #ifdef LAYOUT_COLEMAK |
| 372 | [_COLEMAK] = KEYMAP( | ||
| 373 | _______, KC_Q, KC_W, KC_F, KC_P, KC_G, KC_J, KC_L, KC_U, KC_Y, KC_QUOT, _______, | ||
| 374 | _______, KC_A, KC_R, KC_S, KC_T, KC_D, KC_H, KC_N, KC_E, KC_I, KC_O, _______, | ||
| 375 | _______, KC_Z, KC_X, KC_C, KC_V, KC_B, KC_K, KC_M, KC_COMM, KC_DOT, KC_SLSH, _______, | ||
| 376 | _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______ | ||
| 377 | ), | ||
| 378 | #endif | ||
| 379 | |||
| 380 | /* Norman | ||
| 333 | * ,-----------------------------------------------------------------------------------. | 381 | * ,-----------------------------------------------------------------------------------. |
| 334 | * | | | | | | | | | | | | | | 382 | * | Tab | Q | W | D | F | K | J | U | R | L | ; | Bksp | |
| 335 | * |------+------+------+------+------+-------------+------+------+------+------+------| | 383 | * |------+------+------+------+------+-------------+------+------+------+------+------| |
| 336 | * | | | | | | | | | | | | | | 384 | * | Esc | A | S | E | T | G | Y | N | I | O | H |Enter | |
| 337 | * |------+------+------+------+------+------+------+------+------+------+------+------| | 385 | * |------+------+------+------+------+------|------+------+------+------+------+------| |
| 338 | * | | | | | | | | | | | | | | 386 | * | Shift| Z | X | C | V | B | P | M | , | . | / |Shift | |
| 339 | * |------+------+------+------+------+------+------+------+------+------+------+------| | 387 | * |------+------+------+------+------+------+------+------+------+------+------+------| |
| 340 | * | | | | | | | | | | | | | | 388 | * | Ctrl | Alt | GUI | Punc | Num | Space | Func |Greek | GUI |AltGr | Ctrl | |
| 341 | * `-----------------------------------------------------------------------------------' | 389 | * `-----------------------------------------------------------------------------------' |
| 342 | */ | 390 | */ |
| 343 | [_GREEKU] = { | ||
| 344 | {_______, _______, _______,X(UEPSI), X(URHO), X(UTAU),X(UUPSI),X(UTHET),X(UIOTA),X(UOMIC), X(UPI), _______}, | ||
| 345 | {_______,X(UALPH),X(USIGM),X(UDELT), X(UPHI),X(UGAMM), X(UETA), X(UXI),X(UKAPP),X(ULAMB), _______, _______}, | ||
| 346 | {_______,X(UZETA), X(UCHI), X(UPSI),X(UOMEG),X(UBETA), X(UNU), X(UMU), _______, _______, _______, _______}, | ||
| 347 | {_______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______} | ||
| 348 | }, | ||
| 349 | 391 | ||
| 350 | /* Lowercase Greek | 392 | #ifdef LAYOUT_NORMAN |
| 393 | [_NORMAN] = KEYMAP( | ||
| 394 | _______, KC_Q, KC_W, KC_D, KC_F, KC_K, KC_J, KC_U, KC_R, KC_L, KC_QUOT, _______, | ||
| 395 | _______, KC_A, KC_S, KC_E, KC_T, KC_G, KC_Y, KC_N, KC_I, KC_O, KC_H, _______, | ||
| 396 | _______, KC_Z, KC_X, KC_C, KC_V, KC_B, KC_P, KC_M, KC_COMM, KC_DOT, KC_SLSH, _______, | ||
| 397 | _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______ | ||
| 398 | ), | ||
| 399 | #endif | ||
| 400 | |||
| 401 | /* Workman | ||
| 351 | * ,-----------------------------------------------------------------------------------. | 402 | * ,-----------------------------------------------------------------------------------. |
| 352 | * | | | | | | | | | | | | | | 403 | * | Tab | Q | D | R | W | B | J | F | U | P | ; | Bksp | |
| 353 | * |------+------+------+------+------+-------------+------+------+------+------+------| | 404 | * |------+------+------+------+------+-------------+------+------+------+------+------| |
| 354 | * | | | | | | | | | | | | | | 405 | * | Esc | A | S | H | T | G | Y | N | E | O | I |Enter | |
| 355 | * |------+------+------+------+------+------+------+------+------+------+------+------| | 406 | * |------+------+------+------+------+------|------+------+------+------+------+------| |
| 356 | * | | | | | | | | | | | | | | 407 | * | Shift| Z | X | M | C | V | K | K | , | . | / |Shift | |
| 357 | * |------+------+------+------+------+------+------+------+------+------+------+------| | 408 | * |------+------+------+------+------+------+------+------+------+------+------+------| |
| 358 | * | | | | | | | | | | | | | | 409 | * | Ctrl | Alt | GUI | Punc | Num | Space | Func |Greek | GUI |AltGr | Ctrl | |
| 359 | * `-----------------------------------------------------------------------------------' | 410 | * `-----------------------------------------------------------------------------------' |
| 360 | */ | 411 | */ |
| 361 | [_GREEKL] = { | 412 | |
| 362 | {_______, _______,X(FSIGM),X(LEPSI), X(LRHO), X(LTAU),X(LUPSI),X(LTHET),X(LIOTA),X(LOMIC), X(LPI), _______}, | 413 | #ifdef LAYOUT_WORKMAN |
| 363 | {_______,X(LALPH),X(LSIGM),X(LDELT), X(LPHI),X(LGAMM), X(LETA), X(LXI),X(LKAPP),X(LLAMB), _______, _______}, | 414 | [_WORKMAN] = KEYMAP( |
| 364 | {_______,X(LZETA), X(LCHI), X(LPSI),X(LOMEG),X(LBETA), X(LNU), X(LMU), _______, _______, _______, _______}, | 415 | _______, KC_Q, KC_D, KC_R, KC_W, KC_B, KC_J, KC_F, KC_U, KC_P, KC_QUOT, _______, |
| 365 | {_______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______} | 416 | _______, KC_A, KC_S, KC_H, KC_T, KC_G, KC_Y, KC_N, KC_E, KC_O, KC_I, _______, |
| 366 | }, | 417 | _______, KC_Z, KC_X, KC_M, KC_C, KC_V, KC_K, KC_L, KC_COMM, KC_DOT, KC_SLSH, _______, |
| 418 | _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______ | ||
| 419 | ), | ||
| 420 | #endif | ||
| 367 | 421 | ||
| 368 | /* Punc | 422 | /* Punc |
| 369 | * ,-----------------------------------------------------------------------------------. | 423 | * ,-----------------------------------------------------------------------------------. |
| 370 | * | ~ | ! | @ | # | $ | % | ^ | & | * | ( | ) | ` | | 424 | * | ~ | ! | @ | # | $ | % | ^ | & | * | ( | ) | ` | |
| 371 | * |------+------+------+------+------+-------------+------+------+------+------+------| | 425 | * |------+------+------+------+------+-------------+------+------+------+------+------| |
| 372 | * | | | \ | - | = | < | > | ( | ) | ' | | | | 426 | * | | * | \ | - | = | / | | ( | ) | < | > | | |
| 373 | * |------+------+------+------+------+------|------+------+------+------+------+------| | 427 | * |------+------+------+------+------+------|------+------+------+------+------+------| |
| 374 | * | | | | | _ | + | { | } | [ | ] | " | | | | 428 | * | & | ^ | | | _ | + | ? | | [ | ] | { | } | : | |
| 375 | * |------+------+------+------+------+------+------+------+------+------+------+------| | 429 | * |------+------+------+------+------+------+------+------+------+------+------+------| |
| 376 | * | | | | | | | | | | | | | 430 | * | | | | | | | | | | | | |
| 377 | * `-----------------------------------------------------------------------------------' | 431 | * `-----------------------------------------------------------------------------------' |
| 378 | */ | 432 | */ |
| 379 | [_PUNC] = { | 433 | [_PUNC] = KEYMAP( |
| 380 | {KC_TILD, KC_EXLM, KC_AT, KC_HASH, KC_DLR, KC_PERC, KC_CIRC, KC_AMPR, KC_ASTR, KC_LPRN, KC_RPRN, KC_GRV }, | 434 | KC_TILD, KC_EXLM, KC_AT, KC_HASH, KC_DLR, KC_PERC, KC_CIRC, KC_AMPR, KC_ASTR, KC_LPRN, KC_RPRN, KC_GRV , |
| 381 | {XXXXXXX, XXXXXXX, KC_BSLS, KC_MINS, KC_EQL, KC_LABK, KC_RABK, KC_LPRN, KC_RPRN, KC_QUOT, XXXXXXX, XXXXXXX}, | 435 | XXXXXXX, KC_ASTR, KC_BSLS, KC_MINS, KC_EQL, KC_SLSH, XXXXXXX, KC_LPRN, KC_RPRN, KC_LABK, KC_RABK, XXXXXXX, |
| 382 | {XXXXXXX, XXXXXXX, KC_PIPE, KC_UNDS, KC_PLUS, KC_LCBR, KC_RCBR, KC_LBRC, KC_RBRC, KC_DQUO, XXXXXXX, XXXXXXX}, | 436 | KC_AMPR, KC_CIRC, KC_PIPE, KC_UNDS, KC_PLUS, KC_QUES, XXXXXXX, KC_LBRC, KC_RBRC, KC_LCBR, KC_RCBR, KC_COLN, |
| 383 | {_______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______} | 437 | _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______ |
| 384 | }, | 438 | ), |
| 385 | 439 | ||
| 386 | /* Num | 440 | /* Num |
| 387 | * ,-----------------------------------------------------------------------------------. | 441 | * ,-----------------------------------------------------------------------------------. |
| 388 | * | ^ | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 0 | Bksp | | 442 | * | ~ | ! | @ | # | $ | % | A | 7 | 8 | 9 | D | ` | |
| 389 | * |------+------+------+------+------+-------------+------+------+------+------+------| | 443 | * |------+------+------+------+------+-------------+------+------+------+------+------| |
| 390 | * | Esc | @ | A | B | C | ( | ) | 4 | 5 | 6 | : |Enter | | 444 | * | | * | \ | - | = | / | B | 4 | 5 | 6 | E | | |
| 391 | * |------+------+------+------+------+------|------+------+------+------+------+------| | 445 | * |------+------+------+------+------+------|------+------+------+------+------+------| |
| 392 | * | & | # | D | E | F | [ | ] | 1 | 2 | 3 | / | * | | 446 | * | & | ^ | | | _ | + | ? | C | 1 | 2 | 3 | F | : | |
| 393 | * |------+------+------+------+------+------+------+------+------+------+------+------| | 447 | * |------+------+------+------+------+------+------+------+------+------+------+------| |
| 394 | * | | | | x | | | 0 | , | . | + | - | | 448 | * | | | | | | | x | 0 | , | . | | | |
| 395 | * `-----------------------------------------------------------------------------------' | 449 | * `-----------------------------------------------------------------------------------' |
| 396 | */ | 450 | */ |
| 397 | [_NUM] = { | 451 | [_NUM] = KEYMAP( |
| 398 | {KC_CIRC, KC_1, KC_2, KC_3, KC_4, KC_5, KC_6, KC_7, KC_8, KC_9, KC_0, KC_BSPC}, | 452 | KC_TILD, KC_EXLM, KC_AT, KC_HASH, KC_DLR, KC_PERC, S(KC_A), KC_7, KC_8, KC_9, S(KC_D), KC_GRV, |
| 399 | { KC_ESC, KC_AT, S(KC_A), S(KC_B), S(KC_C), KC_LPRN, KC_RPRN, KC_4, KC_5, KC_6, KC_COLN, KC_ENT}, | 453 | XXXXXXX, KC_ASTR, KC_BSLS, KC_MINS, KC_EQL, KC_SLSH, S(KC_B), KC_4, KC_5, KC_6, S(KC_E), _______, |
| 400 | {KC_AMPR, KC_HASH, S(KC_D), S(KC_E), S(KC_F), KC_LBRC, KC_RBRC, KC_1, KC_2, KC_3, KC_SLSH, KC_ASTR}, | 454 | KC_AMPR, KC_CIRC, KC_PIPE, KC_UNDS, KC_PLUS, KC_QUES, S(KC_C), KC_1, KC_2, KC_3, S(KC_F), KC_COLN, |
| 401 | {_______, _______, _______, KC_X, _______, KC_SPC, KC_SPC, KC_0, KC_COMM, KC_DOT, KC_PLUS, KC_MINS} | 455 | _______, _______, _______, _______, _______, _______, _______, KC_0, KC_COMM, KC_DOT, KC_X, _______ |
| 402 | }, | 456 | ), |
| 403 | 457 | ||
| 404 | /* Func | 458 | /* Func |
| 405 | * ,-----------------------------------------------------------------------------------. | 459 | * ,-----------------------------------------------------------------------------------. |
| @@ -412,12 +466,48 @@ const uint16_t PROGMEM keymaps[][MATRIX_ROWS][MATRIX_COLS] = { | |||
| 412 | * | | | | | | | | | | | | | 466 | * | | | | | | | | | | | | |
| 413 | * `-----------------------------------------------------------------------------------' | 467 | * `-----------------------------------------------------------------------------------' |
| 414 | */ | 468 | */ |
| 415 | [_FUNC] = { | 469 | [_FUNC] = KEYMAP( |
| 416 | {XXXXXXX, KC_F1, KC_F2, KC_F3, KC_F4, XXXXXXX, XXXXXXX, KC_PGUP, KC_UP, KC_PGDN, KC_PGUP, KC_DEL}, | 470 | XXXXXXX, KC_F1, KC_F2, KC_F3, KC_F4, XXXXXXX, XXXXXXX, KC_PGUP, KC_UP, KC_PGDN, KC_PGUP, KC_DEL, |
| 417 | {XXXXXXX, KC_F5, KC_F6, KC_F7, KC_F8,KC_PSCREEN,XXXXXXX, KC_LEFT, KC_DOWN, KC_RGHT, KC_PGDN, KC_INS}, | 471 | XXXXXXX, KC_F5, KC_F6, KC_F7, KC_F8,KC_PSCREEN,XXXXXXX, KC_LEFT, KC_DOWN, KC_RGHT, KC_PGDN, KC_INS, |
| 418 | {_______, KC_F9, KC_F10, KC_F11, KC_F12, XXXXXXX, XXXXXXX, XXXXXXX, KC_HOME, KC_END, XXXXXXX, _______}, | 472 | _______, KC_F9, KC_F10, KC_F11, KC_F12, XXXXXXX, XXXXXXX, XXXXXXX, KC_HOME, KC_END, XXXXXXX, _______, |
| 419 | {_______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______} | 473 | _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______ |
| 420 | }, | 474 | ), |
| 475 | |||
| 476 | /* Uppercase Greek | ||
| 477 | * ,-----------------------------------------------------------------------------------. | ||
| 478 | * | | | | | | | | | | | | | | ||
| 479 | * |------+------+------+------+------+-------------+------+------+------+------+------| | ||
| 480 | * | | | | | | | | | | | | | | ||
| 481 | * |------+------+------+------+------+------+------+------+------+------+------+------| | ||
| 482 | * | | | | | | | | | | | | | | ||
| 483 | * |------+------+------+------+------+------+------+------+------+------+------+------| | ||
| 484 | * | | | | | | | | | | | | | | ||
| 485 | * `-----------------------------------------------------------------------------------' | ||
| 486 | */ | ||
| 487 | [_GREEKU] = KEYMAP( | ||
| 488 | _______, _______, _______,X(UEPSI), X(URHO), X(UTAU),X(UUPSI),X(UTHET),X(UIOTA),X(UOMIC), X(UPI), _______, | ||
| 489 | _______,X(UALPH),X(USIGM),X(UDELT), X(UPHI),X(UGAMM), X(UETA), X(UXI),X(UKAPP),X(ULAMB), _______, _______, | ||
| 490 | _______,X(UZETA), X(UCHI), X(UPSI),X(UOMEG),X(UBETA), X(UNU), X(UMU), _______, _______, _______, _______, | ||
| 491 | _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______ | ||
| 492 | ), | ||
| 493 | |||
| 494 | /* Lowercase Greek | ||
| 495 | * ,-----------------------------------------------------------------------------------. | ||
| 496 | * | | | | | | | | | | | | | | ||
| 497 | * |------+------+------+------+------+-------------+------+------+------+------+------| | ||
| 498 | * | | | | | | | | | | | | | | ||
| 499 | * |------+------+------+------+------+------+------+------+------+------+------+------| | ||
| 500 | * | | | | | | | | | | | | | | ||
| 501 | * |------+------+------+------+------+------+------+------+------+------+------+------| | ||
| 502 | * | | | | | | | | | | | | | | ||
| 503 | * `-----------------------------------------------------------------------------------' | ||
| 504 | */ | ||
| 505 | [_GREEKL] = KEYMAP( | ||
| 506 | _______, _______,X(FSIGM),X(LEPSI), X(LRHO), X(LTAU),X(LUPSI),X(LTHET),X(LIOTA),X(LOMIC), X(LPI), _______, | ||
| 507 | _______,X(LALPH),X(LSIGM),X(LDELT), X(LPHI),X(LGAMM), X(LETA), X(LXI),X(LKAPP),X(LLAMB), _______, _______, | ||
| 508 | _______,X(LZETA), X(LCHI), X(LPSI),X(LOMEG),X(LBETA), X(LNU), X(LMU), _______, _______, _______, _______, | ||
| 509 | _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______ | ||
| 510 | ), | ||
| 421 | 511 | ||
| 422 | /* Emoji | 512 | /* Emoji |
| 423 | * ,-----------------------------------------------------------------------------------. | 513 | * ,-----------------------------------------------------------------------------------. |
| @@ -430,30 +520,48 @@ const uint16_t PROGMEM keymaps[][MATRIX_ROWS][MATRIX_COLS] = { | |||
| 430 | * | | | | | | | | | | | | | | 520 | * | | | | | | | | | | | | | |
| 431 | * `-----------------------------------------------------------------------------------' | 521 | * `-----------------------------------------------------------------------------------' |
| 432 | */ | 522 | */ |
| 433 | [_EMOJI] = { | 523 | [_EMOJI] = KEYMAP( |
| 434 | {X(HART2), X(CRY2),X(WEARY),X(EYERT),X(SMIRK), X(TJOY),X(RECYC),X(UNAMU),X(MUSIC),X(OKHND),X(PENSV), X(PHEW)}, | 524 | X(HART2), X(CRY2),X(WEARY),X(EYERT),X(SMIRK), X(TJOY),X(RECYC),X(UNAMU),X(MUSIC),X(OKHND),X(PENSV), X(PHEW), |
| 435 | {X(THMUP), X(PRAY),X(SMILE),X(SMIL2),X(FLUSH), X(GRIN),X(HEART), X(BYE), X(KISS),X(CELEB), X(COOL),X(NOEVS)}, | 525 | X(THMUP), X(PRAY),X(SMILE),X(SMIL2),X(FLUSH), X(GRIN),X(HEART), X(BYE), X(KISS),X(CELEB), X(COOL),X(NOEVS), |
| 436 | {X(THMDN),X(SLEEP), X(CLAP), X(CRY), X(VIC),X(BHART), X(SUN),X(SMEYE), X(WINK), X(MOON),X(CONFU),X(NOEVH)}, | 526 | X(THMDN),X(SLEEP), X(CLAP), X(CRY), X(VIC),X(BHART), X(SUN),X(SMEYE), X(WINK), X(MOON),X(CONFU),X(NOEVH), |
| 437 | { X(POO), X(EYES),X(HUNRD), _______,X(SKULL),X(HORNS), X(HALO), X(FEAR), _______,X(YUMMY),X(DISAP),X(NOEVK)} | 527 | X(POO), X(EYES), _______,X(HUNRD), X(SKULL),X(HORNS), X(HALO), X(FEAR),X(YUMMY),_______,X(DISAP),X(NOEVK) |
| 438 | }, | 528 | ), |
| 439 | 529 | ||
| 440 | /* GUI | 530 | /* GUI |
| 441 | * ,-----------------------------------------------------------------------------------. | 531 | * ,-----------------------------------------------------------------------------------. |
| 442 | * | | D1 | D2 | D3 | D4 | D5 | D6 | D7 | D8 | D9 | D10 | | | 532 | * | | D1 | D2 | D3 | D4 | D5 | D6 | D7 | D8 | D9 | D10 | | |
| 443 | * |------+------+------+------+------+-------------+------+------+------+------+------| | 533 | * |------+------+------+------+------+-------------+------+------+------+------+------| |
| 444 | * |Linux | | Vol- | Mute | Vol+ | | | D- | | D+ | |Qwerty| | 534 | * | | | Vol- | Mute | Vol+ | | | Prev | | Next | | | |
| 445 | * |------+------+------+------+------+------+------+------+------+------+------+------| | 535 | * |------+------+------+------+------+------+------+------+------+------+------+------| |
| 446 | * | Win | | Prev | Play | Next | | | | | | |Colmak| | 536 | * | | | Prev | Play | Next | | | | | | | | |
| 447 | * |------+------+------+------+------+------+------+------+------+------+------+------| | 537 | * |------+------+------+------+------+------+------+------+------+------+------+------| |
| 448 | * | OSX | | | | | BL- | BL+ | | | | |Workmn| | 538 | * | | | | | | | | | | | | | |
| 449 | * `-----------------------------------------------------------------------------------' | 539 | * `-----------------------------------------------------------------------------------' |
| 450 | */ | 540 | */ |
| 451 | [_GUI] = { | 541 | [_GUI] = KEYMAP( |
| 452 | {_______, LGUI(KC_1),LGUI(KC_2),LGUI(KC_3),LGUI(KC_4),LGUI(KC_5),LGUI(KC_6),LGUI(KC_7),LGUI(KC_8),LGUI(KC_9),LGUI(KC_0), _______}, | 542 | XXXXXXX, G(KC_1), G(KC_2), G(KC_3), G(KC_4), G(KC_5), G(KC_6), G(KC_7), G(KC_8), G(KC_9), G(KC_0), XXXXXXX, |
| 453 | { LINUX, _______, KC_VOLD, KC_MUTE, KC_VOLU,_______,_______,KC_WWW_BACK,_______,KC_WWW_FORWARD,_______, QWERTY}, | 543 | XXXXXXX, XXXXXXX, KC_VOLD, KC_MUTE, KC_VOLU, XXXXXXX, XXXXXXX, KC_WWWB, XXXXXXX, KC_WWWF, XXXXXXX, XXXXXXX, |
| 454 | { WIN, _______, KC_MPRV, KC_MPLY, KC_MNXT, _______, _______, _______, _______, _______, _______, COLEMAK}, | 544 | XXXXXXX, XXXXXXX, KC_MPRV, KC_MPLY, KC_MNXT, KC_SPC, KC_SPC, XXXXXXX, XXXXXXX, XXXXXXX, XXXXXXX, XXXXXXX, |
| 455 | { OSX, _______, _______, _______, _______, BL_DEC, BL_INC, _______, _______, _______, _______, WORKMAN} | 545 | XXXXXXX, XXXXXXX, XXXXXXX, _______, XXXXXXX, XXXXXXX, XXXXXXX, XXXXXXX, _______, XXXXXXX, XXXXXXX, XXXXXXX |
| 456 | }, | 546 | ), |
| 547 | |||
| 548 | /* Sys | ||
| 549 | * ,-----------------------------------------------------------------------------------. | ||
| 550 | * | |Qwerty| Win | |Reset | | | USB | | | | | | ||
| 551 | * |------+------+------+------+------+-------------+------+------+------+------+------| | ||
| 552 | * | |Audio | |Dvorak| | Glow | | |WorkMn|Linux | | | | ||
| 553 | * |------+------+------+------+------+------+------+------+------+------+------+------| | ||
| 554 | * | | | |Colmak| | BLE |Norman|MacOS | | | | | | ||
| 555 | * |------+------+------+------+------+------+------+------+------+------+------+------| | ||
| 556 | * | | | | | | | | | | | | | | ||
| 557 | * `-----------------------------------------------------------------------------------' | ||
| 558 | */ | ||
| 559 | [_SYS] = KEYMAP( | ||
| 560 | XXXXXXX, QWERTY, WIN, XXXXXXX, RESET, XXXXXXX, XXXXXXX, OUT_USB, XXXXXXX, XXXXXXX, XXXXXXX, XXXXXXX, | ||
| 561 | XXXXXXX, AUDIO, XXXXXXX, DVORAK, XXXXXXX, GLOW, XXXXXXX, XXXXXXX, WORKMAN, LINUX, XXXXXXX, XXXXXXX, | ||
| 562 | XXXXXXX, XXXXXXX, XXXXXXX, COLEMAK, XXXXXXX, OUT_BLE, NORMAN, OSX, XXXXXXX, XXXXXXX, XXXXXXX, XXXXXXX, | ||
| 563 | _______, XXXXXXX, XXXXXXX, XXXXXXX, XXXXXXX, XXXXXXX, XXXXXXX, XXXXXXX, XXXXXXX, XXXXXXX, XXXXXXX, _______ | ||
| 564 | ), | ||
| 457 | 565 | ||
| 458 | }; | 566 | }; |
| 459 | 567 | ||
| @@ -476,6 +584,32 @@ void persistant_default_layer_set(uint16_t default_layer) { | |||
| 476 | default_layer_set(default_layer); | 584 | default_layer_set(default_layer); |
| 477 | } | 585 | } |
| 478 | 586 | ||
| 587 | #ifdef DOUBLESPACE_LAYER_ENABLE | ||
| 588 | void process_doublespace(bool pressed, bool *isactive, bool *otheractive, bool *isemitted) { | ||
| 589 | if (pressed) { | ||
| 590 | *isactive = true; | ||
| 591 | if (*otheractive) { | ||
| 592 | layer_on(_SPACE); | ||
| 593 | space_layer_entered = true; | ||
| 594 | } | ||
| 595 | } else { | ||
| 596 | *isactive = false; | ||
| 597 | if (space_layer_entered) { | ||
| 598 | layer_off(_SPACE); | ||
| 599 | if (!*otheractive) { | ||
| 600 | space_layer_entered = false; | ||
| 601 | } | ||
| 602 | } else { | ||
| 603 | if (!*isemitted) { | ||
| 604 | register_code(KC_SPC); | ||
| 605 | unregister_code(KC_SPC); | ||
| 606 | } | ||
| 607 | *isemitted = false; | ||
| 608 | } | ||
| 609 | } | ||
| 610 | } | ||
| 611 | #endif | ||
| 612 | |||
| 479 | bool process_record_user(uint16_t keycode, keyrecord_t *record) { | 613 | bool process_record_user(uint16_t keycode, keyrecord_t *record) { |
| 480 | // faux clicky | 614 | // faux clicky |
| 481 | // if (record->event.pressed) PLAY_NOTE_ARRAY(tone_click, false, 0); | 615 | // if (record->event.pressed) PLAY_NOTE_ARRAY(tone_click, false, 0); |
| @@ -493,27 +627,49 @@ bool process_record_user(uint16_t keycode, keyrecord_t *record) { | |||
| 493 | #endif | 627 | #endif |
| 494 | #endif | 628 | #endif |
| 495 | 629 | ||
| 496 | bool lshifted = keyboard_report->mods & MOD_BIT(KC_LSFT); | 630 | bool lshift = keyboard_report->mods & MOD_BIT(KC_LSFT); |
| 497 | bool rshifted = keyboard_report->mods & MOD_BIT(KC_RSFT); | 631 | bool rshift = keyboard_report->mods & MOD_BIT(KC_RSFT); |
| 632 | |||
| 633 | #ifdef DOUBLESPACE_LAYER_ENABLE | ||
| 634 | // double-space: send space immediately if any other key depressed before space is released | ||
| 635 | if ((lspace_active ^ rspace_active) | ||
| 636 | && keycode != LSPACE | ||
| 637 | && keycode != RSPACE | ||
| 638 | && record->event.pressed) | ||
| 639 | { | ||
| 640 | if (lspace_active) { | ||
| 641 | if (!lspace_emitted) { | ||
| 642 | register_code(KC_SPC); | ||
| 643 | unregister_code(KC_SPC); | ||
| 644 | } | ||
| 645 | lspace_emitted = true; | ||
| 646 | } | ||
| 647 | if (rspace_active) { | ||
| 648 | if (!rspace_emitted) { | ||
| 649 | register_code(KC_SPC); | ||
| 650 | unregister_code(KC_SPC); | ||
| 651 | } | ||
| 652 | rspace_emitted = true; | ||
| 653 | } | ||
| 654 | } | ||
| 655 | #endif | ||
| 498 | 656 | ||
| 499 | switch (keycode) { | 657 | switch (keycode) { |
| 500 | // Greek layer handling | 658 | |
| 501 | case GREEK: | 659 | #ifdef DOUBLESPACE_LAYER_ENABLE |
| 502 | if (record->event.pressed) { | 660 | // double-space enter space layer |
| 503 | if (lshifted || rshifted) { | 661 | case LSPACE: |
| 504 | layer_on(_GREEKU); | 662 | process_doublespace(record->event.pressed, &lspace_active, &rspace_active, &lspace_emitted); |
| 505 | layer_off(_GREEKL); | ||
| 506 | } else { | ||
| 507 | layer_on(_GREEKL); | ||
| 508 | layer_off(_GREEKU); | ||
| 509 | } | ||
| 510 | } else { | ||
| 511 | layer_off(_GREEKU); | ||
| 512 | layer_off(_GREEKL); | ||
| 513 | } | ||
| 514 | return false; | 663 | return false; |
| 515 | break; | 664 | break; |
| 665 | case RSPACE: | ||
| 666 | process_doublespace(record->event.pressed, &rspace_active, &lspace_active, &rspace_emitted); | ||
| 667 | return false; | ||
| 668 | break; | ||
| 669 | #endif | ||
| 516 | 670 | ||
| 671 | // handle greek layer shift | ||
| 672 | // handle both shift = capslock | ||
| 517 | case KC_LSFT: | 673 | case KC_LSFT: |
| 518 | case KC_RSFT: | 674 | case KC_RSFT: |
| 519 | ; | 675 | ; |
| @@ -523,11 +679,34 @@ bool process_record_user(uint16_t keycode, keyrecord_t *record) { | |||
| 523 | layer_on(_GREEKU); | 679 | layer_on(_GREEKU); |
| 524 | layer_off(_GREEKL); | 680 | layer_off(_GREEKL); |
| 525 | } else { | 681 | } else { |
| 526 | if (lshifted ^ rshifted) { // if only one shift is pressed | 682 | if (lshift ^ rshift) { // if only one shift was pressed |
| 527 | layer_on(_GREEKL); | 683 | layer_on(_GREEKL); |
| 528 | layer_off(_GREEKU); | 684 | layer_off(_GREEKU); |
| 529 | } | 685 | } |
| 530 | } | 686 | } |
| 687 | } else { | ||
| 688 | if (record->event.pressed) { | ||
| 689 | if (lshift ^ rshift) { // if only one shift was pressed | ||
| 690 | register_code(KC_CAPS); | ||
| 691 | unregister_code(KC_CAPS); | ||
| 692 | } | ||
| 693 | } | ||
| 694 | } | ||
| 695 | return true; | ||
| 696 | break; | ||
| 697 | |||
| 698 | // press both ctrls to activate SYS layer | ||
| 699 | case KC_LCTL: | ||
| 700 | case KC_RCTL: | ||
| 701 | ; | ||
| 702 | bool lctrl = keyboard_report->mods & MOD_BIT(KC_LCTL); | ||
| 703 | bool rctrl = keyboard_report->mods & MOD_BIT(KC_RCTL); | ||
| 704 | if (record->event.pressed) { | ||
| 705 | if (lctrl ^ rctrl) { // if only one ctrl was pressed | ||
| 706 | layer_on(_SYS); | ||
| 707 | } | ||
| 708 | } else { | ||
| 709 | layer_off(_SYS); | ||
| 531 | } | 710 | } |
| 532 | return true; | 711 | return true; |
| 533 | break; | 712 | break; |
| @@ -535,13 +714,13 @@ bool process_record_user(uint16_t keycode, keyrecord_t *record) { | |||
| 535 | // QWERTZ style comma and dot: semicolon and colon when shifted | 714 | // QWERTZ style comma and dot: semicolon and colon when shifted |
| 536 | case KC_COMM: | 715 | case KC_COMM: |
| 537 | if (record->event.pressed) { | 716 | if (record->event.pressed) { |
| 538 | if (lshifted || rshifted) { | 717 | if (lshift || rshift) { |
| 539 | if (lshifted) unregister_code(KC_LSFT); | 718 | if (lshift) unregister_code(KC_LSFT); |
| 540 | if (rshifted) unregister_code(KC_RSFT); | 719 | if (rshift) unregister_code(KC_RSFT); |
| 541 | register_code(KC_SCLN); | 720 | register_code(KC_SCLN); |
| 542 | unregister_code(KC_SCLN); | 721 | unregister_code(KC_SCLN); |
| 543 | if (lshifted) register_code(KC_LSFT); | 722 | if (lshift) register_code(KC_LSFT); |
| 544 | if (rshifted) register_code(KC_RSFT); | 723 | if (rshift) register_code(KC_RSFT); |
| 545 | } else { | 724 | } else { |
| 546 | register_code(KC_COMM); | 725 | register_code(KC_COMM); |
| 547 | unregister_code(KC_COMM); | 726 | unregister_code(KC_COMM); |
| @@ -565,53 +744,73 @@ bool process_record_user(uint16_t keycode, keyrecord_t *record) { | |||
| 565 | // layout switcher | 744 | // layout switcher |
| 566 | case QWERTY: | 745 | case QWERTY: |
| 567 | if (record->event.pressed) { | 746 | if (record->event.pressed) { |
| 568 | #ifdef AUDIO_ENABLE | ||
| 569 | PLAY_NOTE_ARRAY(tone_qwerty, false, 0); | ||
| 570 | #endif | ||
| 571 | persistant_default_layer_set(1UL<<_QWERTY); | 747 | persistant_default_layer_set(1UL<<_QWERTY); |
| 572 | } | 748 | } |
| 573 | return false; | 749 | return false; |
| 574 | break; | 750 | break; |
| 751 | #ifdef LAYOUT_DVORAK | ||
| 752 | case DVORAK: | ||
| 753 | if (record->event.pressed) { | ||
| 754 | persistant_default_layer_set(1UL<<_DVORAK); | ||
| 755 | } | ||
| 756 | return false; | ||
| 757 | break; | ||
| 758 | #endif | ||
| 759 | #ifdef LAYOUT_COLEMAK | ||
| 575 | case COLEMAK: | 760 | case COLEMAK: |
| 576 | if (record->event.pressed) { | 761 | if (record->event.pressed) { |
| 577 | #ifdef AUDIO_ENABLE | ||
| 578 | PLAY_NOTE_ARRAY(tone_colemak, false, 0); | ||
| 579 | #endif | ||
| 580 | persistant_default_layer_set(1UL<<_COLEMAK); | 762 | persistant_default_layer_set(1UL<<_COLEMAK); |
| 581 | } | 763 | } |
| 582 | return false; | 764 | return false; |
| 583 | break; | 765 | break; |
| 766 | #endif | ||
| 767 | #ifdef LAYOUT_WORKMAN | ||
| 584 | case WORKMAN: | 768 | case WORKMAN: |
| 585 | if (record->event.pressed) { | 769 | if (record->event.pressed) { |
| 586 | #ifdef AUDIO_ENABLE | ||
| 587 | PLAY_NOTE_ARRAY(tone_workman, false, 0); | ||
| 588 | #endif | ||
| 589 | persistant_default_layer_set(1UL<<_WORKMAN); | 770 | persistant_default_layer_set(1UL<<_WORKMAN); |
| 590 | } | 771 | } |
| 591 | return false; | 772 | return false; |
| 592 | break; | 773 | break; |
| 774 | #endif | ||
| 775 | #ifdef LAYOUT_NORMAN | ||
| 776 | case NORMAN: | ||
| 777 | if (record->event.pressed) { | ||
| 778 | persistant_default_layer_set(1UL<<_NORMAN); | ||
| 779 | } | ||
| 780 | return false; | ||
| 781 | break; | ||
| 782 | #endif | ||
| 593 | 783 | ||
| 594 | // layer switchers | 784 | // layer switchers |
| 595 | case PUNC: | 785 | case PUNC: |
| 596 | if (record->event.pressed) { | 786 | if (record->event.pressed) { |
| 597 | layer_on(_PUNC); | 787 | layer_on(_PUNC); |
| 598 | update_tri_layer(_PUNC, _EMOJI, _GUI); | 788 | update_tri_layer(_PUNC, _GREEKL, _EMOJI); |
| 599 | } else { | 789 | } else { |
| 600 | layer_off(_PUNC); | 790 | layer_off(_PUNC); |
| 601 | update_tri_layer(_PUNC, _EMOJI, _GUI); | 791 | update_tri_layer(_PUNC, _GREEKL, _EMOJI); |
| 602 | } | 792 | } |
| 603 | return false; | 793 | return false; |
| 604 | break; | 794 | break; |
| 605 | case EMOJI: | 795 | |
| 796 | case GREEK: | ||
| 606 | if (record->event.pressed) { | 797 | if (record->event.pressed) { |
| 607 | layer_on(_EMOJI); | 798 | if (lshift || rshift) { |
| 608 | update_tri_layer(_PUNC, _EMOJI, _GUI); | 799 | layer_on(_GREEKU); |
| 800 | layer_off(_GREEKL); | ||
| 801 | } else { | ||
| 802 | layer_on(_GREEKL); | ||
| 803 | layer_off(_GREEKU); | ||
| 804 | update_tri_layer(_PUNC, _GREEKL, _EMOJI); | ||
| 805 | } | ||
| 609 | } else { | 806 | } else { |
| 610 | layer_off(_EMOJI); | 807 | layer_off(_GREEKU); |
| 611 | update_tri_layer(_PUNC, _EMOJI, _GUI); | 808 | layer_off(_GREEKL); |
| 809 | update_tri_layer(_PUNC, _GREEKL, _EMOJI); | ||
| 612 | } | 810 | } |
| 613 | return false; | 811 | return false; |
| 614 | break; | 812 | break; |
| 813 | |||
| 615 | case NUM: | 814 | case NUM: |
| 616 | if (record->event.pressed) { | 815 | if (record->event.pressed) { |
| 617 | layer_on(_NUM); | 816 | layer_on(_NUM); |
| @@ -651,6 +850,12 @@ bool process_record_user(uint16_t keycode, keyrecord_t *record) { | |||
| 651 | #endif | 850 | #endif |
| 652 | return false; | 851 | return false; |
| 653 | break; | 852 | break; |
| 853 | |||
| 854 | // faux clicky toggle, TBD | ||
| 855 | case AUDIO: | ||
| 856 | return false; | ||
| 857 | break; | ||
| 858 | |||
| 654 | } | 859 | } |
| 655 | return true; | 860 | return true; |
| 656 | } | 861 | } |
| @@ -677,4 +882,17 @@ void shutdown_user() | |||
| 677 | stop_all_notes(); | 882 | stop_all_notes(); |
| 678 | } | 883 | } |
| 679 | 884 | ||
| 680 | #endif \ No newline at end of file | 885 | #endif |
| 886 | |||
| 887 | void matrix_scan_user(void) { | ||
| 888 | } | ||
| 889 | |||
| 890 | void led_set_user(uint8_t usb_led) { | ||
| 891 | } | ||
| 892 | |||
| 893 | void turn_off_capslock() { | ||
| 894 | if (capslock) { | ||
| 895 | register_code(KC_CAPS); | ||
| 896 | unregister_code(KC_CAPS); | ||
| 897 | } | ||
| 898 | } | ||
diff --git a/keyboards/planck/rev3/Makefile b/keyboards/planck/rev3/Makefile new file mode 100644 index 000000000..191c6bb66 --- /dev/null +++ b/keyboards/planck/rev3/Makefile | |||
| @@ -0,0 +1,3 @@ | |||
| 1 | ifndef MAKEFILE_INCLUDED | ||
| 2 | include ../../../Makefile | ||
| 3 | endif \ No newline at end of file | ||
diff --git a/keyboards/tv44/keymaps/smt/Makefile b/keyboards/tv44/keymaps/smt/Makefile new file mode 100644 index 000000000..f4671a9d1 --- /dev/null +++ b/keyboards/tv44/keymaps/smt/Makefile | |||
| @@ -0,0 +1,21 @@ | |||
| 1 | # Build Options | ||
| 2 | # change to "no" to disable the options, or define them in the Makefile in | ||
| 3 | # the appropriate keymap folder that will get included automatically | ||
| 4 | # | ||
| 5 | BOOTMAGIC_ENABLE = no # Virtual DIP switch configuration(+1000) | ||
| 6 | MOUSEKEY_ENABLE = yes # Mouse keys(+4700) | ||
| 7 | EXTRAKEY_ENABLE = yes # Audio control and System control(+450) | ||
| 8 | CONSOLE_ENABLE = no # Console for debug(+400) | ||
| 9 | COMMAND_ENABLE = yes # Commands for debug and configuration | ||
| 10 | NKRO_ENABLE = yes # Nkey Rollover - if this doesn't work, see here: https://github.com/tmk/tmk_keyboard/wiki/FAQ#nkro-doesnt-work | ||
| 11 | BACKLIGHT_ENABLE = no # Enable keyboard backlight functionality | ||
| 12 | MIDI_ENABLE = no # MIDI controls | ||
| 13 | AUDIO_ENABLE = no # Audio output on port C6 | ||
| 14 | UNICODE_ENABLE = no # Unicode | ||
| 15 | BLUETOOTH_ENABLE = no # Enable Bluetooth with the Adafruit EZ-Key HID | ||
| 16 | RGBLIGHT_ENABLE = no # Enable WS2812 RGB underlight. Do not enable this with audio at the same time. | ||
| 17 | SLEEP_LED_ENABLE = no # Breathing sleep LED during USB suspend | ||
| 18 | |||
| 19 | ifndef QUANTUM_DIR | ||
| 20 | include ../../../../Makefile | ||
| 21 | endif \ No newline at end of file | ||
diff --git a/keyboards/tv44/keymaps/smt/config.h b/keyboards/tv44/keymaps/smt/config.h new file mode 100644 index 000000000..f8f0a5078 --- /dev/null +++ b/keyboards/tv44/keymaps/smt/config.h | |||
| @@ -0,0 +1,36 @@ | |||
| 1 | #ifndef CONFIG_USER_H | ||
| 2 | #define CONFIG_USER_H | ||
| 3 | |||
| 4 | #include "../../config.h" | ||
| 5 | |||
| 6 | /** | ||
| 7 | *TV44 keymap definition macro | ||
| 8 | */ | ||
| 9 | #define KEYMAP_TV44( \ | ||
| 10 | K01, K02, K03, K04, K05, K06, K07, K08, K09, K10, K11, K12, \ | ||
| 11 | K13, K14, K15, K16, K17, K18, K19, K20, K21, K22, K23, K24, \ | ||
| 12 | K25, K26, K27, K28, K29, K30, K31, K32, K33, K34, K35, K36, \ | ||
| 13 | K37, K38, K39, K40, K41, K42, K43, K44 \ | ||
| 14 | ) { \ | ||
| 15 | { K01, K02, K03, K04, K05, K06, K07, K08, K09, K10, K11, K12, }, \ | ||
| 16 | { K13, K14, K15, K16, K17, K18, K19, K20, K21, K22, K23, K24, }, \ | ||
| 17 | { K25, K26, K27, K28, K29, K30, K31, K32, K33, K34, K35, K36, }, \ | ||
| 18 | { K37, K38, K39, K40, KC_NO, KC_NO, KC_NO, K41, K42, K43, KC_NO, K44 } \ | ||
| 19 | } | ||
| 20 | |||
| 21 | /** | ||
| 22 | *TV45 keymap definition macro (arrows layout) | ||
| 23 | */ | ||
| 24 | #define KEYMAP_TV45( \ | ||
| 25 | K01, K02, K03, K04, K05, K06, K07, K08, K09, K10, K11, K12, \ | ||
| 26 | K13, K14, K15, K16, K17, K18, K19, K20, K21, K22, K23, K24, \ | ||
| 27 | K25, K26, K27, K28, K29, K30, K31, K32, K33, K34, K35, K36, \ | ||
| 28 | K37, K38, K39, K40, K41, K42, K43, K44, K45 \ | ||
| 29 | ) { \ | ||
| 30 | { K01, K02, K03, K04, K05, K06, K07, K08, K09, K10, K11, K12, }, \ | ||
| 31 | { K13, K14, K15, K16, K17, K18, K19, K20, K21, K22, K23, K24, }, \ | ||
| 32 | { K25, K26, K27, K28, K29, K30, K31, K32, K33, K34, K35, K36, }, \ | ||
| 33 | { K37, K38, K39, K40, KC_NO, KC_NO, KC_NO, K41, K42, K43, K44, K45 } \ | ||
| 34 | } | ||
| 35 | |||
| 36 | #endif | ||
diff --git a/keyboards/tv44/keymaps/smt/keyboard-layout-minivan.png b/keyboards/tv44/keymaps/smt/keyboard-layout-minivan.png new file mode 100644 index 000000000..2dca67fb6 --- /dev/null +++ b/keyboards/tv44/keymaps/smt/keyboard-layout-minivan.png | |||
| Binary files differ | |||
diff --git a/keyboards/tv44/keymaps/smt/keymap.c b/keyboards/tv44/keymaps/smt/keymap.c new file mode 100644 index 000000000..de5ce03e2 --- /dev/null +++ b/keyboards/tv44/keymaps/smt/keymap.c | |||
| @@ -0,0 +1,232 @@ | |||
| 1 | #include "tv44.h" | ||
| 2 | #include "action_layer.h" | ||
| 3 | #include "eeconfig.h" | ||
| 4 | |||
| 5 | extern keymap_config_t keymap_config; | ||
| 6 | |||
| 7 | // Each layer gets a name for readability, which is then used in the keymap matrix below. | ||
| 8 | // The underscores don't mean anything - you can have a layer called STUFF or any other name. | ||
| 9 | // Layer names don't all need to be of the same length, obviously, and you can also skip them | ||
| 10 | // entirely and just use numbers. | ||
| 11 | #define _QWERTY 0 | ||
| 12 | #define _COLEMAK 1 | ||
| 13 | #define _DVORAK 2 | ||
| 14 | #define _LOWER 3 | ||
| 15 | #define _RAISE 4 | ||
| 16 | #define _ADJUST 16 | ||
| 17 | |||
| 18 | // Keycodes | ||
| 19 | enum planck_keycodes { | ||
| 20 | QWERTY = SAFE_RANGE, | ||
| 21 | COLEMAK, | ||
| 22 | DVORAK, | ||
| 23 | LOWER, | ||
| 24 | RAISE, | ||
| 25 | BACKLIT | ||
| 26 | }; | ||
| 27 | |||
| 28 | // Fillers to make layering more clear | ||
| 29 | #define _______ KC_TRNS | ||
| 30 | #define XXXXXXX KC_NO | ||
| 31 | |||
| 32 | // Custom macros | ||
| 33 | #define CTL_ESC CTL_T(KC_ESC) // Tap for Esc, hold for Ctrl | ||
| 34 | #define SFT_ENT SFT_T(KC_ENT) // Tap for Enter, hold for Shift | ||
| 35 | #define HPR_TAB ALL_T(KC_TAB) // Tap for Tab, hold for Hyper | ||
| 36 | #define ALT_GRV ALT_T(KC_GRV) // Tap for Backtick, hold for Alt | ||
| 37 | |||
| 38 | const uint16_t PROGMEM keymaps[][MATRIX_ROWS][MATRIX_COLS] = { | ||
| 39 | |||
| 40 | /* Qwerty | ||
| 41 | * | ||
| 42 | * ,---------+------+------+------+------+------+------+------+------+------+------+---------. | ||
| 43 | * |Hyper/Tab| Q | W | E | R | T | Y | U | I | O | P | Bksp | | ||
| 44 | * |---------`------`------`------`------`------`------`------`------`------`------`---------| | ||
| 45 | * | Ctrl/Esc | A | S | D | F | G | H | J | K | L | ; | ' | | ||
| 46 | * |----------`------`------`------`------`------`------`------`------`------`------`--------| | ||
| 47 | * | Shift | Z | X | C | V | B | N | M | , | . | / |Sft/Ent| | ||
| 48 | * |-----------`------`------`------`------`-----'-------`------`------`------`------`-------| | ||
| 49 | * | Alt/` | GUI | Lower | Space | Space | Raise | GUI | Alt | Ctrl | | ||
| 50 | * `-------+---------+--------+-----^^^------+-----^^^------+---------+------+------+-------' | ||
| 51 | */ | ||
| 52 | [_QWERTY] = KEYMAP_TV45( | ||
| 53 | /*,--------+-------+--------+--------+--------+--------+--------+--------+--------+--------+--------+-----------------.*/ | ||
| 54 | HPR_TAB, KC_Q, KC_W, KC_E, KC_R, KC_T, KC_Y, KC_U, KC_I, KC_O, KC_P, KC_BSPC , | ||
| 55 | /*|--------`-------`--------`--------`--------`--------`--------`--------`--------`--------`--------`-----------------|*/ | ||
| 56 | CTL_ESC , KC_A, KC_S, KC_D, KC_F, KC_G, KC_H, KC_J, KC_K, KC_L, KC_SCLN, KC_QUOT , | ||
| 57 | /*|---------`-------`--------`--------`--------`--------`--------`--------`--------`--------`--------`----------------|*/ | ||
| 58 | KC_LSFT , KC_Z, KC_X, KC_C, KC_V, KC_B, KC_N, KC_M, KC_COMM, KC_DOT, KC_SLSH, SFT_ENT , | ||
| 59 | /*|----------`-------`--------`--------`--------`--------`--------`--------`--------`--------`--------`---------------|*/ | ||
| 60 | ALT_GRV , KC_LGUI , LOWER , KC_SPC , KC_SPC , RAISE , KC_RGUI, KC_RALT, KC_RCTL ), | ||
| 61 | /*`---------+---------------+---------+-------^^^------+-------^^^-------+----------+--------+--------+--------------'*/ | ||
| 62 | |||
| 63 | /* Colemak | ||
| 64 | * ,---------+------+------+------+------+------+------+------+------+------+------+---------. | ||
| 65 | * |Hyper/Tab| Q | W | F | P | G | J | L | U | Y | ; | Bksp | | ||
| 66 | * |---------`------`------`------`------`------`------`------`------`------`------`---------| | ||
| 67 | * | Ctrl/Esc | A | R | S | T | D | H | N | E | I | O | ' | | ||
| 68 | * |----------`------`------`------`------`------`------`------`------`------`------`--------| | ||
| 69 | * | Shift | Z | X | C | V | B | K | M | , | . | / |Sft/Ent| | ||
| 70 | * |-----------`------`------`------`------`-----'-------`------`------`------`------`-------| | ||
| 71 | * | Alt/` | GUI | Lower | Space | Space | Raise | GUI | Alt | Ctrl | | ||
| 72 | * `-------+---------+--------+-----^^^------+-----^^^------+---------+------+------+-------' | ||
| 73 | */ | ||
| 74 | [_COLEMAK] = KEYMAP_TV45( | ||
| 75 | /*,--------+-------+--------+--------+--------+--------+--------+--------+--------+--------+--------+-----------------.*/ | ||
| 76 | HPR_TAB, KC_Q, KC_W, KC_F, KC_P, KC_G, KC_J, KC_L, KC_U, KC_Y, KC_SCLN, KC_BSPC , | ||
| 77 | /*|--------`-------`--------`--------`--------`--------`--------`--------`--------`--------`--------`-----------------|*/ | ||
| 78 | CTL_ESC , KC_A, KC_R, KC_S, KC_T, KC_D, KC_H, KC_N, KC_E, KC_I, KC_O, KC_QUOT , | ||
| 79 | /*|---------`-------`--------`--------`--------`--------`--------`--------`--------`--------`--------`----------------|*/ | ||
| 80 | KC_LSFT , KC_Z, KC_X, KC_C, KC_V, KC_B, KC_K, KC_M, KC_COMM, KC_DOT, KC_SLSH, SFT_ENT , | ||
| 81 | /*|----------`-------`--------`--------`--------`--------`--------`--------`--------`--------`--------`---------------|*/ | ||
| 82 | ALT_GRV , KC_LGUI , LOWER , KC_SPC , KC_SPC , RAISE , KC_RGUI, KC_RALT, KC_RCTL ), | ||
| 83 | /*`---------+---------------+---------+-------^^^------+-------^^^-------+----------+--------+--------+--------------'*/ | ||
| 84 | |||
| 85 | /* Dvorak | ||
| 86 | * ,---------+------+------+------+------+------+------+------+------+------+------+---------. | ||
| 87 | * |Hyper/Tab| ' | , | . | P | Y | F | G | C | R | L | Bksp | | ||
| 88 | * |---------`------`------`------`------`------`------`------`------`------`------`---------| | ||
| 89 | * | Ctrl/Esc | A | O | E | U | I | D | H | T | N | S | - | | ||
| 90 | * |----------`------`------`------`------`------`------`------`------`------`------`--------| | ||
| 91 | * | Shift | ; | Q | J | K | X | B | M | W | V | Z |Sft/Ent| | ||
| 92 | * |-----------`------`------`------`------`-----'-------`------`------`------`------`-------| | ||
| 93 | * | Alt/` | GUI | Lower | Space | Space | Raise | GUI | Alt | Ctrl | | ||
| 94 | * `-------+---------+--------+-----^^^------+-----^^^------+---------+------+------+-------' | ||
| 95 | */ | ||
| 96 | [_DVORAK] = KEYMAP_TV45( | ||
| 97 | /*,--------+-------+--------+--------+--------+--------+--------+--------+--------+--------+--------+-----------------.*/ | ||
| 98 | HPR_TAB,KC_QUOT, KC_COMM, KC_DOT, KC_P, KC_Y, KC_F, KC_G, KC_C, KC_R, KC_L, KC_BSPC , | ||
| 99 | /*|--------`-------`--------`--------`--------`--------`--------`--------`--------`--------`--------`-----------------|*/ | ||
| 100 | CTL_ESC , KC_A, KC_O, KC_E, KC_U, KC_I, KC_D, KC_H, KC_T, KC_N, KC_S, KC_MINS , | ||
| 101 | /*|---------`-------`--------`--------`--------`--------`--------`--------`--------`--------`--------`----------------|*/ | ||
| 102 | KC_LSFT , KC_SCLN, KC_Q, KC_J, KC_K, KC_X, KC_B, KC_M, KC_W, KC_V, KC_Z, SFT_ENT , | ||
| 103 | /*|----------`-------`--------`--------`--------`--------`--------`--------`--------`--------`--------`---------------|*/ | ||
| 104 | ALT_GRV , KC_LGUI , LOWER , KC_SPC , KC_SPC , RAISE , KC_RGUI, KC_RALT, KC_RCTL ), | ||
| 105 | /*`---------+---------------+---------+-------^^^------+-------^^^-------+----------+--------+--------+--------------'*/ | ||
| 106 | |||
| 107 | /* Lower | ||
| 108 | * ,---------+------+------+------+------+------+------+------+------+------+------+---------. | ||
| 109 | * | 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 0 | Del | | ||
| 110 | * |---------`------`------`------`------`------`------`------`------`------`------`---------| | ||
| 111 | * | $ | 4 | 5 | 6 | . | + | * | 4 | 5 | 6 | . | PageUp | | ||
| 112 | * |----------`------`------`------`------`------`------`------`------`------`------`--------| | ||
| 113 | * | = | 7 | 8 | 9 | 0 | - | / | 1 | 2 | 3 | Up |PageDn | | ||
| 114 | * |-----------`------`------`------`------`-----'-------`------`------`------`------`-------| | ||
| 115 | * | Brite | | | Home | End | | Left | Down | Right | | ||
| 116 | * `-------+---------+--------+-----^^^------+-----^^^------+---------+------+------+-------' | ||
| 117 | */ | ||
| 118 | [_LOWER] = KEYMAP_TV45( | ||
| 119 | /*,--------+-------+--------+--------+--------+--------+--------+--------+--------+--------+--------+-----------------.*/ | ||
| 120 | KC_0 , KC_1, KC_2, KC_3, KC_4, KC_5, KC_6, KC_7, KC_8, KC_9, KC_0, KC_DEL , | ||
| 121 | /*|--------`-------`--------`--------`--------`--------`--------`--------`--------`--------`--------`-----------------|*/ | ||
| 122 | KC_DLR , KC_4, KC_5, KC_6, KC_DOT, KC_PLUS, KC_ASTR, KC_4, KC_5, KC_6, KC_DOT, KC_PGUP , | ||
| 123 | /*|---------`-------`--------`--------`--------`--------`--------`--------`--------`--------`--------`----------------|*/ | ||
| 124 | KC_EQL , KC_7, KC_8, KC_9, KC_0, KC_MINS, KC_SLSH, KC_1, KC_2, KC_3, KC_UP, KC_PGDN , | ||
| 125 | /*|----------`-------`--------`--------`--------`--------`--------`--------`--------`--------`--------`---------------|*/ | ||
| 126 | BACKLIT , _______ , _______ , KC_HOME , KC_END , _______ , KC_LEFT, KC_DOWN, KC_RGHT ), | ||
| 127 | /*`---------+---------------+---------+-------^^^------+-------^^^-------+----------+--------+--------+--------------'*/ | ||
| 128 | |||
| 129 | /* Raise | ||
| 130 | * ,---------+------+------+------+------+------+------+------+------+------+------+---------. | ||
| 131 | * | ~ | ! | @ | # | $ | % | ^ | & | * | ( | ) | Del | | ||
| 132 | * |---------`------`------`------`------`------`------`------`------`------`------`---------| | ||
| 133 | * | F1 | F2 | F3 | F4 | F5 | F6 | _ | ? | + | { | } | | | ||
| 134 | * |----------`------`------`------`------`------`------`------`------`------`------`--------| | ||
| 135 | * | F7 | F8 | F9 | F10 | F11 | F12 | - | / | = | [ | ] | | | ||
| 136 | * |-----------`------`------`------`------`-----'-------`------`------`------`------`-------| | ||
| 137 | * | Brite | | | Play | Next | | Mute | Vol- | Vol+ | | ||
| 138 | * `-------+---------+--------+-----^^^------+-----^^^------+---------+------+------+-------' | ||
| 139 | */ | ||
| 140 | [_RAISE] = KEYMAP_TV45( | ||
| 141 | /*,--------+-------+--------+--------+--------+--------+--------+--------+--------+--------+--------+-----------------.*/ | ||
| 142 | KC_TILD,KC_EXLM, KC_AT, KC_HASH, KC_DLR, KC_PERC, KC_CIRC, KC_AMPR, KC_ASTR, KC_LPRN, KC_RPRN, KC_DEL , | ||
| 143 | /*|--------`-------`--------`--------`--------`--------`--------`--------`--------`--------`--------`-----------------|*/ | ||
| 144 | KC_F1, KC_F2, KC_F3, KC_F4, KC_F5, KC_F6, KC_UNDS, KC_QUES, KC_PLUS, KC_LCBR, KC_RCBR, KC_PIPE , | ||
| 145 | /*|---------`-------`--------`--------`--------`--------`--------`--------`--------`--------`--------`----------------|*/ | ||
| 146 | KC_F7, KC_F8, KC_F9, KC_F10, KC_F11, KC_F12, KC_MINS, KC_SLSH, KC_EQL, KC_LBRC, KC_RBRC, KC_BSLS , | ||
| 147 | /*|----------`-------`--------`--------`--------`--------`--------`--------`--------`--------`--------`---------------|*/ | ||
| 148 | BACKLIT , _______ , _______ , KC_MPLY , KC_MNXT , _______ , KC_MUTE, KC_VOLD, KC_VOLU ), | ||
| 149 | /*`---------+---------------+---------+-------^^^------+-------^^^-------+----------+--------+--------+--------------'*/ | ||
| 150 | |||
| 151 | /* Adjust (Lower + Raise) | ||
| 152 | * ,---------+------+------+------+------+------+------+------+------+------+------+---------. | ||
| 153 | * | | Reset| | | | | | | | | | Del | | ||
| 154 | * |---------`------`------`------`------`------`------`------`------`------`------`---------| | ||
| 155 | * | | | | | |AGnorm|AGswap|Qwerty|Colemk|Dvorak| | | | ||
| 156 | * |----------`------`------`------`------`------`------`------`------`------`------`--------| | ||
| 157 | * | | | | | | | | | | | | | | ||
| 158 | * |-----------`------`------`------`------`-----'-------`------`------`------`------`-------| | ||
| 159 | * | | | | | | | | | | | ||
| 160 | * `-------+---------+--------+-----^^^------+-----^^^------+---------+------+------+-------' | ||
| 161 | */ | ||
| 162 | [_ADJUST] = KEYMAP_TV45( | ||
| 163 | /*,--------+-------+--------+--------+--------+--------+--------+--------+--------+--------+--------+-----------------.*/ | ||
| 164 | _______, RESET , _______, _______, _______, _______, _______, _______, _______, _______, _______, KC_DEL , | ||
| 165 | /*|--------`-------`--------`--------`--------`--------`--------`--------`--------`--------`--------`-----------------|*/ | ||
| 166 | _______ ,_______, _______, _______, _______, AG_NORM, AG_SWAP, QWERTY, COLEMAK, DVORAK, _______, _______ , | ||
| 167 | /*|---------`-------`--------`--------`--------`--------`--------`--------`--------`--------`--------`----------------|*/ | ||
| 168 | _______ ,_______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______ , | ||
| 169 | /*|----------`-------`--------`--------`--------`--------`--------`--------`--------`--------`--------`---------------|*/ | ||
| 170 | _______ , _______ , _______ , _______ , _______ , _______ , _______, _______, _______ ), | ||
| 171 | /*`---------+---------------+---------+-------^^^------+-------^^^-------+----------+--------+--------+--------------'*/ | ||
| 172 | }; | ||
| 173 | |||
| 174 | void persistant_default_layer_set(uint16_t default_layer) { | ||
| 175 | eeconfig_update_default_layer(default_layer); | ||
| 176 | default_layer_set(default_layer); | ||
| 177 | } | ||
| 178 | |||
| 179 | bool process_record_user(uint16_t keycode, keyrecord_t *record) { | ||
| 180 | switch (keycode) { | ||
| 181 | case QWERTY: | ||
| 182 | if (record->event.pressed) { | ||
| 183 | persistant_default_layer_set(1UL<<_QWERTY); | ||
| 184 | } | ||
| 185 | return false; | ||
| 186 | break; | ||
| 187 | case COLEMAK: | ||
| 188 | if (record->event.pressed) { | ||
| 189 | persistant_default_layer_set(1UL<<_COLEMAK); | ||
| 190 | } | ||
| 191 | return false; | ||
| 192 | break; | ||
| 193 | case DVORAK: | ||
| 194 | if (record->event.pressed) { | ||
| 195 | persistant_default_layer_set(1UL<<_DVORAK); | ||
| 196 | } | ||
| 197 | return false; | ||
| 198 | break; | ||
| 199 | case LOWER: | ||
| 200 | if (record->event.pressed) { | ||
| 201 | layer_on(_LOWER); | ||
| 202 | update_tri_layer(_LOWER, _RAISE, _ADJUST); | ||
| 203 | } else { | ||
| 204 | layer_off(_LOWER); | ||
| 205 | update_tri_layer(_LOWER, _RAISE, _ADJUST); | ||
| 206 | } | ||
| 207 | return false; | ||
| 208 | break; | ||
| 209 | case RAISE: | ||
| 210 | if (record->event.pressed) { | ||
| 211 | layer_on(_RAISE); | ||
| 212 | update_tri_layer(_LOWER, _RAISE, _ADJUST); | ||
| 213 | } else { | ||
| 214 | layer_off(_RAISE); | ||
| 215 | update_tri_layer(_LOWER, _RAISE, _ADJUST); | ||
| 216 | } | ||
| 217 | return false; | ||
| 218 | break; | ||
| 219 | case BACKLIT: | ||
| 220 | if (record->event.pressed) { | ||
| 221 | register_code(KC_RSFT); | ||
| 222 | #ifdef BACKLIGHT_ENABLE | ||
| 223 | backlight_step(); | ||
| 224 | #endif | ||
| 225 | } else { | ||
| 226 | unregister_code(KC_RSFT); | ||
| 227 | } | ||
| 228 | return false; | ||
| 229 | break; | ||
| 230 | } | ||
| 231 | return true; | ||
| 232 | } | ||
diff --git a/keyboards/tv44/keymaps/smt/readme.md b/keyboards/tv44/keymaps/smt/readme.md new file mode 100644 index 000000000..647eb8976 --- /dev/null +++ b/keyboards/tv44/keymaps/smt/readme.md | |||
| @@ -0,0 +1,126 @@ | |||
| 1 | # smt's TV44 keymap | ||
| 2 | |||
| 3 | This keymap is based on a combination of my Planck keymap and [jeebak's TV44 layout](https://github.com/qmk/qmk_firmware/tree/master/keyboards/tv44/keymaps/jeebak). I removed the macros and TouchCursor/MouseCursor layers, because I'm just not ready for that level of mind-mapping. | ||
| 4 | |||
| 5 | I had been using something close to the default Minivan layout, but after spending a bit of time with the Planck and Preonic, I decided it would be better for me to try to standardize to some degree, where possible. | ||
| 6 | |||
| 7 | Also, it's worth noting that my Minivan is one with the "arrows" layout, which has a 45th key, so I had to define a new KEYMAP_TV45 macro in config.h. In spite of this, the 45-key Minivan is still technically considered a "TV44" as far as I know. | ||
| 8 | |||
| 9 |  | ||
| 10 | |||
| 11 | ## Notable features (most of which can be found in my or jeebak's respective keymap file): | ||
| 12 | |||
| 13 | 1. **Shift/Enter** | ||
| 14 | |||
| 15 | I use both the left and right shift keys when I type. When I want to modify a key with shift, I hold shift with the hand opposite the one typing the key. In the default keymap, Enter is where shift would be on a standard keyboard layout. Oh, muscle memory. | ||
| 16 | |||
| 17 | Thankfully, QMK supports [mod-tap](https://github.com/jackhumbert/qmk_firmware/wiki#fun-with-modifier-keys) keys, and this allows me to set the Enter key to send a modifier (MOD_LSFT) when held, and KC_ENT when tapped. Awesome! | ||
| 18 | |||
| 19 | 2. **Hyper/Tab** | ||
| 20 | |||
| 21 | This key modifies with "Hyper" (see [Brett Terpstra's post](http://brettterpstra.com/2012/12/08/a-useful-caps-lock-key/) on this) when held, and outputs the code for Tab when tapped. On the Mac, I use KeyboardMaestro to remap my hyper-keys to do a lot of crazy things. | ||
| 22 | |||
| 23 | 3. **Ctrl/Escape** | ||
| 24 | |||
| 25 | I set up another mod-tap, this time for the Escape key that would act as a Control modifier when held. | ||
| 26 | |||
| 27 | 4. **Alt/Backtick** | ||
| 28 | |||
| 29 | I don't currently have LEDs on most of my keyboards, and I certainly don't want LED controls on the base layer of a 40%. | ||
| 30 | |||
| 31 | So, why use backtick in the lower left corner? I use it as my tmux prefix key, so I need to type it more frequently than most people. Putting it on the base layer works well for my use case, and it's consistent with where I place it in my Planck and Preonic keymaps. | ||
| 32 | |||
| 33 | I also like Alt in that position, so it works well as yet another mod-tap key. | ||
| 34 | |||
| 35 | |||
| 36 | ## Layers | ||
| 37 | |||
| 38 | ### Qwerty | ||
| 39 | |||
| 40 | ``` | ||
| 41 | ,---------+------+------+------+------+------+------+------+------+------+------+---------. | ||
| 42 | |Hyper/Tab| Q | W | E | R | T | Y | U | I | O | P | Bksp | | ||
| 43 | |---------`------`------`------`------`------`------`------`------`------`------`---------| | ||
| 44 | | Ctrl/Esc | A | S | D | F | G | H | J | K | L | ; | ' | | ||
| 45 | |----------`------`------`------`------`------`------`------`------`------`------`--------| | ||
| 46 | | Shift | Z | X | C | V | B | N | M | , | . | / |Sft/Ent| | ||
| 47 | |-----------`------`------`------`------`-----'-------`------`------`------`------`-------| | ||
| 48 | | Alt/` | GUI | Lower | Space | Space | Raise | GUI | Alt | Ctrl | | ||
| 49 | `-------+---------+--------+-----^^^------+-----^^^------+---------+------+------+-------' | ||
| 50 | ``` | ||
| 51 | |||
| 52 | ### Colemak | ||
| 53 | |||
| 54 | ``` | ||
| 55 | ,---------+------+------+------+------+------+------+------+------+------+------+---------. | ||
| 56 | |Hyper/Tab| Q | W | F | P | G | J | L | U | Y | ; | Bksp | | ||
| 57 | |---------`------`------`------`------`------`------`------`------`------`------`---------| | ||
| 58 | | Ctrl/Esc | A | R | S | T | D | H | N | E | I | O | ' | | ||
| 59 | |----------`------`------`------`------`------`------`------`------`------`------`--------| | ||
| 60 | | Shift | Z | X | C | V | B | K | M | , | . | / |Sft/Ent| | ||
| 61 | |-----------`------`------`------`------`-----'-------`------`------`------`------`-------| | ||
| 62 | | Alt/` | GUI | Lower | Space | Space | Raise | GUI | Alt | Ctrl | | ||
| 63 | `-------+---------+--------+-----^^^------+-----^^^------+---------+------+------+-------' | ||
| 64 | ``` | ||
| 65 | |||
| 66 | ### Dvorak | ||
| 67 | |||
| 68 | ``` | ||
| 69 | ,---------+------+------+------+------+------+------+------+------+------+------+---------. | ||
| 70 | |Hyper/Tab| ' | , | . | P | Y | F | G | C | R | L | Bksp | | ||
| 71 | |---------`------`------`------`------`------`------`------`------`------`------`---------| | ||
| 72 | | Ctrl/Esc | A | O | E | U | I | D | H | T | N | S | - | | ||
| 73 | |----------`------`------`------`------`------`------`------`------`------`------`--------| | ||
| 74 | | Shift | ; | Q | J | K | X | B | M | W | V | Z |Sft/Ent| | ||
| 75 | |-----------`------`------`------`------`-----'-------`------`------`------`------`-------| | ||
| 76 | | Alt/` | GUI | Lower | Space | Space | Raise | GUI | Alt | Ctrl | | ||
| 77 | `-------+---------+--------+-----^^^------+-----^^^------+---------+------+------+-------' | ||
| 78 | ``` | ||
| 79 | |||
| 80 | ### Lower | ||
| 81 | |||
| 82 | This is where I put the number row, two numpad clusters, common arithmetic operators, and cursorkeys: Arrow cluster, Home/End, Page Up/Page Down. `0` and `$` are also placed on the left side for convenient access to beginning-of-line and end-of-line Vim commands. BRITE has been moved here from the base layer. | ||
| 83 | |||
| 84 | ``` | ||
| 85 | ,---------+------+------+------+------+------+------+------+------+------+------+---------. | ||
| 86 | | 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 0 | Del | | ||
| 87 | |---------`------`------`------`------`------`------`------`------`------`------`---------| | ||
| 88 | | $ | 4 | 5 | 6 | . | + | * | 4 | 5 | 6 | . | PageUp | | ||
| 89 | |----------`------`------`------`------`------`------`------`------`------`------`--------| | ||
| 90 | | = | 7 | 8 | 9 | 0 | - | / | 1 | 2 | 3 | Up |PageDn | | ||
| 91 | |-----------`------`------`------`------`-----'-------`------`------`------`------`-------| | ||
| 92 | | Brite | | | Home | End | | Left | Down | Right | | ||
| 93 | `-------+---------+--------+-----^^^------+-----^^^------+---------+------+------+-------' | ||
| 94 | ``` | ||
| 95 | |||
| 96 | ### Raise | ||
| 97 | |||
| 98 | As a developer, it makes the most sense for me to group all the commonly-used symbols that don't fit on the main layer. In particular, having the dual-column of parens-braces-brackets helps me keep them straight. I've dropped basic media controls onto this layer as well. | ||
| 99 | |||
| 100 | ``` | ||
| 101 | ,---------+------+------+------+------+------+------+------+------+------+------+---------. | ||
| 102 | | ~ | ! | @ | # | $ | % | ^ | & | * | ( | ) | Del | | ||
| 103 | |---------`------`------`------`------`------`------`------`------`------`------`---------| | ||
| 104 | | F1 | F2 | F3 | F4 | F5 | F6 | _ | ? | + | { | } | | | | ||
| 105 | |----------`------`------`------`------`------`------`------`------`------`------`--------| | ||
| 106 | | F7 | F8 | F9 | F10 | F11 | F12 | - | / | = | [ | ] | \ | | ||
| 107 | |-----------`------`------`------`------`-----'-------`------`------`------`------`-------| | ||
| 108 | | Brite | | | Play | Next | | Mute | Vol- | Vol+ | | ||
| 109 | `-------+---------+--------+-----^^^------+-----^^^------+---------+------+------+-------' | ||
| 110 | ``` | ||
| 111 | |||
| 112 | ### Adjust (Lower + Raise) | ||
| 113 | |||
| 114 | Utility layer. There isn't much here; it's mainly for swapping the default keymap between Qwerty and Dvorak, or putting the keyboard into flash mode via the Reset key. | ||
| 115 | |||
| 116 | ``` | ||
| 117 | ,---------+------+------+------+------+------+------+------+------+------+------+---------. | ||
| 118 | | | Reset| | | | | | | | | | Del | | ||
| 119 | |---------`------`------`------`------`------`------`------`------`------`------`---------| | ||
| 120 | | | | | | |AGnorm|AGswap|Qwerty|Colemk|Dvorak| | | | ||
| 121 | |----------`------`------`------`------`------`------`------`------`------`------`--------| | ||
| 122 | | | | | | | | | | | | | | | ||
| 123 | |-----------`------`------`------`------`-----'-------`------`------`------`------`-------| | ||
| 124 | | | | | | | | | | | | ||
| 125 | `-------+---------+--------+-----^^^------+-----^^^------+---------+------+------+-------' | ||
| 126 | ``` | ||
| @@ -1,6 +1,6 @@ | |||
| 1 | # Quantum Mechanical Keyboard Firmware | 1 | # Quantum Mechanical Keyboard Firmware |
| 2 | 2 | ||
| 3 | [](https://travis-ci.org/jackhumbert/qmk_firmware) [](https://gitter.im/qmk/qmk_firmware?utm_source=badge&utm_medium=badge&utm_campaign=pr-badge) | 3 | [](https://travis-ci.org/jackhumbert/qmk_firmware) [](https://gitter.im/qmk/qmk_firmware?utm_source=badge&utm_medium=badge&utm_campaign=pr-badge) |
| 4 | 4 | ||
| 5 | This is a keyboard firmware based on the [tmk_keyboard firmware](http://github.com/tmk/tmk_keyboard) with some useful features for Atmel AVR controllers, and more specifically, the [OLKB product line](http://olkb.com), the [ErgoDox EZ](http://www.ergodox-ez.com) keyboard, and the [Clueboard product line](http://clueboard.co/). | 5 | This is a keyboard firmware based on the [tmk_keyboard firmware](http://github.com/tmk/tmk_keyboard) with some useful features for Atmel AVR controllers, and more specifically, the [OLKB product line](http://olkb.com), the [ErgoDox EZ](http://www.ergodox-ez.com) keyboard, and the [Clueboard product line](http://clueboard.co/). |
| 6 | 6 | ||
