From 826417bfc001377719c9034fe273d1596ba62c9c Mon Sep 17 00:00:00 2001 From: IBNobody Date: Tue, 18 Oct 2016 16:45:45 -0500 Subject: [PATCH 01/15] Updating Vision keyboard files --- .../vision_division/keymaps/default/Makefile | 4 +- .../vision_division/keymaps/default/keymap.c | 195 ++++++++++-------- 2 files changed, 108 insertions(+), 91 deletions(-) diff --git a/keyboards/vision_division/keymaps/default/Makefile b/keyboards/vision_division/keymaps/default/Makefile index 5a930e85ed..28060947af 100644 --- a/keyboards/vision_division/keymaps/default/Makefile +++ b/keyboards/vision_division/keymaps/default/Makefile @@ -2,7 +2,7 @@ # change to "no" to disable the options, or define them in the Makefile in # the appropriate keymap folder that will get included automatically # -BOOTMAGIC_ENABLE = yes # Virtual DIP switch configuration(+1000) +BOOTMAGIC_ENABLE = no # Virtual DIP switch configuration(+1000) MOUSEKEY_ENABLE = yes # Mouse keys(+4700) EXTRAKEY_ENABLE = yes # Audio control and System control(+450) CONSOLE_ENABLE = yes # Console for debug(+400) @@ -18,4 +18,4 @@ SLEEP_LED_ENABLE = no # Breathing sleep LED during USB suspend ifndef QUANTUM_DIR include ../../../../Makefile -endif \ No newline at end of file +endif diff --git a/keyboards/vision_division/keymaps/default/keymap.c b/keyboards/vision_division/keymaps/default/keymap.c index 64118abdce..8622ee5211 100644 --- a/keyboards/vision_division/keymaps/default/keymap.c +++ b/keyboards/vision_division/keymaps/default/keymap.c @@ -121,6 +121,7 @@ enum keyboard_macros { #define M_CP_CT M(MACRO_COPY_CUT) +#define M_COPY KC_FN1 #define SC_UNDO LCTL(KC_Z) #define SC_REDO LCTL(KC_Y) @@ -145,31 +146,31 @@ const uint16_t PROGMEM keymaps[][MATRIX_ROWS][MATRIX_COLS] = { /* LAYER = LAYER_QWERTY .-----------------------------------. .-----------------------------------------------------------------------------------------------------------------------------. .-----------------------------------. - | FN | PRINT | SCR LK | PAUSE | | F1 | F2 | F3 | F4 | XXXXXX | F5 | F6 | F7 | F8 | XXXXXX | F9 | F10 | F11 | F12 | | VOL DN | MUTE | VOL UP | BACKLT | + | VOL DN | MUTE | VOL UP | BACKLT | | F1 | F2 | F3 | F4 | XXXXXX | F5 | F6 | F7 | F8 | XXXXXX | F9 | F10 | F11 | F12 | | PRINT | SCR LK | PAUSE | FN | '-----------------------------------' '-----------------------------------------------------------------------------------------------------------------------------' '-----------------------------------' .-----------------------------------. .-----------------------------------------------------------------------------------------------------------------------------. .-----------------------------------. - | M1 | INS | HOME | PG UP | | ESC | ` | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 0 | = | BACKSP | | NUM LK | KP / | KP * | KP - | + | NUM LK | KP / | KP * | KP - | | ESC | ` | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 0 | = | BACKSP | | INS | HOME | PG UP | M1 | |--------+--------+--------+--------| |--------+--------+--------+--------+--------+--------+--------+--------+--------+--------+--------+--------+--------+--------| |--------|--------|--------+--------| - | M2 | DEL | END | PG DN | | TAB | TAB | Q | W | E | R | T | Y | U | I | O | P | - | \ | | KP 7 | KP 8 | KP 9 | KP + | + | KP 7 | KP 8 | KP 9 | KP + | | TAB | TAB | Q | W | E | R | T | Y | U | I | O | P | - | \ | | DEL | END | PG DN | M2 | |--------+--------+--------+--------| |--------+--------+--------+--------+--------+--------+--------+--------+--------+--------+--------+--------+--------+--------| o |--------|--------|--------+--------| - | M3 | UL | UP | UR | | CAP LK | BACKSP | A | S | D | F | G | H | J | K | L | ; | ' | ENTER | o | KP 4 | KP 5 | KP 6 | KP + | + | KP 4 | KP 5 | KP 6 | KP + | | CAP LK | BACKSP | A | S | D | F | G | H | J | K | L | ; | ' | ENTER | o | CP/CT | UNDO | PASTE | M3 | |--------+--------+--------+--------| |--------+--------+--------+--------+--------+--------+--------+--------+--------+--------+--------+--------+--------+--------| o |--------|--------|--------+--------| - | M4 | LEFT | CP/CT | RIGHT | | LSHIFT | LSHIFT | Z | X | C | V | B | N | M | , | . | / | RSHIFT | RSHIFT | | KP 1 | KP 2 | KP 3 | KP Ent | + | KP 1 | KP 2 | KP 3 | KP Ent | | LSHIFT | LSHIFT | Z | X | C | V | B | N | M | , | . | / | RSHIFT | RSHIFT | | XXXXXX | UP | XXXXXX | M4 | |--------+--------+--------+--------| |--------+--------+--------+--------+--------+--------+--------+--------+--------+--------+--------+--------+--------+--------| |--------|--------|--------+--------| - | M5 | DL | DOWN | DR | | LCTRL | XXXXXX | XXXXXX | LWIN | LALT | LOWER | SPACE . SPACE | UPPER | OSHIFT | RALT | APP | XXXXXX | RCTRL | | KP 0 | KP , | KP . | KP Ent | + | KP 0 | KP , | KP . | KP Ent | | LCTRL | XXXXXX | LWIN | XXXXXX | LALT | UPPER | SPACE . SPACE | LOWER | OSHIFT | RALT | APP | XXXXXX | RCTRL | | LEFT | DOWN | RIGHT | M5 | '-----------------------------------' '-----------------------------------------------------------------------------------------------------------------------------' '-----------------------------------' */ KEYMAP(LAYER_QWERTY, \ - M_HELP , KC_PSCR, KC_SLCK, KC_PAUS, KC_F1 , KC_F2 , KC_F3 , KC_F4 , XXXXXXX, KC_F5 , KC_F6 , KC_F7 , KC_F8 , XXXXXXX, KC_F9 , KC_F10 , KC_F11 , KC_F12 , KC_VOLD, KC_MUTE, KC_VOLU, M_BACKL, \ - M_M1 , KC_INS , KC_HOME, KC_PGUP, KC_ESC , KC_GRV , KC_1 , KC_2 , KC_3 , KC_4 , KC_5 , KC_6 , KC_7 , KC_8 , KC_9 , KC_0 , KC_EQL , KC_BSPC, KC_NLCK, KC_PSLS, KC_PAST, KC_PMNS, \ - M_M2 , KC_DEL , KC_END , KC_PGDN, KC_TAB , KC_TAB , KC_Q , KC_W , KC_E , KC_R , KC_T , KC_Y , KC_U , KC_I , KC_O , KC_P , KC_MINS, KC_BSLS, KC_KP_7, KC_KP_8, KC_KP_9, KC_PPLS, \ - M_M3 , M_UL , KC_UP , M_UR , KC_CAPS, KC_BSPC, KC_A , KC_S , KC_D , KC_F , KC_G , KC_H , KC_J , KC_K , KC_L , KC_SCLN, KC_QUOT, KC_ENT , KC_KP_4, KC_KP_5, KC_KP_6, KC_PPLS, \ - M_M4 , KC_LEFT, M_CP_CT, KC_RGHT, KC_LSFT, KC_LSFT, KC_Z , KC_X , KC_C , KC_V , KC_B , KC_N , KC_M , KC_COMM, KC_DOT , KC_SLSH, KC_RSFT, KC_RSFT, KC_KP_1, KC_KP_2, KC_KP_3, KC_PENT, \ - M_M5 , M_DL , KC_DOWN, M_DR , KC_LCTL, XXXXXXX, XXXXXXX, KC_LGUI, KC_LALT, M_LOWER, KC_SPC , KC_SPC , M_UPPER, OS_SHFT, KC_RALT, KC_APP , XXXXXXX, KC_RCTL, KC_KP_0, KC_PCMM, KC_PDOT, KC_PENT \ + KC_VOLD, KC_MUTE, KC_VOLU, M_BACKL, KC_F1 , KC_F2 , KC_F3 , KC_F4 , XXXXXXX, KC_F5 , KC_F6 , KC_F7 , KC_F8 , XXXXXXX, KC_F9 , KC_F10 , KC_F11 , KC_F12 , KC_PSCR, KC_SLCK, KC_PAUS, M_HELP , \ + KC_NLCK, KC_PSLS, KC_PAST, KC_PMNS, KC_ESC , KC_GRV , KC_1 , KC_2 , KC_3 , KC_4 , KC_5 , KC_6 , KC_7 , KC_8 , KC_9 , KC_0 , KC_EQL , KC_BSPC, KC_INS , KC_HOME, KC_PGUP, M_M1 , \ + KC_KP_7, KC_KP_8, KC_KP_9, KC_PPLS, KC_TAB , KC_TAB , KC_Q , KC_W , KC_E , KC_R , KC_T , KC_Y , KC_U , KC_I , KC_O , KC_P , KC_MINS, KC_BSLS, KC_DEL , KC_END , KC_PGDN, M_M2 , \ + KC_KP_4, KC_KP_5, KC_KP_6, KC_PPLS, KC_CAPS, KC_BSPC, KC_A , KC_S , KC_D , KC_F , KC_G , KC_H , KC_J , KC_K , KC_L , KC_SCLN, KC_QUOT, KC_ENT , M_CP_CT, SC_UNDO, SC_PSTE, M_M3 , \ + KC_KP_1, KC_KP_2, KC_KP_3, KC_PENT, KC_LSFT, KC_LSFT, KC_Z , KC_X , KC_C , KC_V , KC_B , KC_N , KC_M , KC_COMM, KC_DOT , KC_SLSH, KC_RSFT, KC_RSFT, XXXXXXX, KC_UP , XXXXXXX, M_M4 , \ + KC_KP_0, KC_PCMM, KC_PDOT, KC_PENT, KC_LCTL, XXXXXXX, KC_LGUI, XXXXXXX, KC_LALT, M_UPPER, KC_SPC , KC_SPC , M_LOWER, OS_SHFT, KC_RALT, KC_APP , XXXXXXX, KC_RCTL, KC_LEFT, KC_DOWN, KC_RGHT, M_M5 \ ), /* LAYER = LAYER_LOWER .-----------------------------------. .-----------------------------------------------------------------------------------------------------------------------------. .-----------------------------------. - | ______ | ______ | ______ | ______ | | F13 | F14 | F15 | F16 | XXXXXX | F17 | F18 | F19 | F20 | XXXXXX | F21 | F22 | F23 | F24 | | ______ | MUTE A | ______ | ______ | + | ______ | MUTE A | ______ | ______ | | F13 | F14 | F15 | F16 | XXXXXX | F17 | F18 | F19 | F20 | XXXXXX | F21 | F22 | F23 | F24 | | ______ | ______ | ______ | ______ | '-----------------------------------' '-----------------------------------------------------------------------------------------------------------------------------' '-----------------------------------' .-----------------------------------. .-----------------------------------------------------------------------------------------------------------------------------. .-----------------------------------. | ______ | ______ | ______ | ______ | | ______ | ______ | ______ | ______ | ______ | ______ | ______ | ______ | ______ | ______ | ______ | ______ | ______ | ______ | | ______ | ______ | ______ | ______ | @@ -180,20 +181,20 @@ KEYMAP(LAYER_QWERTY, \ |--------+--------+--------+--------| |--------+--------+--------+--------+--------+--------+--------+--------+--------+--------+--------+--------+--------+--------| o |--------|--------|--------+--------| | ______ | ______ | ______ | ______ | | ______ | ______ | | | & | ! | ~ | ; | : | = | < | > | ? | ______ | ______ | | ______ | ______ | ______ | ______ | |--------+--------+--------+--------| |--------+--------+--------+--------+--------+--------+--------+--------+--------+--------+--------+--------+--------+--------| |--------|--------|--------+--------| - | ______ | ______ | ______ | ______ | | ______ | XXXXXX | XXXXXX | ______ | ______ | ______ | ______ . ______ | LOWER | ______ | ______ | ______ | XXXXXX | ______ | | ______ | ______ | ______ | ______ | + | ______ | ______ | ______ | ______ | | ______ | ______ | ______ | ______ | ______ | ______ | ______ . ______ | LOWER | ______ | ______ | ______ | XXXXXX | ______ | | ______ | ______ | ______ | ______ | '-----------------------------------' '-----------------------------------------------------------------------------------------------------------------------------' '-----------------------------------' */ KEYMAP(LAYER_LOWER, \ - _______, _______, _______, _______, KC_F13 , KC_F14 , KC_F15 , KC_F16 , XXXXXXX, KC_F17 , KC_F18 , KC_F19 , KC_F20 , XXXXXXX, KC_F21 , KC_F22 , KC_F23 , KC_F24 , _______, M_MUTEA, _______, _______, \ + _______, M_MUTEA, _______, _______, KC_F13 , KC_F14 , KC_F15 , KC_F16 , XXXXXXX, KC_F17 , KC_F18 , KC_F19 , KC_F20 , XXXXXXX, KC_F21 , KC_F22 , KC_F23 , KC_F24 , _______, _______, _______, _______, \ _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, \ _______, _______, _______, _______, _______, _______, KC_DLR , KC_LCBR, KC_LBRC, KC_LPRN, KC_PERC, KC_HASH, KC_RPRN, KC_RBRC, KC_RCBR, KC_AT , _______, _______, _______, _______, _______, _______, \ _______, _______, _______, _______, _______, _______, KC_CIRC, KC_ASTR, KC_PLUS, KC_MINS, KC_SLSH, KC_BSLS, KC_UNDS, KC_QUOT, KC_DQT , KC_GRV , _______, _______, _______, _______, _______, _______, \ _______, _______, _______, _______, _______, _______, KC_PIPE, KC_AMPR, KC_EXLM, KC_TILD, KC_SCLN, KC_COLN, KC_EQL , KC_LT , KC_GT , KC_QUES, _______, _______, _______, _______, _______, _______, \ - _______, _______, _______, _______, _______, XXXXXXX, XXXXXXX, _______, _______, _______, _______, _______, M_LOWER, _______, _______, _______, XXXXXXX, _______, _______, _______, _______, _______ \ + _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, M_LOWER, _______, _______, _______, XXXXXXX, _______, _______, _______, _______, _______ \ ), /* LAYER = LAYER_UPPER .-----------------------------------. .-----------------------------------------------------------------------------------------------------------------------------. .-----------------------------------. - | ______ | ______ | ______ | ______ | | F13 | F14 | F15 | F16 | XXXXXX | F17 | F18 | F19 | F20 | XXXXXX | F21 | F22 | F23 | F24 | | ______ | MUTE A | ______ | ______ | + | ______ | MUTE A | ______ | ______ | | F13 | F14 | F15 | F16 | XXXXXX | F17 | F18 | F19 | F20 | XXXXXX | F21 | F22 | F23 | F24 | | ______ | ______ | ______ | ______ | '-----------------------------------' '-----------------------------------------------------------------------------------------------------------------------------' '-----------------------------------' .-----------------------------------. .-----------------------------------------------------------------------------------------------------------------------------. .-----------------------------------. | ______ | ______ | ______ | ______ | | ______ | ______ | ______ | ______ | ______ | ______ | ______ | ______ | ______ | ______ | ______ | ______ | ______ | ______ | | ______ | ______ | ______ | ______ | @@ -204,44 +205,44 @@ KEYMAP(LAYER_LOWER, \ |--------+--------+--------+--------| |--------+--------+--------+--------+--------+--------+--------+--------+--------+--------+--------+--------+--------+--------| o |--------|--------|--------+--------| | ______ | ______ | ______ | ______ | | ______ | ______ | F9 | F10 | F11 | F12 | SCR LK | KP 0 | KP 1 | KP 2 | KP 3 | KP Ent | ______ | ______ | | ______ | ______ | ______ | ______ | |--------+--------+--------+--------| |--------+--------+--------+--------+--------+--------+--------+--------+--------+--------+--------+--------+--------+--------| |--------|--------|--------+--------| - | ______ | ______ | ______ | ______ | | ______ | XXXXXX | XXXXXX | ______ | ______ | UPPER | KP 0 . KP 0 | ______ | RALT | KP . | KP Ent | XXXXXX | ______ | | ______ | ______ | ______ | ______ | + | ______ | ______ | ______ | ______ | | ______ | ______ | ______ | ______ | ______ | UPPER | KP 0 . KP 0 | ______ | RALT | KP . | KP Ent | XXXXXX | ______ | | ______ | ______ | ______ | ______ | '-----------------------------------' '-----------------------------------------------------------------------------------------------------------------------------' '-----------------------------------' */ KEYMAP(LAYER_UPPER, \ - _______, _______, _______, _______, KC_F13 , KC_F14 , KC_F15 , KC_F16 , XXXXXXX, KC_F17 , KC_F18 , KC_F19 , KC_F20 , XXXXXXX, KC_F21 , KC_F22 , KC_F23 , KC_F24 , _______, M_MUTEA, _______, _______, \ + _______, M_MUTEA, _______, _______, KC_F13 , KC_F14 , KC_F15 , KC_F16 , XXXXXXX, KC_F17 , KC_F18 , KC_F19 , KC_F20 , XXXXXXX, KC_F21 , KC_F22 , KC_F23 , KC_F24 , _______, _______, _______, _______, \ _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, \ _______, _______, _______, _______, _______, _______, KC_F1 , KC_F2 , KC_F3 , KC_F4 , KC_NLCK, KC_PSLS, KC_KP_7, KC_KP_8, KC_KP_9, KC_PMNS, _______, _______, _______, _______, _______, _______, \ _______, _______, _______, _______, _______, _______, KC_F5 , KC_F6 , KC_F7 , KC_F8 , KC_CAPS, KC_PAST, KC_KP_4, KC_KP_5, KC_KP_6, KC_PPLS, _______, _______, _______, _______, _______, _______, \ _______, _______, _______, _______, _______, _______, KC_F9 , KC_F10 , KC_F11 , KC_F12 , KC_SLCK, KC_KP_0, KC_KP_1, KC_KP_2, KC_KP_3, KC_PENT, _______, _______, _______, _______, _______, _______, \ - _______, _______, _______, _______, _______, XXXXXXX, XXXXXXX, _______, _______, M_UPPER, KC_KP_0, KC_KP_0, _______, KC_RALT, KC_PDOT, KC_PENT, XXXXXXX, _______, _______, _______, _______, _______ \ + _______, _______, _______, _______, _______, _______, _______, _______, _______, M_UPPER, KC_KP_0, KC_KP_0, _______, KC_RALT, KC_PDOT, KC_PENT, XXXXXXX, _______, _______, _______, _______, _______ \ ), /* LAYER = LAYER_MOUSE .-----------------------------------. .-----------------------------------------------------------------------------------------------------------------------------. .-----------------------------------. | ______ | ______ | ______ | ______ | | ______ | ______ | ______ | ______ | ______ | ______ | ______ | ______ | ______ | ______ | ______ | ______ | ______ | ______ | | ______ | ______ | ______ | ______ | '-----------------------------------' '-----------------------------------------------------------------------------------------------------------------------------' '-----------------------------------' .-----------------------------------. .-----------------------------------------------------------------------------------------------------------------------------. .-----------------------------------. - | MS BT1 | MS AC0 | MS WHU | MS AC2 | | ______ | ______ | ______ | ______ | ______ | ______ | ______ | ______ | ______ | ______ | ______ | ______ | ______ | ______ | | ______ | ______ | ______ | ______ | + | ______ | ______ | ______ | ______ | | ______ | ______ | ______ | ______ | ______ | ______ | ______ | ______ | ______ | ______ | ______ | ______ | ______ | ______ | | MS AC0 | MS WHU | MS AC2 | MS BT1 | |--------+--------+--------+--------| |--------+--------+--------+--------+--------+--------+--------+--------+--------+--------+--------+--------+--------+--------| |--------|--------|--------+--------| - | MS BT2 | MS WHL | MS WHD | MS WHU | | ______ | ______ | ______ | ______ | ______ | ______ | ______ | ______ | ______ | ______ | ______ | ______ | ______ | ______ | | ______ | ______ | ______ | ______ | + | ______ | ______ | ______ | ______ | | ______ | ______ | ______ | ______ | ______ | ______ | ______ | ______ | ______ | ______ | ______ | ______ | ______ | ______ | | MS WHL | MS WHD | MS WHU | MS BT2 | |--------+--------+--------+--------| |--------+--------+--------+--------+--------+--------+--------+--------+--------+--------+--------+--------+--------+--------| o |--------|--------|--------+--------| - | MS BT3 | MS UL | MS U | MS UR | | ______ | ______ | ______ | ______ | ______ | ______ | ______ | ______ | ______ | ______ | ______ | ______ | ______ | ______ | o | ______ | ______ | ______ | ______ | + | ______ | ______ | ______ | ______ | | ______ | ______ | ______ | ______ | ______ | ______ | ______ | ______ | ______ | ______ | ______ | ______ | ______ | ______ | o | MS BT1 | MS BT2 | MS BT3 | MS BT3 | |--------+--------+--------+--------| |--------+--------+--------+--------+--------+--------+--------+--------+--------+--------+--------+--------+--------+--------| o |--------|--------|--------+--------| - | MS BT4 | MS L | MS BT1 | MS R | | ______ | ______ | ______ | ______ | ______ | ______ | ______ | ______ | ______ | ______ | ______ | ______ | ______ | ______ | | ______ | ______ | ______ | ______ | + | ______ | ______ | ______ | ______ | | ______ | ______ | ______ | ______ | ______ | ______ | ______ | ______ | ______ | ______ | ______ | ______ | ______ | ______ | | XXXXXX | MS U | XXXXXX | MS BT4 | |--------+--------+--------+--------| |--------+--------+--------+--------+--------+--------+--------+--------+--------+--------+--------+--------+--------+--------| |--------|--------|--------+--------| - | MS BT5 | MS DL | MS D | MS DR | | ______ | ______ | ______ | ______ | ______ | ______ | ______ . ______ | ______ | ______ | ______ | ______ | ______ | ______ | | ______ | ______ | ______ | ______ | + | ______ | ______ | ______ | ______ | | ______ | ______ | ______ | ______ | ______ | ______ | ______ . ______ | ______ | ______ | ______ | ______ | ______ | ______ | | MS L | MS D | MS R | MS BT5 | '-----------------------------------' '-----------------------------------------------------------------------------------------------------------------------------' '-----------------------------------' */ KEYMAP(LAYER_MOUSE, \ _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, \ - KC_BTN1, KC_ACL0, KC_WH_U, KC_ACL2, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, \ - KC_BTN2, KC_WH_L, KC_WH_D, KC_WH_U, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, \ - KC_BTN3, M_MS_UL, KC_MS_U, M_MS_UR, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, \ - KC_BTN4, KC_MS_L, KC_BTN1, KC_MS_R, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, \ - KC_BTN5, M_MS_DL, KC_MS_D, M_MS_DR, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______ \ + _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, KC_ACL0, KC_WH_U, KC_ACL2, KC_BTN1, \ + _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, KC_WH_L, KC_WH_D, KC_WH_U, KC_BTN2, \ + _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, KC_BTN1, KC_BTN2, KC_BTN3, KC_BTN3, \ + _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, XXXXXXX, KC_MS_U, XXXXXXX, KC_BTN4, \ + _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, KC_MS_L, KC_MS_D, KC_MS_R, KC_BTN5 \ ), /* LAYER = LAYER_ADJUST .-----------------------------------. .-----------------------------------------------------------------------------------------------------------------------------. .-----------------------------------. - | XXXXXX | XXXXXX | XXXXXX | XXXXXX | | HELP 1 | HELP 2 | HELP 3 | HELP 4 | XXXXXX | HELP 5 | HELP 6 | HELP 7 | HELP 8 | XXXXXX | HELP 9 | HELP 0 | XXXXXX | XXXXXX | | VOICE- | AUDIO | VOICE+ | MUSIC | + | VOICE- | AUDIO | VOICE+ | MUSIC | | HELP 1 | HELP 2 | HELP 3 | HELP 4 | XXXXXX | HELP 5 | HELP 6 | HELP 7 | HELP 8 | XXXXXX | HELP 9 | HELP 0 | XXXXXX | XXXXXX | | XXXXXX | XXXXXX | XXXXXX | XXXXXX | '-----------------------------------' '-----------------------------------------------------------------------------------------------------------------------------' '-----------------------------------' .-----------------------------------. .-----------------------------------------------------------------------------------------------------------------------------. .-----------------------------------. | XXXXXX | XXXXXX | XXXXXX | XXXXXX | | XXXXXX | XXXXXX | XXXXXX | XXXXXX | XXXXXX | XXXXXX | XXXXXX | XXXXXX | XXXXXX | XXXXXX | XXXXXX | XXXXXX | XXXXXX | XXXXXX | | XXXXXX | XXXXXX | XXXXXX | XXXXXX | @@ -256,14 +257,13 @@ KEYMAP(LAYER_MOUSE, \ '-----------------------------------' '-----------------------------------------------------------------------------------------------------------------------------' '-----------------------------------' */ KEYMAP(LAYER_ADJUST, \ - XXXXXXX, XXXXXXX, XXXXXXX, XXXXXXX, M_HELP1, M_HELP2, M_HELP3, M_HELP4, XXXXXXX, M_HELP5, M_HELP6, M_HELP7, M_HELP8, XXXXXXX, M_HELP9, M_HELP0, XXXXXXX, XXXXXXX, MUV_DE , AU_TOG , MUV_IN , MU_TOG , \ + MUV_DE , AU_TOG , MUV_IN , MU_TOG , M_HELP1, M_HELP2, M_HELP3, M_HELP4, XXXXXXX, M_HELP5, M_HELP6, M_HELP7, M_HELP8, XXXXXXX, M_HELP9, M_HELP0, XXXXXXX, XXXXXXX, XXXXXXX, XXXXXXX, XXXXXXX, XXXXXXX, \ XXXXXXX, XXXXXXX, XXXXXXX, XXXXXXX, XXXXXXX, XXXXXXX, XXXXXXX, XXXXXXX, XXXXXXX, XXXXXXX, XXXXXXX, XXXXXXX, XXXXXXX, XXXXXXX, XXXXXXX, XXXXXXX, XXXXXXX, XXXXXXX, XXXXXXX, XXXXXXX, XXXXXXX, XXXXXXX, \ XXXXXXX, XXXXXXX, XXXXXXX, XXXXXXX, XXXXXXX, XXXXXXX, XXXXXXX, XXXXXXX, XXXXXXX, XXXXXXX, XXXXXXX, XXXXXXX, XXXXXXX, XXXXXXX, XXXXXXX, XXXXXXX, XXXXXXX, XXXXXXX, XXXXXXX, XXXXXXX, XXXXXXX, XXXXXXX, \ XXXXXXX, XXXXXXX, XXXXXXX, XXXXXXX, XXXXXXX, XXXXXXX, XXXXXXX, XXXXXXX, XXXXXXX, XXXXXXX, XXXXXXX, XXXXXXX, XXXXXXX, XXXXXXX, XXXXXXX, XXXXXXX, XXXXXXX, XXXXXXX, XXXXXXX, XXXXXXX, XXXXXXX, XXXXXXX, \ XXXXXXX, XXXXXXX, XXXXXXX, XXXXXXX, XXXXXXX, XXXXXXX, XXXXXXX, XXXXXXX, XXXXXXX, XXXXXXX, RESET , XXXXXXX, M_MOUSE, XXXXXXX, XXXXXXX, XXXXXXX, XXXXXXX, XXXXXXX, XXXXXXX, XXXXXXX, XXXXXXX, XXXXXXX, \ XXXXXXX, XXXXXXX, XXXXXXX, XXXXXXX, XXXXXXX, XXXXXXX, XXXXXXX, XXXXXXX, XXXXXXX, M_UPPER, XXXXXXX, XXXXXXX, M_LOWER, XXXXXXX, XXXXXXX, XXXXXXX, XXXXXXX, XXXXXXX, XXXXXXX, XXXXXXX, XXXXXXX, XXXXXXX \ ), - }; #ifdef AUDIO_ENABLE @@ -296,6 +296,7 @@ void persistant_default_layer_set(uint16_t default_layer) const uint16_t PROGMEM fn_actions[] = { [0] = ACTION_MODS_ONESHOT(MOD_LSFT), + [1] = ACTION_MACRO_TAP(MACRO_COPY_CUT), }; const macro_t *action_get_macro(keyrecord_t *record, uint8_t id, uint8_t opt) @@ -305,68 +306,84 @@ const macro_t *action_get_macro(keyrecord_t *record, uint8_t id, uint8_t opt) switch(id) { - case MACRO_HELP_1: - if (record->event.pressed) - { - uprint("H1"); - } - break; + case MACRO_COPY_CUT: + if (record->event.pressed) { + register_code(KC_LCTL); + if (record->tap.count == 1) { + register_code(KC_C); + unregister_code(KC_C); + } + else if (record->tap.count == 2) { + register_code(KC_X); + unregister_code(KC_X); + } + unregister_code(KC_LCTL); + } + break; - case MACRO_HELP_2: - if (record->event.pressed) - { - uprint("H2"); - } - break; - case MACRO_HELP_3: - if (record->event.pressed) - { - uprint("H3"); - } - break; + // case MACRO_HELP_1: + // if (record->event.pressed) + // { + // uprint("H1"); + // } + // break; - case MACRO_HELP_4: - if (record->event.pressed) - { - uprint("H4"); - } - break; + // case MACRO_HELP_2: + // if (record->event.pressed) + // { + // uprint("H2"); + // } + // break; - case MACRO_HELP_5: - if (record->event.pressed) - { - uprint("H5"); - } - break; + // case MACRO_HELP_3: + // if (record->event.pressed) + // { + // uprint("H3"); + // } + // break; - case MACRO_HELP_6: - if (record->event.pressed) - { - uprint("H6"); - } - break; + // case MACRO_HELP_4: + // if (record->event.pressed) + // { + // uprint("H4"); + // } + // break; - case MACRO_HELP_7: - if (record->event.pressed) - { - uprint("H7"); - } - break; + // case MACRO_HELP_5: + // if (record->event.pressed) + // { + // uprint("H5"); + // } + // break; - case MACRO_HELP_8: - if (record->event.pressed) - { - uprint("H8"); - } - break; + // case MACRO_HELP_6: + // if (record->event.pressed) + // { + // uprint("H6"); + // } + // break; - case MACRO_HELP_9: - if (record->event.pressed) - { - uprint("H9"); - } - break; + // case MACRO_HELP_7: + // if (record->event.pressed) + // { + // uprint("H7"); + // } + // break; + + // case MACRO_HELP_8: + // if (record->event.pressed) + // { + // uprint("H8"); + // } + // break; + + // case MACRO_HELP_9: + // if (record->event.pressed) + // { + // uprint("H9"); + // } + // break; case MACRO_BREATH_TOGGLE: if (record->event.pressed) @@ -566,12 +583,12 @@ void led_set_user(uint8_t usb_led) void startup_user() { _delay_ms(10); // gets rid of tick - PLAY_NOTE_ARRAY(tone_my_startup, false, STACCATO); + // PLAY_NOTE_ARRAY(tone_my_startup, false, STACCATO); } void shutdown_user() { - PLAY_NOTE_ARRAY(tone_my_goodbye, false, STACCATO); + // PLAY_NOTE_ARRAY(tone_my_goodbye, false, STACCATO); _delay_ms(2000); stop_all_notes(); } From 17170ba76d3c94edcf1ab263520238fdb0384774 Mon Sep 17 00:00:00 2001 From: IBNobody Date: Sun, 23 Oct 2016 23:00:43 -0500 Subject: [PATCH 02/15] Fixed some large keyboard bugs Fixed some bugs relating to keyboards with more than 16 columns. Also added the ability to mask off keyboard matrix bits. --- keyboards/vision_division/config.h | 2 + .../vision_division/keymaps/default/keymap.c | 11 ++++++ quantum/matrix.c | 37 +++++++++++++++++-- readme.md | 1 + tmk_core/common/command.c | 6 +-- 5 files changed, 50 insertions(+), 7 deletions(-) diff --git a/keyboards/vision_division/config.h b/keyboards/vision_division/config.h index 1f8466a546..93c9606712 100644 --- a/keyboards/vision_division/config.h +++ b/keyboards/vision_division/config.h @@ -33,6 +33,8 @@ along with this program. If not, see . /* Debounce reduces chatter (unintended double-presses) - set 0 if debouncing is not needed */ #define DEBOUNCING_DELAY 5 +#define MATRIX_MASKED + /* define if matrix has ghost (lacks anti-ghosting diodes) */ //#define MATRIX_HAS_GHOST diff --git a/keyboards/vision_division/keymaps/default/keymap.c b/keyboards/vision_division/keymaps/default/keymap.c index 8622ee5211..3282761c0f 100644 --- a/keyboards/vision_division/keymaps/default/keymap.c +++ b/keyboards/vision_division/keymaps/default/keymap.c @@ -142,6 +142,17 @@ enum keyboard_macros { #define ________________ _______, _______ #define XXXXXXXXXXXXXXXX XXXXXXX, XXXXXXX +const matrix_row_t matrix_mask[MATRIX_ROWS] = +{ +// 1098765432109876543210987654321 + 0b0000000001111111101111011111111, + 0b0000000001111111111111111111111, + 0b0000000001111111111111111111111, + 0b0000000001111111111111111111111, + 0b0000000001010111111111111111111, + 0b0000000001111101111111101011111, +}; + const uint16_t PROGMEM keymaps[][MATRIX_ROWS][MATRIX_COLS] = { /* LAYER = LAYER_QWERTY diff --git a/quantum/matrix.c b/quantum/matrix.c index 3174e07390..ac81794e59 100644 --- a/quantum/matrix.c +++ b/quantum/matrix.c @@ -26,6 +26,10 @@ along with this program. If not, see . #include "util.h" #include "matrix.h" +#ifdef MATRIX_MASKED +extern const matrix_row_t matrix_mask[]; +#endif + /* Set 0 if debouncing isn't needed */ #ifndef DEBOUNCING_DELAY @@ -218,15 +222,34 @@ bool matrix_is_on(uint8_t row, uint8_t col) inline matrix_row_t matrix_get_row(uint8_t row) { + // Matrix mask lets you disable switches in the returned matrix data. For example, if you have a + // switch blocker installed and the switch is always pressed. +#ifdef MATRIX_MASKED + return matrix[row] & matrix_mask[row]; +#else return matrix[row]; +#endif } void matrix_print(void) { +#if (MATRIX_COLS <= 8) + print("\nr/c 01234567\n"); +#elif (MATRIX_COLS <= 16) print("\nr/c 0123456789ABCDEF\n"); +#elif (MATRIX_COLS <= 32) + print("\nr/c 0123456789ABCDEF0123456789ABCDEF\n"); +#endif + for (uint8_t row = 0; row < MATRIX_ROWS; row++) { phex(row); print(": "); - pbin_reverse16(matrix_get_row(row)); +#if (MATRIX_COLS <= 8) + print_bin_reverse8(matrix_get_row(row)); +#elif (MATRIX_COLS <= 16) + print_bin_reverse16(matrix_get_row(row)); +#elif (MATRIX_COLS <= 32) + print_bin_reverse32(matrix_get_row(row)); +#endif print("\n"); } } @@ -235,7 +258,13 @@ uint8_t matrix_key_count(void) { uint8_t count = 0; for (uint8_t i = 0; i < MATRIX_ROWS; i++) { +#if (MATRIX_COLS <= 8) + count += bitpop(matrix[i]); +#elif (MATRIX_COLS <= 16) count += bitpop16(matrix[i]); +#elif (MATRIX_COLS <= 32) + count += bitpop32(matrix[i]); +#endif } return count; } @@ -259,7 +288,7 @@ static matrix_row_t read_cols(void) matrix_row_t result = 0; #if DIODE_DIRECTION == COL2ROW - for(int x = 0; x < MATRIX_COLS; x++) { + for(int x = 0; x < MATRIX_COLS; x++) { int pin = col_pins[x]; #else for(int x = 0; x < MATRIX_ROWS; x++) { @@ -273,10 +302,10 @@ static matrix_row_t read_cols(void) static void unselect_rows(void) { #if DIODE_DIRECTION == COL2ROW - for(int x = 0; x < MATRIX_ROWS; x++) { + for(int x = 0; x < MATRIX_ROWS; x++) { int pin = row_pins[x]; #else - for(int x = 0; x < MATRIX_COLS; x++) { + for(int x = 0; x < MATRIX_COLS; x++) { int pin = col_pins[x]; #endif _SFR_IO8((pin >> 4) + 1) &= ~_BV(pin & 0xF); diff --git a/readme.md b/readme.md index 62d479ff1d..c460933a70 100644 --- a/readme.md +++ b/readme.md @@ -241,6 +241,7 @@ You can also add extra options at the end of the make command line, after the ta * `make COLOR=false` - turns off color output * `make SILENT=true` - turns off output besides errors/warnings * `make VERBOSE=true` - outputs all of the gcc stuff (not interesting, unless you need to debug) +* `make EXTRAFLAGS=-E` - Preprocess the code without doing any compiling (useful if you are trying to debug #define commands) The make command itself also has some additional options, type `make --help` for more information. The most useful is probably `-jx`, which specifies that you want to compile using more than one CPU, the `x` represents the number of CPUs that you want to use. Setting that can greatly reduce the compile times, especially if you are compiling many keyboards/keymaps. I usually set it to one less than the number of CPUs that I have, so that I have some left for doing other things while it's compiling. Note that not all operating systems and make versions supports that option. diff --git a/tmk_core/common/command.c b/tmk_core/common/command.c index f3e1bf6234..5f29bc0b4e 100644 --- a/tmk_core/common/command.c +++ b/tmk_core/common/command.c @@ -379,11 +379,11 @@ static bool command_common(uint8_t code) debug_enable = !debug_enable; if (debug_enable) { print("\ndebug: on\n"); - debug_matrix = true; - debug_keyboard = true; - debug_mouse = true; } else { print("\ndebug: off\n"); + debug_matrix = false; + debug_keyboard = false; + debug_mouse = false; } break; From ef8f6180272c3e112f97a6beb9dd90bece3c2131 Mon Sep 17 00:00:00 2001 From: IBNobody Date: Sun, 23 Oct 2016 23:03:26 -0500 Subject: [PATCH 03/15] Fixing Line Terminations --- .../keymaps/win10_writers-block/config.h | 72 +- .../keymaps/win10_writers-block/keymap.c | 648 +++++++++--------- .../keymaps/win10_writers-block/readme.md | 224 +++--- 3 files changed, 472 insertions(+), 472 deletions(-) diff --git a/keyboards/ergodox/keymaps/win10_writers-block/config.h b/keyboards/ergodox/keymaps/win10_writers-block/config.h index 568a711a86..43259db088 100644 --- a/keyboards/ergodox/keymaps/win10_writers-block/config.h +++ b/keyboards/ergodox/keymaps/win10_writers-block/config.h @@ -1,36 +1,36 @@ -#ifndef KEYBOARDS_ERGODOX_CONFIG_H_ -#define KEYBOARDS_ERGODOX_CONFIG_H_ - -#define MOUSEKEY_DELAY 100 -#define MOUSEKEY_INTERVAL 20 -#define MOUSEKEY_MAX_SPEED 3 -#define MOUSEKEY_TIME_TO_MAX 10 - -#define TAPPING_TOGGLE 1 - -/* define if matrix has ghost */ -//#define MATRIX_HAS_GHOST - -#define TAPPING_TERM 300 -#define IGNORE_MOD_TAP_INTERRUPT // this makes it possible to do rolling combos (zx) with keys that convert to other keys on hold (z becomes ctrl when you hold it, and when this option isn't enabled, z rapidly followed by x actually sends Ctrl-x. That's bad.) - -/* Mechanical locking support. Use KC_LCAP, KC_LNUM or KC_LSCR instead in keymap */ -#define LOCKING_SUPPORT_ENABLE -/* Locking resynchronize hack */ -#define LOCKING_RESYNC_ENABLE - -/* key combination for command */ -#define IS_COMMAND() ( \ - keyboard_report->mods == (MOD_BIT(KC_LCTL) | MOD_BIT(KC_RCTL)) || \ - keyboard_report->mods == (MOD_BIT(KC_LSFT) | MOD_BIT(KC_RSFT)) \ -) - -#ifdef SUBPROJECT_ez - #include "ez/config.h" -#endif -#ifdef SUBPROJECT_infinity - #include "infinity/config.h" -#endif - - -#endif /* KEYBOARDS_ERGODOX_CONFIG_H_ */ +#ifndef KEYBOARDS_ERGODOX_CONFIG_H_ +#define KEYBOARDS_ERGODOX_CONFIG_H_ + +#define MOUSEKEY_DELAY 100 +#define MOUSEKEY_INTERVAL 20 +#define MOUSEKEY_MAX_SPEED 3 +#define MOUSEKEY_TIME_TO_MAX 10 + +#define TAPPING_TOGGLE 1 + +/* define if matrix has ghost */ +//#define MATRIX_HAS_GHOST + +#define TAPPING_TERM 300 +#define IGNORE_MOD_TAP_INTERRUPT // this makes it possible to do rolling combos (zx) with keys that convert to other keys on hold (z becomes ctrl when you hold it, and when this option isn't enabled, z rapidly followed by x actually sends Ctrl-x. That's bad.) + +/* Mechanical locking support. Use KC_LCAP, KC_LNUM or KC_LSCR instead in keymap */ +#define LOCKING_SUPPORT_ENABLE +/* Locking resynchronize hack */ +#define LOCKING_RESYNC_ENABLE + +/* key combination for command */ +#define IS_COMMAND() ( \ + keyboard_report->mods == (MOD_BIT(KC_LCTL) | MOD_BIT(KC_RCTL)) || \ + keyboard_report->mods == (MOD_BIT(KC_LSFT) | MOD_BIT(KC_RSFT)) \ +) + +#ifdef SUBPROJECT_ez + #include "ez/config.h" +#endif +#ifdef SUBPROJECT_infinity + #include "infinity/config.h" +#endif + + +#endif /* KEYBOARDS_ERGODOX_CONFIG_H_ */ diff --git a/keyboards/ergodox/keymaps/win10_writers-block/keymap.c b/keyboards/ergodox/keymaps/win10_writers-block/keymap.c index ea640ee96f..3106b33747 100644 --- a/keyboards/ergodox/keymaps/win10_writers-block/keymap.c +++ b/keyboards/ergodox/keymaps/win10_writers-block/keymap.c @@ -1,324 +1,324 @@ -#include "ergodox.h" -#include "debug.h" -#include "action_layer.h" -#include "version.h" -#include "wait.h" - -#define BASE 0 // default layer - helpful for writing in Office-style word processors. -#define SYMB 1 // symbol layer - NumPad, etc. - same as Ergodox EZ default but no EEPROM or Version key -#define RIMW 2 // rimworld layer - made for the game RimWorld, by Tynan Sylvester | feel free to remap for your favorite game! -#define MDIA 3 // media layer - mouse and music - close to Ergodox EZ default media layer - -#define CO_PA M(0) // hold copy, tap paste - -#define W_CUT LCTL(KC_X) // C-x Cut -#define W_COPY LCTL(KC_C) // C-c Copy -#define W_PASTE LCTL(KC_V) // C-v Paste -#define W_UNDO LCTL(KC_Z) // C-z Undo -#define W_FIND LCTL(KC_F) // C-v Find -#define W_CAD LCTL(LALT(KC_DEL)) // one-tap ctrl-alt-del - - - -//Tap Dance Declarations -enum { - CAKEWARP, - CTRLALTMDIA, -}; - -void cake_count (qk_tap_dance_state_t *state, void *user_data) { - if (state->count == 2) { - layer_on (SYMB); //define double tap here - layer_off (MDIA); - } - else { - layer_off (SYMB); //define single tap or hold here - layer_off (MDIA); - } - if (state->count == 3) { - layer_on (RIMW); //define triple tap here - layer_off (MDIA); - } - else { - layer_off (RIMW); //define single tap or hold here - layer_off (MDIA); - reset_tap_dance (state); - } -} - -void dance_cad_mdia_fin (qk_tap_dance_state_t *state, void *user_data) { - if (state->count == 1) { - register_code (KC_LCTL); - register_code (KC_LALT); - register_code (KC_DEL); - } else { - layer_on (MDIA); - } -} - -void dance_cad_mdia_reset (qk_tap_dance_state_t *state, void *user_data) { - if (state->count == 1) { - unregister_code (KC_DEL); - unregister_code (KC_LALT); - unregister_code (KC_LCTL); - } else { - ; - } -} - -//Tap Dance Definitions -qk_tap_dance_action_t tap_dance_actions[] = { - // tap for Layer 0, tap twice to switch to symbol layer, and tap three times to switch to rimworld layer. - [CAKEWARP] = ACTION_TAP_DANCE_FN(cake_count) - // tap for ctrl-alt-del, tap twice for media layer - ,[CTRLALTMDIA] = ACTION_TAP_DANCE_FN_ADVANCED (NULL, dance_cad_mdia_fin, dance_cad_mdia_reset) - // Other declarations would go here, separated by commas, if you have them -}; - -//In Layer declaration, add tap dance item in place of a key code - -const uint16_t PROGMEM keymaps[][MATRIX_ROWS][MATRIX_COLS] = { -/* Keymap 0: Basic layer - TD(one_tap, two_taps, three_taps...) - * - * ,--------------------------------------------------. ,--------------------------------------------------. - * | ` | 1 | 2 | 3 | 4 | 5 | 6 | | 7 | 7 | 8 | 9 | 0 | - | = | - * |--------+------+------+------+------+-------------| |------+------+------+------+------+------+--------| - * | F12/L1 | Q | W | E | R | T | {/[ | |TD(L0 | Y | U | I | O | P | \ | - * |--------+------+------+------+------+------| | |L1 L2)|------+------+------+------+------+--------| - * |Caps/Win| A | S | D | F | G |------| |------| H | J | K | L | ; | ' | - * |--------+------+------+------+------+------| }/] | TD(ctrl|------+------+------+------+------+--------| - * |LShift/(|Z/Ctrl| X | C | V | B | | |altdel| N | M | , | . | / |RShift/)| - * `--------+------+------+------+------+-------------' |L3) |------+------+------+------+------+--------' - * | Undo | Cut |CopyPa| Meh | LGui | '------| | Enter| Left | Up | Down | Right | - * `----------------------------------' `----------------------------------' - * ,-------------. ,-------------. - * | Esc | VolUp| | F4 | Mute | - * ,------|------|------| |------+--------+------. - * | | | VolDn| | F5 | | | - * |Backsp|Delete|------| |------| Tab / |Space | - * |ace | | Find | | Alt | CTRL | | - * `--------------------' `----------------------' - */ -// If it accepts an argument (i.e, is a function), it doesn't need KC_. -// Otherwise, it needs KC_* -[BASE] = KEYMAP( // layer 0 : default - // left hand - KC_GRV, KC_1, KC_2, KC_3, KC_4, KC_5, KC_6, -LT(SYMB, KC_F12), KC_Q, KC_W, KC_E, KC_R, KC_T, KC_LBRC, - GUI_T(KC_CAPS), KC_A, KC_S, KC_D, KC_F, KC_G, - KC_LSPO, CTL_T(KC_Z), KC_X, KC_C, KC_V, KC_B, KC_RBRC, - W_UNDO, W_CUT, CO_PA, MEH_T(KC_NO), KC_LGUI, - KC_ESC, KC_VOLU, - KC_VOLD, - KC_BSPC, KC_DELETE, W_FIND, - // right hand - KC_7, KC_7, KC_8, KC_9, KC_0, KC_MINS, KC_EQL, - TD(CAKEWARP), KC_Y, KC_U, KC_I, KC_O, KC_P, KC_BSLS, - KC_H, KC_J, KC_K, KC_L, KC_SCLN, KC_QUOT, - TD(CTRLALTMDIA), KC_N, KC_M, KC_COMM, KC_DOT, KC_SLSH, KC_RSPC, - KC_ENT, KC_LEFT, KC_UP, KC_DOWN, KC_RIGHT, - KC_F4, KC_MUTE, - KC_F5, - KC_RALT, CTL_T(KC_TAB), KC_SPC - ), - -/* Keymap 1: Symbol Layer | No EEPROM Or Version keys - * - * ,--------------------------------------------------. ,--------------------------------------------------. - * | | F1 | F2 | F3 | F4 | F5 | xx | | xx | F6 | F7 | F8 | F9 | F10 | F11 | - * |--------+------+------+------+------+-------------| |------+------+------+------+------+------+--------| - * | | ! | @ | { | } | | | | |TD(L0 | Up | 7 | 8 | 9 | * | F12 | - * |--------+------+------+------+------+------| | |L1 L2)|------+------+------+------+------+--------| - * | | # | $ | ( | ) | ` |------| |------| Down | 4 | 5 | 6 | + | - | - * |--------+------+------+------+------+------| | | |------+------+------+------+------+--------| - * | | % | ^ | [ | ] | ~ | | | | & | 1 | 2 | 3 | \ | | - * `--------+------+------+------+------+-------------' `-------------+------+------+------+------+--------' - * | | | | | | | | . | 0 | = | | - * `----------------------------------' `----------------------------------' - * ,-------------. ,-------------. - * | | | | | | - * ,------|------|------| |------+------+------. - * | | | | | | | | - * | | |------| |------| | | - * | | | | | | | | - * `--------------------' `--------------------' - */ -// SYMBOLS -[SYMB] = KEYMAP( - // left hand - KC_TRNS, KC_F1, KC_F2, KC_F3, KC_F4, KC_F5, KC_NO, - KC_TRNS,KC_EXLM,KC_AT, KC_LCBR,KC_RCBR,KC_PIPE,KC_TRNS, - KC_TRNS,KC_HASH,KC_DLR, KC_LPRN,KC_RPRN,KC_GRV, - KC_TRNS,KC_PERC,KC_CIRC,KC_LBRC,KC_RBRC,KC_TILD,KC_TRNS, - KC_TRNS,KC_TRNS,KC_TRNS,KC_TRNS,KC_TRNS, - KC_TRNS,KC_TRNS, - KC_TRNS, - KC_TRNS,KC_TRNS,KC_TRNS, - // right hand - KC_NO, KC_F6, KC_F7, KC_F8, KC_F9, KC_F10, KC_F11, - KC_TRNS, KC_UP, KC_7, KC_8, KC_9, KC_ASTR, KC_F12, - KC_DOWN, KC_4, KC_5, KC_6, KC_PLUS, KC_MINS, - KC_TRNS, KC_AMPR, KC_1, KC_2, KC_3, KC_BSLS, KC_TRNS, - KC_TRNS,KC_DOT, KC_0, KC_EQL, KC_NO, - KC_TRNS, KC_TRNS, - KC_TRNS, - KC_TRNS, KC_TRNS, KC_TRNS -), - -/* Keymap 2: RimWorld Layer - * - * ,--------------------------------------------------. ,--------------------------------------------------. - * | ESC | 1 | 2 | 3 | 4 | 5 | 6 | | 7 | 7 | 8 | 9 | 0 | - | = | - * |--------+------+------+------+------+-------------| |------+------+------+------+------+------+--------| - * | TAB | C | ,< | W | >. | R | | |TD(L0 | U | B | N | J | M | PGUP | - * |--------+------+------+------+------+------| F10 | |L1 L2)|------+------+------+------+------+--------| - * | I | F | A | S | D | 8 |------| |------| X | L | P | Y | H | ENTER | - * |--------+------+------+------+------+------| | | |------+------+------+------+------+--------| - * | K | F1 | F2 | F3 | F4 | F5 | F6 | | F7 | F8 | F9 | F10 | F11 | F12 | PGDN | - * `--------+------+------+------+------+-------------' `-------------+------+------+------+------+--------' - * | | | | | | | F | | | | | - * `----------------------------------' `----------------------------------' - * ,-------------. ,-------------. - * | | | | | | - * ,------|------|------| |------+------+------. - * | | | | | | | | - * |SPACE | C |------| |------| E |SPACE | - * | | | Q | | | | | - * `--------------------' `--------------------' - */ -// RIMWORLD -[RIMW] = KEYMAP( - // left hand - KC_ESC, KC_1, KC_2, KC_3, KC_4, KC_5, KC_6, - KC_TAB, KC_C, KC_COMM, KC_W, KC_DOT, KC_R, KC_F10, - KC_I, KC_F, KC_A, KC_S, KC_D, KC_8, - KC_K, KC_F1, KC_F2, KC_F3, KC_F4, KC_F5, KC_F6, - KC_TRNS,KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, - KC_TRNS,KC_TRNS, - KC_TRNS, - KC_C,KC_Q,KC_TRNS, - // right hand - KC_7, KC_7, KC_8, KC_9, KC_0, KC_MINS, KC_EQL, - KC_TRNS, KC_U, KC_B, KC_N, KC_J, KC_M, KC_PGUP, - KC_X, KC_L, SFT_T(KC_P), KC_Y, KC_H, KC_ENT, - KC_F7, KC_F8, KC_F9, KC_F10, KC_F11, KC_F12, KC_PGDN, - KC_F, KC_LEFT, KC_UP, KC_DOWN,KC_RIGHT, - KC_TRNS, KC_TRNS, - KC_TRNS, - KC_TRNS, KC_E, KC_TRNS -), -/* Keymap 3: Media and mouse keys - * - * ,--------------------------------------------------. ,--------------------------------------------------. - * | | | | | | | | | | | | | | | | - * |--------+------+------+------+------+-------------| |------+------+------+------+------+------+--------| - * | | | | MsUp | | | | | | | | | | | | - * |--------+------+------+------+------+------| | | |------+------+------+------+------+--------| - * | | |MsLeft|MsDown|MsRght| |------| |------| | | | | | Play | - * |--------+------+------+------+------+------| | | |------+------+------+------+------+--------| - * | | | | | | | | | | | | Prev | Next | | | - * `--------+------+------+------+------+-------------' `-------------+------+------+------+------+--------' - * | | | | Lclk | Rclk | |VolUp |VolDn | Mute | | | - * `----------------------------------' `----------------------------------' - * ,-------------. ,-------------. - * | | | | | | - * ,------|------|------| |------+------+------. - * | | | | | | |Brwser| - * | Lclk | Rclk |------| |------| |Back | - * | | | | | | | | - * `--------------------' `--------------------' - */ -// MEDIA AND MOUSE -[MDIA] = KEYMAP( - KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, - KC_TRNS, KC_TRNS, KC_TRNS, KC_MS_U, KC_TRNS, KC_TRNS, KC_TRNS, - KC_TRNS, KC_TRNS, KC_MS_L, KC_MS_D, KC_MS_R, KC_TRNS, - KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, - KC_TRNS, KC_TRNS, KC_TRNS, KC_BTN1, KC_BTN2, - KC_TRNS, KC_TRNS, - KC_TRNS, - KC_BTN1, KC_BTN2, KC_TRNS, - // right hand - KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, - KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, - KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_MPLY, - KC_TRNS, KC_TRNS, KC_TRNS, KC_MPRV, KC_MNXT, KC_TRNS, KC_TRNS, - KC_VOLU, KC_VOLD, KC_MUTE, KC_TRNS, KC_TRNS, - KC_TRNS, KC_TRNS, - KC_TRNS, - KC_TRNS, KC_TRNS, KC_WBAK -), -}; - -static uint16_t key_timer; - -const macro_t *action_get_macro(keyrecord_t *record, uint8_t id, uint8_t opt) -{ - switch(id) { - case 0: { - if (record->event.pressed) { - key_timer = timer_read(); // if the key is being pressed, we start the timer. - } - else { // this means the key was just released, so we can figure out how long it was pressed for (tap or "held down"). - if (timer_elapsed(key_timer) > 150) { // 150 being 150ms, the threshhold we pick for counting something as a tap. - return MACRO( D(LCTL), T(C), U(LCTL), END ); - } - else { - return MACRO( D(LCTL), T(V), U(LCTL), END ); - } - } - break; - } - } - return MACRO_NONE; -}; - -// Anything you want to do once when the keyboard initializes. -// Tests LED function when the keyboard initializes. -void matrix_init_user(void) { - - wait_ms(500); - ergodox_board_led_on(); - wait_ms(200); - ergodox_right_led_1_on(); - wait_ms(200); - ergodox_right_led_2_on(); - wait_ms(200); - ergodox_right_led_3_on(); - wait_ms(200); - ergodox_board_led_off(); - wait_ms(200); - ergodox_right_led_1_off(); - wait_ms(200); - ergodox_right_led_2_off(); - wait_ms(200); - ergodox_right_led_3_off(); - -}; - - -// Runs constantly in the background, in a loop. -void matrix_scan_user(void) { - - uint8_t layer = biton32(layer_state); - - ergodox_board_led_off(); - ergodox_right_led_1_off(); - ergodox_right_led_2_off(); - ergodox_right_led_3_off(); - switch (layer) { - case 1: - ergodox_right_led_1_on(); - break; - case 2: - ergodox_right_led_2_on(); - break; - case 3: - ergodox_right_led_3_on(); - break; - default: - // none - break; - } - -}; +#include "ergodox.h" +#include "debug.h" +#include "action_layer.h" +#include "version.h" +#include "wait.h" + +#define BASE 0 // default layer - helpful for writing in Office-style word processors. +#define SYMB 1 // symbol layer - NumPad, etc. - same as Ergodox EZ default but no EEPROM or Version key +#define RIMW 2 // rimworld layer - made for the game RimWorld, by Tynan Sylvester | feel free to remap for your favorite game! +#define MDIA 3 // media layer - mouse and music - close to Ergodox EZ default media layer + +#define CO_PA M(0) // hold copy, tap paste + +#define W_CUT LCTL(KC_X) // C-x Cut +#define W_COPY LCTL(KC_C) // C-c Copy +#define W_PASTE LCTL(KC_V) // C-v Paste +#define W_UNDO LCTL(KC_Z) // C-z Undo +#define W_FIND LCTL(KC_F) // C-v Find +#define W_CAD LCTL(LALT(KC_DEL)) // one-tap ctrl-alt-del + + + +//Tap Dance Declarations +enum { + CAKEWARP, + CTRLALTMDIA, +}; + +void cake_count (qk_tap_dance_state_t *state, void *user_data) { + if (state->count == 2) { + layer_on (SYMB); //define double tap here + layer_off (MDIA); + } + else { + layer_off (SYMB); //define single tap or hold here + layer_off (MDIA); + } + if (state->count == 3) { + layer_on (RIMW); //define triple tap here + layer_off (MDIA); + } + else { + layer_off (RIMW); //define single tap or hold here + layer_off (MDIA); + reset_tap_dance (state); + } +} + +void dance_cad_mdia_fin (qk_tap_dance_state_t *state, void *user_data) { + if (state->count == 1) { + register_code (KC_LCTL); + register_code (KC_LALT); + register_code (KC_DEL); + } else { + layer_on (MDIA); + } +} + +void dance_cad_mdia_reset (qk_tap_dance_state_t *state, void *user_data) { + if (state->count == 1) { + unregister_code (KC_DEL); + unregister_code (KC_LALT); + unregister_code (KC_LCTL); + } else { + ; + } +} + +//Tap Dance Definitions +qk_tap_dance_action_t tap_dance_actions[] = { + // tap for Layer 0, tap twice to switch to symbol layer, and tap three times to switch to rimworld layer. + [CAKEWARP] = ACTION_TAP_DANCE_FN(cake_count) + // tap for ctrl-alt-del, tap twice for media layer + ,[CTRLALTMDIA] = ACTION_TAP_DANCE_FN_ADVANCED (NULL, dance_cad_mdia_fin, dance_cad_mdia_reset) + // Other declarations would go here, separated by commas, if you have them +}; + +//In Layer declaration, add tap dance item in place of a key code + +const uint16_t PROGMEM keymaps[][MATRIX_ROWS][MATRIX_COLS] = { +/* Keymap 0: Basic layer - TD(one_tap, two_taps, three_taps...) + * + * ,--------------------------------------------------. ,--------------------------------------------------. + * | ` | 1 | 2 | 3 | 4 | 5 | 6 | | 7 | 7 | 8 | 9 | 0 | - | = | + * |--------+------+------+------+------+-------------| |------+------+------+------+------+------+--------| + * | F12/L1 | Q | W | E | R | T | {/[ | |TD(L0 | Y | U | I | O | P | \ | + * |--------+------+------+------+------+------| | |L1 L2)|------+------+------+------+------+--------| + * |Caps/Win| A | S | D | F | G |------| |------| H | J | K | L | ; | ' | + * |--------+------+------+------+------+------| }/] | TD(ctrl|------+------+------+------+------+--------| + * |LShift/(|Z/Ctrl| X | C | V | B | | |altdel| N | M | , | . | / |RShift/)| + * `--------+------+------+------+------+-------------' |L3) |------+------+------+------+------+--------' + * | Undo | Cut |CopyPa| Meh | LGui | '------| | Enter| Left | Up | Down | Right | + * `----------------------------------' `----------------------------------' + * ,-------------. ,-------------. + * | Esc | VolUp| | F4 | Mute | + * ,------|------|------| |------+--------+------. + * | | | VolDn| | F5 | | | + * |Backsp|Delete|------| |------| Tab / |Space | + * |ace | | Find | | Alt | CTRL | | + * `--------------------' `----------------------' + */ +// If it accepts an argument (i.e, is a function), it doesn't need KC_. +// Otherwise, it needs KC_* +[BASE] = KEYMAP( // layer 0 : default + // left hand + KC_GRV, KC_1, KC_2, KC_3, KC_4, KC_5, KC_6, +LT(SYMB, KC_F12), KC_Q, KC_W, KC_E, KC_R, KC_T, KC_LBRC, + GUI_T(KC_CAPS), KC_A, KC_S, KC_D, KC_F, KC_G, + KC_LSPO, CTL_T(KC_Z), KC_X, KC_C, KC_V, KC_B, KC_RBRC, + W_UNDO, W_CUT, CO_PA, MEH_T(KC_NO), KC_LGUI, + KC_ESC, KC_VOLU, + KC_VOLD, + KC_BSPC, KC_DELETE, W_FIND, + // right hand + KC_7, KC_7, KC_8, KC_9, KC_0, KC_MINS, KC_EQL, + TD(CAKEWARP), KC_Y, KC_U, KC_I, KC_O, KC_P, KC_BSLS, + KC_H, KC_J, KC_K, KC_L, KC_SCLN, KC_QUOT, + TD(CTRLALTMDIA), KC_N, KC_M, KC_COMM, KC_DOT, KC_SLSH, KC_RSPC, + KC_ENT, KC_LEFT, KC_UP, KC_DOWN, KC_RIGHT, + KC_F4, KC_MUTE, + KC_F5, + KC_RALT, CTL_T(KC_TAB), KC_SPC + ), + +/* Keymap 1: Symbol Layer | No EEPROM Or Version keys + * + * ,--------------------------------------------------. ,--------------------------------------------------. + * | | F1 | F2 | F3 | F4 | F5 | xx | | xx | F6 | F7 | F8 | F9 | F10 | F11 | + * |--------+------+------+------+------+-------------| |------+------+------+------+------+------+--------| + * | | ! | @ | { | } | | | | |TD(L0 | Up | 7 | 8 | 9 | * | F12 | + * |--------+------+------+------+------+------| | |L1 L2)|------+------+------+------+------+--------| + * | | # | $ | ( | ) | ` |------| |------| Down | 4 | 5 | 6 | + | - | + * |--------+------+------+------+------+------| | | |------+------+------+------+------+--------| + * | | % | ^ | [ | ] | ~ | | | | & | 1 | 2 | 3 | \ | | + * `--------+------+------+------+------+-------------' `-------------+------+------+------+------+--------' + * | | | | | | | | . | 0 | = | | + * `----------------------------------' `----------------------------------' + * ,-------------. ,-------------. + * | | | | | | + * ,------|------|------| |------+------+------. + * | | | | | | | | + * | | |------| |------| | | + * | | | | | | | | + * `--------------------' `--------------------' + */ +// SYMBOLS +[SYMB] = KEYMAP( + // left hand + KC_TRNS, KC_F1, KC_F2, KC_F3, KC_F4, KC_F5, KC_NO, + KC_TRNS,KC_EXLM,KC_AT, KC_LCBR,KC_RCBR,KC_PIPE,KC_TRNS, + KC_TRNS,KC_HASH,KC_DLR, KC_LPRN,KC_RPRN,KC_GRV, + KC_TRNS,KC_PERC,KC_CIRC,KC_LBRC,KC_RBRC,KC_TILD,KC_TRNS, + KC_TRNS,KC_TRNS,KC_TRNS,KC_TRNS,KC_TRNS, + KC_TRNS,KC_TRNS, + KC_TRNS, + KC_TRNS,KC_TRNS,KC_TRNS, + // right hand + KC_NO, KC_F6, KC_F7, KC_F8, KC_F9, KC_F10, KC_F11, + KC_TRNS, KC_UP, KC_7, KC_8, KC_9, KC_ASTR, KC_F12, + KC_DOWN, KC_4, KC_5, KC_6, KC_PLUS, KC_MINS, + KC_TRNS, KC_AMPR, KC_1, KC_2, KC_3, KC_BSLS, KC_TRNS, + KC_TRNS,KC_DOT, KC_0, KC_EQL, KC_NO, + KC_TRNS, KC_TRNS, + KC_TRNS, + KC_TRNS, KC_TRNS, KC_TRNS +), + +/* Keymap 2: RimWorld Layer + * + * ,--------------------------------------------------. ,--------------------------------------------------. + * | ESC | 1 | 2 | 3 | 4 | 5 | 6 | | 7 | 7 | 8 | 9 | 0 | - | = | + * |--------+------+------+------+------+-------------| |------+------+------+------+------+------+--------| + * | TAB | C | ,< | W | >. | R | | |TD(L0 | U | B | N | J | M | PGUP | + * |--------+------+------+------+------+------| F10 | |L1 L2)|------+------+------+------+------+--------| + * | I | F | A | S | D | 8 |------| |------| X | L | P | Y | H | ENTER | + * |--------+------+------+------+------+------| | | |------+------+------+------+------+--------| + * | K | F1 | F2 | F3 | F4 | F5 | F6 | | F7 | F8 | F9 | F10 | F11 | F12 | PGDN | + * `--------+------+------+------+------+-------------' `-------------+------+------+------+------+--------' + * | | | | | | | F | | | | | + * `----------------------------------' `----------------------------------' + * ,-------------. ,-------------. + * | | | | | | + * ,------|------|------| |------+------+------. + * | | | | | | | | + * |SPACE | C |------| |------| E |SPACE | + * | | | Q | | | | | + * `--------------------' `--------------------' + */ +// RIMWORLD +[RIMW] = KEYMAP( + // left hand + KC_ESC, KC_1, KC_2, KC_3, KC_4, KC_5, KC_6, + KC_TAB, KC_C, KC_COMM, KC_W, KC_DOT, KC_R, KC_F10, + KC_I, KC_F, KC_A, KC_S, KC_D, KC_8, + KC_K, KC_F1, KC_F2, KC_F3, KC_F4, KC_F5, KC_F6, + KC_TRNS,KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, + KC_TRNS,KC_TRNS, + KC_TRNS, + KC_C,KC_Q,KC_TRNS, + // right hand + KC_7, KC_7, KC_8, KC_9, KC_0, KC_MINS, KC_EQL, + KC_TRNS, KC_U, KC_B, KC_N, KC_J, KC_M, KC_PGUP, + KC_X, KC_L, SFT_T(KC_P), KC_Y, KC_H, KC_ENT, + KC_F7, KC_F8, KC_F9, KC_F10, KC_F11, KC_F12, KC_PGDN, + KC_F, KC_LEFT, KC_UP, KC_DOWN,KC_RIGHT, + KC_TRNS, KC_TRNS, + KC_TRNS, + KC_TRNS, KC_E, KC_TRNS +), +/* Keymap 3: Media and mouse keys + * + * ,--------------------------------------------------. ,--------------------------------------------------. + * | | | | | | | | | | | | | | | | + * |--------+------+------+------+------+-------------| |------+------+------+------+------+------+--------| + * | | | | MsUp | | | | | | | | | | | | + * |--------+------+------+------+------+------| | | |------+------+------+------+------+--------| + * | | |MsLeft|MsDown|MsRght| |------| |------| | | | | | Play | + * |--------+------+------+------+------+------| | | |------+------+------+------+------+--------| + * | | | | | | | | | | | | Prev | Next | | | + * `--------+------+------+------+------+-------------' `-------------+------+------+------+------+--------' + * | | | | Lclk | Rclk | |VolUp |VolDn | Mute | | | + * `----------------------------------' `----------------------------------' + * ,-------------. ,-------------. + * | | | | | | + * ,------|------|------| |------+------+------. + * | | | | | | |Brwser| + * | Lclk | Rclk |------| |------| |Back | + * | | | | | | | | + * `--------------------' `--------------------' + */ +// MEDIA AND MOUSE +[MDIA] = KEYMAP( + KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, + KC_TRNS, KC_TRNS, KC_TRNS, KC_MS_U, KC_TRNS, KC_TRNS, KC_TRNS, + KC_TRNS, KC_TRNS, KC_MS_L, KC_MS_D, KC_MS_R, KC_TRNS, + KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, + KC_TRNS, KC_TRNS, KC_TRNS, KC_BTN1, KC_BTN2, + KC_TRNS, KC_TRNS, + KC_TRNS, + KC_BTN1, KC_BTN2, KC_TRNS, + // right hand + KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, + KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, + KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_MPLY, + KC_TRNS, KC_TRNS, KC_TRNS, KC_MPRV, KC_MNXT, KC_TRNS, KC_TRNS, + KC_VOLU, KC_VOLD, KC_MUTE, KC_TRNS, KC_TRNS, + KC_TRNS, KC_TRNS, + KC_TRNS, + KC_TRNS, KC_TRNS, KC_WBAK +), +}; + +static uint16_t key_timer; + +const macro_t *action_get_macro(keyrecord_t *record, uint8_t id, uint8_t opt) +{ + switch(id) { + case 0: { + if (record->event.pressed) { + key_timer = timer_read(); // if the key is being pressed, we start the timer. + } + else { // this means the key was just released, so we can figure out how long it was pressed for (tap or "held down"). + if (timer_elapsed(key_timer) > 150) { // 150 being 150ms, the threshhold we pick for counting something as a tap. + return MACRO( D(LCTL), T(C), U(LCTL), END ); + } + else { + return MACRO( D(LCTL), T(V), U(LCTL), END ); + } + } + break; + } + } + return MACRO_NONE; +}; + +// Anything you want to do once when the keyboard initializes. +// Tests LED function when the keyboard initializes. +void matrix_init_user(void) { + + wait_ms(500); + ergodox_board_led_on(); + wait_ms(200); + ergodox_right_led_1_on(); + wait_ms(200); + ergodox_right_led_2_on(); + wait_ms(200); + ergodox_right_led_3_on(); + wait_ms(200); + ergodox_board_led_off(); + wait_ms(200); + ergodox_right_led_1_off(); + wait_ms(200); + ergodox_right_led_2_off(); + wait_ms(200); + ergodox_right_led_3_off(); + +}; + + +// Runs constantly in the background, in a loop. +void matrix_scan_user(void) { + + uint8_t layer = biton32(layer_state); + + ergodox_board_led_off(); + ergodox_right_led_1_off(); + ergodox_right_led_2_off(); + ergodox_right_led_3_off(); + switch (layer) { + case 1: + ergodox_right_led_1_on(); + break; + case 2: + ergodox_right_led_2_on(); + break; + case 3: + ergodox_right_led_3_on(); + break; + default: + // none + break; + } + +}; diff --git a/keyboards/ergodox/keymaps/win10_writers-block/readme.md b/keyboards/ergodox/keymaps/win10_writers-block/readme.md index 66b1aaf40d..e51e3c48fc 100644 --- a/keyboards/ergodox/keymaps/win10_writers-block/readme.md +++ b/keyboards/ergodox/keymaps/win10_writers-block/readme.md @@ -1,113 +1,113 @@ - - -Win10 Writer's Block ErgoDox - v1.0 - -======================= - -This is a QWERTY layout for QMK. It's designed to work well in MS Office-like environments. It's tested on Windows 7 and 10. - -Professional writers may find this layout useful -- copywriters, technical writers, novelists, etc. - -I use my ErgoDox with this keymap as a daily driver at my office. - -A gaming layer is unobtrusively built into this layout. I use that layer to play RimWorld. - -Feel free to modify the gaming layer to your personal taste. - -## Table of Contents - -* [Layouts](#layouts) - - [Base layer](#base-layer) - - [Symbol layer](#symbol-layer) - - [Gaming layer](#rimworld-layer) - - [Media layer](#media-layer) -* [Tools](#tools) - - [Layer notification](#layer-notification) -* [Building](#building) - - [Using on Windows](#using-on-windows) -* [License](#license) -* [Special Thanks](#special-thanks) - -# Layouts - -* TapDance will teleport you to the layer you want: -* One Tap for the Base layer -* Two Taps for the Symbol layer -* Three Taps for the Rimworld/Gaming layer - -* Where the "Meh" key is located on the Ergodox EZ default layout, I've changed it to another tap dance key: -* One Tap for CTRL-ALT-DEL -* Two Taps for the Media/Mouse layer - -## Base layer - -[![Base layer](images/base-layer.png)](http://www.keyboard-layout-editor.com/#/gists/8fd9bbdd3a23bbb5a8779de3624a3be1) - -This is a QWERTY layout with some quirks. - -* Enter is located on a key that won't cause as much thumb fatigue. -* Copy and Paste work from the same key. Just hold the key to copy and tap the key to paste! -* Undo, Find and Cut are also one-touch keys. -* F12 is where you would normally find TAB on standard layouts. Quickly save in Word, safely. -* You'll find bracket keys below the "6" key. - -* The Meh Key is a single-button CTRL+ALT+SHIFT modifier. - -* Space Cadet Shift: Tap L Shift for "(" and R Shift for ")" -- holding either shift works like a normal shift. -* Tap "Z" or Tab to use either normally. Hold them for CTRL. -* Tap Caps Lock to use it normally. Hold it for Win key combinations (Win+D to minimize all programs, etc). - -## Symbol layer - -[![Symbol layer](images/symbol-layer.png)](http://www.keyboard-layout-editor.com/#/gists/04eb6458b8b17882e472f64d482f12b4) - -Your standard Ergodox EZ symbol + numpad layout, minus the Version and EEPROM keys. - -* From the base layer, hold the F12 Key to temporarily access this layer (use for quick access to numpad) -* Release F12 to return to the base layer. - -## Rimworld layer - -[![Rimworld / Gaming Layer](images/rimworld-layer.png)](http://www.keyboard-layout-editor.com/#/gists/d53af8391e6e443ed0a98ccfbdb4eace) - -This layer was made to play RimWorld, a Sci-Fi Colony Survival Game by Tynan Sylvester and Ludeon Studios, available on Steam. - -* Have fun! - -## Media layer - -[![Media layer](images/media-layer.png)](http://www.keyboard-layout-editor.com/#/gists/3209d09ed4bd997e4f49f28c6ada2ab3) - -This is the standard Ergodox EZ media layout with more options for mouseclick buttons. - -* In this layer, your "space" key changes into a back button for your browser. - -## LED states - -Your LEDs will change to indicate your layer. You'll know you are in the base layer if all LEDs are off. - -# Building - -To build, you will need the [QMK][qmk] firmware checked out. from there, dive into `keyboards/ergodox/keymaps/win10_writers-block/` - -[qmk]: https://github.com/jackhumbert/qmk_firmware - -``` -$ make keyboard=ergodox keymap=win10_writers-block -``` - -## Using on Windows - -This layout is tested in Windows 7 Pro and Windows 10 Home environments. - -# License - -GPL 3+ - -# Special Thanks - -* To algernon for his coding help. I'm a novice but I still made this work (and figured out tap dance) with his help. - -* To /r/MechanicalKeyboards for being an all-around great community. - + + +Win10 Writer's Block ErgoDox - v1.0 + +======================= + +This is a QWERTY layout for QMK. It's designed to work well in MS Office-like environments. It's tested on Windows 7 and 10. + +Professional writers may find this layout useful -- copywriters, technical writers, novelists, etc. + +I use my ErgoDox with this keymap as a daily driver at my office. + +A gaming layer is unobtrusively built into this layout. I use that layer to play RimWorld. + +Feel free to modify the gaming layer to your personal taste. + +## Table of Contents + +* [Layouts](#layouts) + - [Base layer](#base-layer) + - [Symbol layer](#symbol-layer) + - [Gaming layer](#rimworld-layer) + - [Media layer](#media-layer) +* [Tools](#tools) + - [Layer notification](#layer-notification) +* [Building](#building) + - [Using on Windows](#using-on-windows) +* [License](#license) +* [Special Thanks](#special-thanks) + +# Layouts + +* TapDance will teleport you to the layer you want: +* One Tap for the Base layer +* Two Taps for the Symbol layer +* Three Taps for the Rimworld/Gaming layer + +* Where the "Meh" key is located on the Ergodox EZ default layout, I've changed it to another tap dance key: +* One Tap for CTRL-ALT-DEL +* Two Taps for the Media/Mouse layer + +## Base layer + +[![Base layer](images/base-layer.png)](http://www.keyboard-layout-editor.com/#/gists/8fd9bbdd3a23bbb5a8779de3624a3be1) + +This is a QWERTY layout with some quirks. + +* Enter is located on a key that won't cause as much thumb fatigue. +* Copy and Paste work from the same key. Just hold the key to copy and tap the key to paste! +* Undo, Find and Cut are also one-touch keys. +* F12 is where you would normally find TAB on standard layouts. Quickly save in Word, safely. +* You'll find bracket keys below the "6" key. + +* The Meh Key is a single-button CTRL+ALT+SHIFT modifier. + +* Space Cadet Shift: Tap L Shift for "(" and R Shift for ")" -- holding either shift works like a normal shift. +* Tap "Z" or Tab to use either normally. Hold them for CTRL. +* Tap Caps Lock to use it normally. Hold it for Win key combinations (Win+D to minimize all programs, etc). + +## Symbol layer + +[![Symbol layer](images/symbol-layer.png)](http://www.keyboard-layout-editor.com/#/gists/04eb6458b8b17882e472f64d482f12b4) + +Your standard Ergodox EZ symbol + numpad layout, minus the Version and EEPROM keys. + +* From the base layer, hold the F12 Key to temporarily access this layer (use for quick access to numpad) +* Release F12 to return to the base layer. + +## Rimworld layer + +[![Rimworld / Gaming Layer](images/rimworld-layer.png)](http://www.keyboard-layout-editor.com/#/gists/d53af8391e6e443ed0a98ccfbdb4eace) + +This layer was made to play RimWorld, a Sci-Fi Colony Survival Game by Tynan Sylvester and Ludeon Studios, available on Steam. + +* Have fun! + +## Media layer + +[![Media layer](images/media-layer.png)](http://www.keyboard-layout-editor.com/#/gists/3209d09ed4bd997e4f49f28c6ada2ab3) + +This is the standard Ergodox EZ media layout with more options for mouseclick buttons. + +* In this layer, your "space" key changes into a back button for your browser. + +## LED states + +Your LEDs will change to indicate your layer. You'll know you are in the base layer if all LEDs are off. + +# Building + +To build, you will need the [QMK][qmk] firmware checked out. from there, dive into `keyboards/ergodox/keymaps/win10_writers-block/` + +[qmk]: https://github.com/jackhumbert/qmk_firmware + +``` +$ make keyboard=ergodox keymap=win10_writers-block +``` + +## Using on Windows + +This layout is tested in Windows 7 Pro and Windows 10 Home environments. + +# License + +GPL 3+ + +# Special Thanks + +* To algernon for his coding help. I'm a novice but I still made this work (and figured out tap dance) with his help. + +* To /r/MechanicalKeyboards for being an all-around great community. + * To /u/profet23 for his amazing custom Ergodox boards. \ No newline at end of file From 2082c6f11076dd8232aea65ed178dea27d3a4109 Mon Sep 17 00:00:00 2001 From: dbroqua Date: Wed, 26 Oct 2016 22:24:26 +0200 Subject: [PATCH 04/15] - Fixed typo in gh60/dbroqua layout --- keyboards/kc60/keymaps/dbroqua/keymap.c | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/keyboards/kc60/keymaps/dbroqua/keymap.c b/keyboards/kc60/keymaps/dbroqua/keymap.c index 1b645ea938..8b5efd0cee 100644 --- a/keyboards/kc60/keymaps/dbroqua/keymap.c +++ b/keyboards/kc60/keymaps/dbroqua/keymap.c @@ -61,7 +61,7 @@ const uint16_t PROGMEM keymaps[][MATRIX_ROWS][MATRIX_COLS] = { * |-----------------------------------------------------------------------------------------+ * | | | | | | | | Psc | | | | | | * |-----------------------------------------------------------------------------------------+ - * | | Led | Led-| Led+| | Mute| Vol+| Vol-| | | | Play | | + * | | Led | Led+| Led-| | Mute| Vol+| Vol-| | | | Play | | * |-----------------------------------------------------------------------------------------+ * | | | | | | Prev | Stop | Next | * `-----------------------------------------------------------------------------------------' From 508eddf8ba8548d3f71e1c09a404839beb49f45c Mon Sep 17 00:00:00 2001 From: IBNobody Date: Fri, 28 Oct 2016 14:21:38 -0500 Subject: [PATCH 05/15] Fixing Debounce - WIP --- keyboards/vision_division/config.h | 2 +- quantum/matrix.c | 256 +++++++++++++++++++---------- tmk_core/common/matrix.h | 10 ++ 3 files changed, 179 insertions(+), 89 deletions(-) diff --git a/keyboards/vision_division/config.h b/keyboards/vision_division/config.h index 93c9606712..5798d91adf 100644 --- a/keyboards/vision_division/config.h +++ b/keyboards/vision_division/config.h @@ -31,7 +31,7 @@ along with this program. If not, see . #define BACKLIGHT_LEVELS 3 /* Debounce reduces chatter (unintended double-presses) - set 0 if debouncing is not needed */ -#define DEBOUNCING_DELAY 5 +#define DEBOUNCING_DELAY 0 #define MATRIX_MASKED diff --git a/quantum/matrix.c b/quantum/matrix.c index ac81794e59..a7dab09877 100644 --- a/quantum/matrix.c +++ b/quantum/matrix.c @@ -26,6 +26,33 @@ along with this program. If not, see . #include "util.h" #include "matrix.h" +#if (MATRIX_COLS <= 8) +# define print_matrix_header() print("\nr/c 01234567\n") +# define print_matrix_row(row) print_bin_reverse8(matrix_get_row(row)) +# define matrix_bitpop(i) bitpop(matrix[i]) +# define ROW_SHIFTER ((uint8_t)1) +#elif (MATRIX_COLS <= 16) +# define print_matrix_header() print("\nr/c 0123456789ABCDEF\n") +# define print_matrix_row(row) print_bin_reverse16(matrix_get_row(row)) +# define matrix_bitpop(i) bitpop16(matrix[i]) +# define ROW_SHIFTER ((uint16_t)1) +#elif (MATRIX_COLS <= 32) +# define print_matrix_header() print("\nr/c 0123456789ABCDEF0123456789ABCDEF\n") +# define print_matrix_row(row) print_bin_reverse32(matrix_get_row(row)) +# define matrix_bitpop(i) bitpop32(matrix[i]) +# define ROW_SHIFTER ((uint32_t)1) +#endif + +#if (MATRIX_ROWS <= 8) +# define COL_SHIFTER ((uint8_t)1) +#elif (MATRIX_ROWS <= 16) +# define COL_SHIFTER ((uint16_t)1) +#elif (MATRIX_ROWS <= 32) +# define COL_SHIFTER ((uint32_t)1) +#endif + + + #ifdef MATRIX_MASKED extern const matrix_row_t matrix_mask[]; #endif @@ -42,24 +69,28 @@ static const uint8_t col_pins[MATRIX_COLS] = MATRIX_COL_PINS; /* matrix state(1:on, 0:off) */ static matrix_row_t matrix[MATRIX_ROWS]; -static matrix_row_t matrix_debouncing[MATRIX_ROWS]; -#if DIODE_DIRECTION == ROW2COL - static matrix_row_t matrix_reversed[MATRIX_COLS]; - static matrix_row_t matrix_reversed_debouncing[MATRIX_COLS]; +#if DIODE_DIRECTION == COL2ROW + static matrix_row_t matrix_debouncing[MATRIX_ROWS]; +#else // ROW2COL + static matrix_col_t matrix_transposed[MATRIX_COLS]; + static matrix_col_t matrix_transposed_debouncing[MATRIX_COLS]; #endif -#if MATRIX_COLS > 16 - #define SHIFTER 1UL -#else - #define SHIFTER 1 +#if (DIODE_DIRECTION == COL2ROW) + static void init_cols(void); + static matrix_row_t read_cols(void); + static void unselect_rows(void); + static void select_row(uint8_t row); + static void unselect_row(uint8_t row); +#else // ROW2COL + static void init_rows(void); + static matrix_col_t read_rows(void); + static void unselect_cols(void); + static void unselect_col(uint8_t col); + static void select_col(uint8_t col); #endif -static matrix_row_t read_cols(void); -static void init_cols(void); -static void unselect_rows(void); -static void select_row(uint8_t row); - __attribute__ ((weak)) void matrix_init_quantum(void) { matrix_init_kb(); @@ -99,7 +130,7 @@ uint8_t matrix_cols(void) { } // void matrix_power_up(void) { -// #if DIODE_DIRECTION == COL2ROW +// #if (DIODE_DIRECTION == COL2ROW) // for (int8_t r = MATRIX_ROWS - 1; r >= 0; --r) { // /* DDRxn */ // _SFR_IO8((row_pins[r] >> 4) + 1) |= _BV(row_pins[r] & 0xF); @@ -123,13 +154,15 @@ uint8_t matrix_cols(void) { // } void matrix_init(void) { + // To use PORTF disable JTAG with writing JTD bit twice within four cycles. - #ifdef __AVR_ATmega32U4__ + #if (defined(__AVR_AT90USB1286__) || defined(__AVR_AT90USB1287__) || defined(__AVR_ATmega32U4__)) MCUCR |= _BV(JTD); MCUCR |= _BV(JTD); #endif // initialize row and col +#if (DIODE_DIRECTION == COL2ROW) unselect_rows(); init_cols(); @@ -139,25 +172,43 @@ void matrix_init(void) { matrix_debouncing[i] = 0; } +#else // ROW2COL + unselect_cols(); + init_rows(); + + // initialize matrix state: all keys off + for (uint8_t i=0; i < MATRIX_ROWS; i++) { + matrix[i] = 0; + } + + // initialize matrix state: all keys off + for (uint8_t i=0; i < MATRIX_COLS; i++) { + matrix_transposed_debouncing[i] = 0; + } +#endif + matrix_init_quantum(); } uint8_t matrix_scan(void) { -#if DIODE_DIRECTION == COL2ROW +#if (DIODE_DIRECTION == COL2ROW) + + // Set row, read cols + for (uint8_t i = 0; i < MATRIX_ROWS; i++) { select_row(i); wait_us(30); // without this wait read unstable value. - matrix_row_t cols = read_cols(); - if (matrix_debouncing[i] != cols) { - matrix_debouncing[i] = cols; + matrix_row_t current_row = read_cols(); + if (matrix_debouncing[i] != current_row) { + matrix_debouncing[i] = current_row; if (debouncing) { debug("bounce!: "); debug_hex(debouncing); debug("\n"); } debouncing = DEBOUNCING_DELAY; } - unselect_rows(); + unselect_row(i); } if (debouncing) { @@ -169,19 +220,23 @@ uint8_t matrix_scan(void) } } } -#else + +#else // ROW2COL + + // Set col, read rows + for (uint8_t i = 0; i < MATRIX_COLS; i++) { - select_row(i); + select_col(i); wait_us(30); // without this wait read unstable value. - matrix_row_t rows = read_cols(); - if (matrix_reversed_debouncing[i] != rows) { - matrix_reversed_debouncing[i] = rows; + matrix_col_t current_col = read_rows(); + if (matrix_transposed_debouncing[i] != current_col) { + matrix_transposed_debouncing[i] = current_col; if (debouncing) { debug("bounce!: "); debug_hex(debouncing); debug("\n"); } debouncing = DEBOUNCING_DELAY; } - unselect_rows(); + unselect_col(i); } if (debouncing) { @@ -189,17 +244,20 @@ uint8_t matrix_scan(void) wait_ms(1); } else { for (uint8_t i = 0; i < MATRIX_COLS; i++) { - matrix_reversed[i] = matrix_reversed_debouncing[i]; + matrix_transposed[i] = matrix_transposed_debouncing[i]; } } } + + // Untranspose matrix for (uint8_t y = 0; y < MATRIX_ROWS; y++) { matrix_row_t row = 0; for (uint8_t x = 0; x < MATRIX_COLS; x++) { - row |= ((matrix_reversed[x] & (1<> y) << x; + row |= ((matrix_transposed[x] & (1<> y) << x; } matrix[y] = row; } + #endif matrix_scan_quantum(); @@ -233,23 +291,11 @@ matrix_row_t matrix_get_row(uint8_t row) void matrix_print(void) { -#if (MATRIX_COLS <= 8) - print("\nr/c 01234567\n"); -#elif (MATRIX_COLS <= 16) - print("\nr/c 0123456789ABCDEF\n"); -#elif (MATRIX_COLS <= 32) - print("\nr/c 0123456789ABCDEF0123456789ABCDEF\n"); -#endif + print_matrix_header(); for (uint8_t row = 0; row < MATRIX_ROWS; row++) { phex(row); print(": "); -#if (MATRIX_COLS <= 8) - print_bin_reverse8(matrix_get_row(row)); -#elif (MATRIX_COLS <= 16) - print_bin_reverse16(matrix_get_row(row)); -#elif (MATRIX_COLS <= 32) - print_bin_reverse32(matrix_get_row(row)); -#endif + print_matrix_row(row); print("\n"); } } @@ -258,28 +304,21 @@ uint8_t matrix_key_count(void) { uint8_t count = 0; for (uint8_t i = 0; i < MATRIX_ROWS; i++) { -#if (MATRIX_COLS <= 8) - count += bitpop(matrix[i]); -#elif (MATRIX_COLS <= 16) - count += bitpop16(matrix[i]); -#elif (MATRIX_COLS <= 32) - count += bitpop32(matrix[i]); -#endif + count += matrix_bitpop(i); } return count; } + + +#if (DIODE_DIRECTION == COL2ROW) + static void init_cols(void) { -#if DIODE_DIRECTION == COL2ROW - for(int x = 0; x < MATRIX_COLS; x++) { - int pin = col_pins[x]; -#else - for(int x = 0; x < MATRIX_ROWS; x++) { - int pin = row_pins[x]; -#endif - _SFR_IO8((pin >> 4) + 1) &= ~_BV(pin & 0xF); - _SFR_IO8((pin >> 4) + 2) |= _BV(pin & 0xF); + for(uint8_t x = 0; x < MATRIX_COLS; x++) { + uint8_t pin = col_pins[x]; + _SFR_IO8((pin >> 4) + 1) &= ~_BV(pin & 0xF); // IN + _SFR_IO8((pin >> 4) + 2) |= _BV(pin & 0xF); // HI } } @@ -287,40 +326,81 @@ static matrix_row_t read_cols(void) { matrix_row_t result = 0; -#if DIODE_DIRECTION == COL2ROW - for(int x = 0; x < MATRIX_COLS; x++) { - int pin = col_pins[x]; -#else - for(int x = 0; x < MATRIX_ROWS; x++) { - int pin = row_pins[x]; -#endif - result |= (_SFR_IO8(pin >> 4) & _BV(pin & 0xF)) ? 0 : (SHIFTER << x); + for(uint8_t x = 0; x < MATRIX_COLS; x++) { + uint8_t pin = col_pins[x]; + result |= (_SFR_IO8(pin >> 4) & _BV(pin & 0xF)) ? 0 : (ROW_SHIFTER << x); } - return result; -} -static void unselect_rows(void) -{ -#if DIODE_DIRECTION == COL2ROW - for(int x = 0; x < MATRIX_ROWS; x++) { - int pin = row_pins[x]; -#else - for(int x = 0; x < MATRIX_COLS; x++) { - int pin = col_pins[x]; -#endif - _SFR_IO8((pin >> 4) + 1) &= ~_BV(pin & 0xF); - _SFR_IO8((pin >> 4) + 2) |= _BV(pin & 0xF); - } + return result; } static void select_row(uint8_t row) { - -#if DIODE_DIRECTION == COL2ROW - int pin = row_pins[row]; -#else - int pin = col_pins[row]; -#endif - _SFR_IO8((pin >> 4) + 1) |= _BV(pin & 0xF); - _SFR_IO8((pin >> 4) + 2) &= ~_BV(pin & 0xF); + uint8_t pin = row_pins[row]; + _SFR_IO8((pin >> 4) + 1) |= _BV(pin & 0xF); // OUT + _SFR_IO8((pin >> 4) + 2) &= ~_BV(pin & 0xF); // LOW } + +static void unselect_row(uint8_t row) +{ + uint8_t pin = row_pins[row]; + _SFR_IO8((pin >> 4) + 1) &= ~_BV(pin & 0xF); // IN + _SFR_IO8((pin >> 4) + 2) |= _BV(pin & 0xF); // HI +} + +static void unselect_rows(void) +{ + for(uint8_t x = 0; x < MATRIX_ROWS; x++) { + uint8_t pin = row_pins[x]; + _SFR_IO8((pin >> 4) + 1) &= ~_BV(pin & 0xF); // IN + _SFR_IO8((pin >> 4) + 2) |= _BV(pin & 0xF); // HI + } +} + +#else // ROW2COL + +static void init_rows(void) +{ + for(uint8_t x = 0; x < MATRIX_ROWS; x++) { + uint8_t pin = row_pins[x]; + _SFR_IO8((pin >> 4) + 1) &= ~_BV(pin & 0xF); // IN + _SFR_IO8((pin >> 4) + 2) |= _BV(pin & 0xF); // HI + } +} + +static matrix_col_t read_rows(void) +{ + matrix_col_t result = 0; + + for(uint8_t x = 0; x < MATRIX_ROWS; x++) { + uint8_t pin = row_pins[x]; + result |= (_SFR_IO8(pin >> 4) & _BV(pin & 0xF)) ? 0 : (COL_SHIFTER << x); + } + + return result; +} + +static void select_col(uint8_t col) +{ + uint8_t pin = col_pins[col]; + _SFR_IO8((pin >> 4) + 1) |= _BV(pin & 0xF); // OUT + _SFR_IO8((pin >> 4) + 2) &= ~_BV(pin & 0xF); // LOW +} + +static void unselect_col(uint8_t col) +{ + uint8_t pin = col_pins[col]; + _SFR_IO8((pin >> 4) + 1) &= ~_BV(pin & 0xF); // IN + _SFR_IO8((pin >> 4) + 2) |= _BV(pin & 0xF); // HI +} + +static void unselect_cols(void) +{ + for(uint8_t x = 0; x < MATRIX_COLS; x++) { + uint8_t pin = col_pins[x]; + _SFR_IO8((pin >> 4) + 1) &= ~_BV(pin & 0xF); // IN + _SFR_IO8((pin >> 4) + 2) |= _BV(pin & 0xF); // HI + } +} + +#endif diff --git a/tmk_core/common/matrix.h b/tmk_core/common/matrix.h index cee3593eee..84e066c673 100644 --- a/tmk_core/common/matrix.h +++ b/tmk_core/common/matrix.h @@ -31,6 +31,16 @@ typedef uint32_t matrix_row_t; #error "MATRIX_COLS: invalid value" #endif +#if (MATRIX_ROWS <= 8) +typedef uint8_t matrix_col_t; +#elif (MATRIX_ROWS <= 16) +typedef uint16_t matrix_col_t; +#elif (MATRIX_ROWS <= 32) +typedef uint32_t matrix_col_t; +#else +#error "MATRIX_COLS: invalid value" +#endif + #define MATRIX_IS_ON(row, col) (matrix_get_row(row) && (1< Date: Fri, 28 Oct 2016 16:24:20 -0500 Subject: [PATCH 06/15] Refactoring Matrix scanning --- quantum/matrix.c | 173 +++++++++++++++++++++------------------ tmk_core/common/matrix.h | 10 --- 2 files changed, 95 insertions(+), 88 deletions(-) diff --git a/quantum/matrix.c b/quantum/matrix.c index a7dab09877..1bacea1bed 100644 --- a/quantum/matrix.c +++ b/quantum/matrix.c @@ -43,16 +43,6 @@ along with this program. If not, see . # define ROW_SHIFTER ((uint32_t)1) #endif -#if (MATRIX_ROWS <= 8) -# define COL_SHIFTER ((uint8_t)1) -#elif (MATRIX_ROWS <= 16) -# define COL_SHIFTER ((uint16_t)1) -#elif (MATRIX_ROWS <= 32) -# define COL_SHIFTER ((uint32_t)1) -#endif - - - #ifdef MATRIX_MASKED extern const matrix_row_t matrix_mask[]; #endif @@ -70,6 +60,9 @@ static const uint8_t col_pins[MATRIX_COLS] = MATRIX_COL_PINS; /* matrix state(1:on, 0:off) */ static matrix_row_t matrix[MATRIX_ROWS]; +static matrix_row_t matrix_raw[MATRIX_ROWS]; + + #if DIODE_DIRECTION == COL2ROW static matrix_row_t matrix_debouncing[MATRIX_ROWS]; #else // ROW2COL @@ -79,13 +72,13 @@ static matrix_row_t matrix[MATRIX_ROWS]; #if (DIODE_DIRECTION == COL2ROW) static void init_cols(void); - static matrix_row_t read_cols(void); + static void read_cols_on_row(matrix_row_t current_matrix[], uint8_t current_row) static void unselect_rows(void); static void select_row(uint8_t row); static void unselect_row(uint8_t row); #else // ROW2COL static void init_rows(void); - static matrix_col_t read_rows(void); + static void read_rows_on_col(matrix_row_t current_matrix[], uint8_t current_col) static void unselect_cols(void); static void unselect_col(uint8_t col); static void select_col(uint8_t col); @@ -169,6 +162,7 @@ void matrix_init(void) { // initialize matrix state: all keys off for (uint8_t i=0; i < MATRIX_ROWS; i++) { matrix[i] = 0; + matrix_raw[i] = 0; matrix_debouncing[i] = 0; } @@ -178,6 +172,7 @@ void matrix_init(void) { // initialize matrix state: all keys off for (uint8_t i=0; i < MATRIX_ROWS; i++) { + matrix_raw[i] = 0; matrix[i] = 0; } @@ -196,67 +191,73 @@ uint8_t matrix_scan(void) #if (DIODE_DIRECTION == COL2ROW) // Set row, read cols - - for (uint8_t i = 0; i < MATRIX_ROWS; i++) { - select_row(i); - wait_us(30); // without this wait read unstable value. - matrix_row_t current_row = read_cols(); - if (matrix_debouncing[i] != current_row) { - matrix_debouncing[i] = current_row; - if (debouncing) { - debug("bounce!: "); debug_hex(debouncing); debug("\n"); - } - debouncing = DEBOUNCING_DELAY; - } - unselect_row(i); + for (uint8_t current_row = 0; current_row < MATRIX_ROWS; current_row++) { + read_cols_on_row(matrix, current_row); } - if (debouncing) { - if (--debouncing) { - wait_ms(1); - } else { - for (uint8_t i = 0; i < MATRIX_ROWS; i++) { - matrix[i] = matrix_debouncing[i]; - } - } - } + // select_row(i); + // wait_us(30); // without this wait read unstable value. + // matrix_row_t current_row = read_cols(); + // if (matrix_debouncing[i] != current_row) { + // matrix_debouncing[i] = current_row; + // if (debouncing) { + // debug("bounce!: "); debug_hex(debouncing); debug("\n"); + // } + // debouncing = DEBOUNCING_DELAY; + // } + // unselect_row(i); + // } + + // if (debouncing) { + // if (--debouncing) { + // wait_ms(1); + // } else { + // for (uint8_t i = 0; i < MATRIX_ROWS; i++) { + // matrix[i] = matrix_debouncing[i]; + // } + // } + // } #else // ROW2COL // Set col, read rows - - for (uint8_t i = 0; i < MATRIX_COLS; i++) { - select_col(i); - wait_us(30); // without this wait read unstable value. - matrix_col_t current_col = read_rows(); - if (matrix_transposed_debouncing[i] != current_col) { - matrix_transposed_debouncing[i] = current_col; - if (debouncing) { - debug("bounce!: "); debug_hex(debouncing); debug("\n"); - } - debouncing = DEBOUNCING_DELAY; - } - unselect_col(i); + for (uint8_t current_col = 0; current_col < MATRIX_COLS; current_col++) { + read_rows_on_col(matrix, current_col); } - if (debouncing) { - if (--debouncing) { - wait_ms(1); - } else { - for (uint8_t i = 0; i < MATRIX_COLS; i++) { - matrix_transposed[i] = matrix_transposed_debouncing[i]; - } - } - } - // Untranspose matrix - for (uint8_t y = 0; y < MATRIX_ROWS; y++) { - matrix_row_t row = 0; - for (uint8_t x = 0; x < MATRIX_COLS; x++) { - row |= ((matrix_transposed[x] & (1<> y) << x; - } - matrix[y] = row; - } + // for (uint8_t i = 0; i < MATRIX_COLS; i++) { + // select_col(i); + // wait_us(30); // without this wait read unstable value. + // matrix_col_t current_col = read_rows(); + // if (matrix_transposed_debouncing[i] != current_col) { + // matrix_transposed_debouncing[i] = current_col; + // if (debouncing) { + // debug("bounce!: "); debug_hex(debouncing); debug("\n"); + // } + // debouncing = DEBOUNCING_DELAY; + // } + // unselect_col(i); + // } + + // if (debouncing) { + // if (--debouncing) { + // wait_ms(1); + // } else { + // for (uint8_t i = 0; i < MATRIX_COLS; i++) { + // matrix_transposed[i] = matrix_transposed_debouncing[i]; + // } + // } + // } + + // // Untranspose matrix + // for (uint8_t y = 0; y < MATRIX_ROWS; y++) { + // matrix_row_t row = 0; + // for (uint8_t x = 0; x < MATRIX_COLS; x++) { + // row |= ((matrix_transposed[x] & (1<> y) << x; + // } + // matrix[y] = row; + // } #endif @@ -322,16 +323,25 @@ static void init_cols(void) } } -static matrix_row_t read_cols(void) +static void read_cols_on_row(matrix_row_t current_matrix[], uint8_t current_row) { - matrix_row_t result = 0; + // Clear data in matrix row + current_matrix[current_row] = 0; - for(uint8_t x = 0; x < MATRIX_COLS; x++) { - uint8_t pin = col_pins[x]; - result |= (_SFR_IO8(pin >> 4) & _BV(pin & 0xF)) ? 0 : (ROW_SHIFTER << x); + // Select row and wait for row selecton to stabilize + select_row(current_row); + wait_us(30); + + // For each col... + for(uint8_t col_index = 0; col_index < MATRIX_COLS; col_index++) { + + // Select the col pin to read (active low) + uint8_t pin = col_pins[col_index]; + uint8_t pin_state = (_SFR_IO8(pin >> 4) & _BV(pin & 0xF)); + + // Populate the matrix row with the state of the col pin + current_matrix[current_row] |= pin_state ? 0 : (ROW_SHIFTER << col_index); } - - return result; } static void select_row(uint8_t row) @@ -368,16 +378,23 @@ static void init_rows(void) } } -static matrix_col_t read_rows(void) +static void read_rows_on_col(matrix_row_t current_matrix[], uint8_t current_col) { - matrix_col_t result = 0; - for(uint8_t x = 0; x < MATRIX_ROWS; x++) { - uint8_t pin = row_pins[x]; - result |= (_SFR_IO8(pin >> 4) & _BV(pin & 0xF)) ? 0 : (COL_SHIFTER << x); + // Select col and wait for col selecton to stabilize + select_col(current_col); + wait_us(30); + + // For each row... + for(uint8_t row_index = 0; row_index < MATRIX_ROWS; row_index++) { + + // Select the row pin to read (active low) + uint8_t pin = row_pins[row_index]; + uint8_t pin_state = (_SFR_IO8(pin >> 4) & _BV(pin & 0xF)); + + // Populate the matrix row with the state of the col pin + current_matrix[row_index] &= pin_state ? ~(ROW_SHIFTER << current_col) : 0; } - - return result; } static void select_col(uint8_t col) diff --git a/tmk_core/common/matrix.h b/tmk_core/common/matrix.h index 84e066c673..cee3593eee 100644 --- a/tmk_core/common/matrix.h +++ b/tmk_core/common/matrix.h @@ -31,16 +31,6 @@ typedef uint32_t matrix_row_t; #error "MATRIX_COLS: invalid value" #endif -#if (MATRIX_ROWS <= 8) -typedef uint8_t matrix_col_t; -#elif (MATRIX_ROWS <= 16) -typedef uint16_t matrix_col_t; -#elif (MATRIX_ROWS <= 32) -typedef uint32_t matrix_col_t; -#else -#error "MATRIX_COLS: invalid value" -#endif - #define MATRIX_IS_ON(row, col) (matrix_get_row(row) && (1< Date: Sat, 29 Oct 2016 10:39:03 -0500 Subject: [PATCH 07/15] Made scanning more efficient --- quantum/matrix.c | 57 +++++++++++++++++++++--------------------------- 1 file changed, 25 insertions(+), 32 deletions(-) diff --git a/quantum/matrix.c b/quantum/matrix.c index 1bacea1bed..f45b251e4d 100644 --- a/quantum/matrix.c +++ b/quantum/matrix.c @@ -61,24 +61,18 @@ static const uint8_t col_pins[MATRIX_COLS] = MATRIX_COL_PINS; static matrix_row_t matrix[MATRIX_ROWS]; static matrix_row_t matrix_raw[MATRIX_ROWS]; +static matrix_row_t matrix_debouncing[MATRIX_ROWS]; -#if DIODE_DIRECTION == COL2ROW - static matrix_row_t matrix_debouncing[MATRIX_ROWS]; -#else // ROW2COL - static matrix_col_t matrix_transposed[MATRIX_COLS]; - static matrix_col_t matrix_transposed_debouncing[MATRIX_COLS]; -#endif - #if (DIODE_DIRECTION == COL2ROW) static void init_cols(void); - static void read_cols_on_row(matrix_row_t current_matrix[], uint8_t current_row) + static void read_cols_on_row(matrix_row_t current_matrix[], uint8_t current_row); static void unselect_rows(void); static void select_row(uint8_t row); static void unselect_row(uint8_t row); #else // ROW2COL static void init_rows(void); - static void read_rows_on_col(matrix_row_t current_matrix[], uint8_t current_col) + static void read_rows_on_col(matrix_row_t current_matrix[], uint8_t current_col); static void unselect_cols(void); static void unselect_col(uint8_t col); static void select_col(uint8_t col); @@ -158,6 +152,10 @@ void matrix_init(void) { #if (DIODE_DIRECTION == COL2ROW) unselect_rows(); init_cols(); +#else // ROW2COL + unselect_cols(); + init_rows(); +#endif // initialize matrix state: all keys off for (uint8_t i=0; i < MATRIX_ROWS; i++) { @@ -166,22 +164,6 @@ void matrix_init(void) { matrix_debouncing[i] = 0; } -#else // ROW2COL - unselect_cols(); - init_rows(); - - // initialize matrix state: all keys off - for (uint8_t i=0; i < MATRIX_ROWS; i++) { - matrix_raw[i] = 0; - matrix[i] = 0; - } - - // initialize matrix state: all keys off - for (uint8_t i=0; i < MATRIX_COLS; i++) { - matrix_transposed_debouncing[i] = 0; - } -#endif - matrix_init_quantum(); } @@ -262,7 +244,7 @@ uint8_t matrix_scan(void) #endif matrix_scan_quantum(); - +// matrix_print(); return 1; } @@ -342,6 +324,9 @@ static void read_cols_on_row(matrix_row_t current_matrix[], uint8_t current_row) // Populate the matrix row with the state of the col pin current_matrix[current_row] |= pin_state ? 0 : (ROW_SHIFTER << col_index); } + + // Unselect row + unselect_row(current_row); } static void select_row(uint8_t row) @@ -388,13 +373,21 @@ static void read_rows_on_col(matrix_row_t current_matrix[], uint8_t current_col) // For each row... for(uint8_t row_index = 0; row_index < MATRIX_ROWS; row_index++) { - // Select the row pin to read (active low) - uint8_t pin = row_pins[row_index]; - uint8_t pin_state = (_SFR_IO8(pin >> 4) & _BV(pin & 0xF)); - - // Populate the matrix row with the state of the col pin - current_matrix[row_index] &= pin_state ? ~(ROW_SHIFTER << current_col) : 0; + // Check row pin state + if ((_SFR_IO8(row_pins[row_index] >> 4) & _BV(row_pins[row_index] & 0xF)) == 0) + { + // Pin LO, set col bit + current_matrix[row_index] |= (ROW_SHIFTER << current_col); + } + else + { + // Pin HI, clear col bit + current_matrix[row_index] &= ~(ROW_SHIFTER << current_col); + } } + + // Unselect col + unselect_col(current_col); } static void select_col(uint8_t col) From f4030289744fc6dc82dd85c955070c0845813cc5 Mon Sep 17 00:00:00 2001 From: IBNobody Date: Sat, 29 Oct 2016 16:12:58 -0500 Subject: [PATCH 08/15] added fixed debounce code --- quantum/matrix.c | 143 +++++++++++++++++++++++------------------------ 1 file changed, 70 insertions(+), 73 deletions(-) diff --git a/quantum/matrix.c b/quantum/matrix.c index f45b251e4d..3c488b417d 100644 --- a/quantum/matrix.c +++ b/quantum/matrix.c @@ -25,6 +25,19 @@ along with this program. If not, see . #include "debug.h" #include "util.h" #include "matrix.h" +#include "timer.h" + + +/* Set 0 if debouncing isn't needed */ + +#ifndef DEBOUNCING_DELAY +# define DEBOUNCING_DELAY 5 +#endif + +#if (DEBOUNCING_DELAY > 0) + static uint16_t debouncing_time; + static bool debouncing = false; +#endif #if (MATRIX_COLS <= 8) # define print_matrix_header() print("\nr/c 01234567\n") @@ -44,16 +57,9 @@ along with this program. If not, see . #endif #ifdef MATRIX_MASKED -extern const matrix_row_t matrix_mask[]; + extern const matrix_row_t matrix_mask[]; #endif -/* Set 0 if debouncing isn't needed */ - -#ifndef DEBOUNCING_DELAY -# define DEBOUNCING_DELAY 5 -#endif -static uint8_t debouncing = DEBOUNCING_DELAY; - static const uint8_t row_pins[MATRIX_ROWS] = MATRIX_ROW_PINS; static const uint8_t col_pins[MATRIX_COLS] = MATRIX_COL_PINS; @@ -66,13 +72,13 @@ static matrix_row_t matrix_debouncing[MATRIX_ROWS]; #if (DIODE_DIRECTION == COL2ROW) static void init_cols(void); - static void read_cols_on_row(matrix_row_t current_matrix[], uint8_t current_row); + static bool read_cols_on_row(matrix_row_t current_matrix[], uint8_t current_row); static void unselect_rows(void); static void select_row(uint8_t row); static void unselect_row(uint8_t row); #else // ROW2COL static void init_rows(void); - static void read_rows_on_col(matrix_row_t current_matrix[], uint8_t current_col); + static bool read_rows_on_col(matrix_row_t current_matrix[], uint8_t current_col); static void unselect_cols(void); static void unselect_col(uint8_t col); static void select_col(uint8_t col); @@ -174,83 +180,56 @@ uint8_t matrix_scan(void) // Set row, read cols for (uint8_t current_row = 0; current_row < MATRIX_ROWS; current_row++) { - read_cols_on_row(matrix, current_row); +# if (DEBOUNCING_DELAY > 0) + bool matrix_changed = read_cols_on_row(matrix_debouncing, current_row); + + if (matrix_changed) { + debouncing = true; + debouncing_time = timer_read(); + } + +# else + read_cols_on_row(matrix, current_row); +# endif + } - // select_row(i); - // wait_us(30); // without this wait read unstable value. - // matrix_row_t current_row = read_cols(); - // if (matrix_debouncing[i] != current_row) { - // matrix_debouncing[i] = current_row; - // if (debouncing) { - // debug("bounce!: "); debug_hex(debouncing); debug("\n"); - // } - // debouncing = DEBOUNCING_DELAY; - // } - // unselect_row(i); - // } - - // if (debouncing) { - // if (--debouncing) { - // wait_ms(1); - // } else { - // for (uint8_t i = 0; i < MATRIX_ROWS; i++) { - // matrix[i] = matrix_debouncing[i]; - // } - // } - // } - #else // ROW2COL // Set col, read rows for (uint8_t current_col = 0; current_col < MATRIX_COLS; current_col++) { - read_rows_on_col(matrix, current_col); +# if (DEBOUNCING_DELAY > 0) + bool matrix_changed = read_rows_on_col(matrix_debouncing, current_col); + if (matrix_changed) { + debouncing = true; + debouncing_time = timer_read(); + } +# else + read_rows_on_col(matrix, current_col); +# endif + } - - // for (uint8_t i = 0; i < MATRIX_COLS; i++) { - // select_col(i); - // wait_us(30); // without this wait read unstable value. - // matrix_col_t current_col = read_rows(); - // if (matrix_transposed_debouncing[i] != current_col) { - // matrix_transposed_debouncing[i] = current_col; - // if (debouncing) { - // debug("bounce!: "); debug_hex(debouncing); debug("\n"); - // } - // debouncing = DEBOUNCING_DELAY; - // } - // unselect_col(i); - // } - - // if (debouncing) { - // if (--debouncing) { - // wait_ms(1); - // } else { - // for (uint8_t i = 0; i < MATRIX_COLS; i++) { - // matrix_transposed[i] = matrix_transposed_debouncing[i]; - // } - // } - // } - - // // Untranspose matrix - // for (uint8_t y = 0; y < MATRIX_ROWS; y++) { - // matrix_row_t row = 0; - // for (uint8_t x = 0; x < MATRIX_COLS; x++) { - // row |= ((matrix_transposed[x] & (1<> y) << x; - // } - // matrix[y] = row; - // } - #endif +# if (DEBOUNCING_DELAY > 0) + if (debouncing && (timer_elapsed(debouncing_time) > DEBOUNCING_DELAY)) { + for (uint8_t i = 0; i < MATRIX_ROWS; i++) { + matrix[i] = matrix_debouncing[i]; + } + debouncing = false; + } +# endif + matrix_scan_quantum(); -// matrix_print(); return 1; } bool matrix_is_modified(void) { +#if (DEBOUNCING_DELAY > 0) if (debouncing) return false; +#endif return true; } @@ -305,8 +284,11 @@ static void init_cols(void) } } -static void read_cols_on_row(matrix_row_t current_matrix[], uint8_t current_row) +static bool read_cols_on_row(matrix_row_t current_matrix[], uint8_t current_row) { + // Store last value of row prior to reading + matrix_row_t last_row_value = current_matrix[current_row]; + // Clear data in matrix row current_matrix[current_row] = 0; @@ -327,6 +309,8 @@ static void read_cols_on_row(matrix_row_t current_matrix[], uint8_t current_row) // Unselect row unselect_row(current_row); + + return (last_row_value == current_matrix[current_row]); } static void select_row(uint8_t row) @@ -363,15 +347,20 @@ static void init_rows(void) } } -static void read_rows_on_col(matrix_row_t current_matrix[], uint8_t current_col) +static bool read_rows_on_col(matrix_row_t current_matrix[], uint8_t current_col) { + bool matrix_changed = false; // Select col and wait for col selecton to stabilize select_col(current_col); wait_us(30); // For each row... - for(uint8_t row_index = 0; row_index < MATRIX_ROWS; row_index++) { + for(uint8_t row_index = 0; row_index < MATRIX_ROWS; row_index++) + { + + // Store last value of row prior to reading + matrix_row_t last_row_value = current_matrix[row_index]; // Check row pin state if ((_SFR_IO8(row_pins[row_index] >> 4) & _BV(row_pins[row_index] & 0xF)) == 0) @@ -384,10 +373,18 @@ static void read_rows_on_col(matrix_row_t current_matrix[], uint8_t current_col) // Pin HI, clear col bit current_matrix[row_index] &= ~(ROW_SHIFTER << current_col); } + + // Determine if the matrix changed state + if ((last_row_value != current_matrix[row_index]) && !(matrix_changed)) + { + matrix_changed = true; + } } // Unselect col unselect_col(current_col); + + return matrix_changed; } static void select_col(uint8_t col) From 78976d8f7a7702eb4e94819af40fb3b32ac6825f Mon Sep 17 00:00:00 2001 From: IBNobody Date: Tue, 1 Nov 2016 11:52:58 -0500 Subject: [PATCH 09/15] Adding SKIP_GIT to speed up compiles. --- Makefile | 57 ++++++++++++++++++++++++++++++++++++++------------------ 1 file changed, 39 insertions(+), 18 deletions(-) diff --git a/Makefile b/Makefile index 66c0ff30f4..aa33c40f1f 100644 --- a/Makefile +++ b/Makefile @@ -38,7 +38,7 @@ ERROR_FILE := $(BUILD_DIR)/error_occured MAKEFILE_INCLUDED=yes -# Helper function to process the newt element of a space separated path +# Helper function to process the newt element of a space separated path # It works a bit like the traditional functional head tail # so the CURRENT_PATH_ELEMENT will beome the new head # and the PATH_ELEMENTS are the rest that are still unprocessed @@ -47,16 +47,16 @@ define NEXT_PATH_ELEMENT $$(eval PATH_ELEMENTS := $$(wordlist 2,9999,$$(PATH_ELEMENTS))) endef -# We change the / to spaces so that we more easily can work with the elements +# We change the / to spaces so that we more easily can work with the elements # separately PATH_ELEMENTS := $(subst /, ,$(STARTING_DIR)) # Initialize the path elements list for further processing $(eval $(call NEXT_PATH_ELEMENT)) -# This function sets the KEYBOARD; KEYMAP and SUBPROJECT to the correct +# This function sets the KEYBOARD; KEYMAP and SUBPROJECT to the correct # variables depending on which directory you stand in. -# It's really a very simple if else chain, if you squint enough, -# but the makefile syntax makes it very verbose. +# It's really a very simple if else chain, if you squint enough, +# but the makefile syntax makes it very verbose. # If we are in a subfolder of keyboards ifeq ($(CURRENT_PATH_ELEMENT),keyboards) $(eval $(call NEXT_PATH_ELEMENT)) @@ -111,7 +111,7 @@ endif .DEFAULT_GOAL := all ifneq ($(KEYMAP),) ifeq ($(SUBPROJECT),) - # Inside a keymap folder, just build the keymap, with the + # Inside a keymap folder, just build the keymap, with the # default subproject .DEFAULT_GOAL := $(KEYBOARD)-$(KEYMAP) else @@ -163,7 +163,7 @@ define TRY_TO_MATCH_RULE_FROM_LIST_HELPER3 ifneq ($1,) ifeq ($$(call COMPARE_AND_REMOVE_FROM_RULE,$$(firstword $1)),true) MATCHED_ITEM := $$(firstword $1) - else + else $$(eval $$(call TRY_TO_MATCH_RULE_FROM_LIST_HELPER3,$$(wordlist 2,9999,$1))) endif endif @@ -171,10 +171,10 @@ endef # A recursive helper function for finding the longest match # $1 The list to be checed -# It works by always removing the currently matched item from the list +# It works by always removing the currently matched item from the list # and call itself recursively, until a match is found define TRY_TO_MATCH_RULE_FROM_LIST_HELPER2 - # Stop the recursion when the list is empty + # Stop the recursion when the list is empty ifneq ($1,) RULE_BEFORE := $$(RULE) $$(eval $$(call TRY_TO_MATCH_RULE_FROM_LIST_HELPER3,$1)) @@ -270,7 +270,7 @@ define PARSE_KEYBOARD $$(eval $$(call PARSE_SUBPROJECT,$$(SUBPROJECT))) # If there's no matching subproject, we assume it's the default # This will allow you to leave the subproject part of the target out - else + else $$(eval $$(call PARSE_SUBPROJECT,)) endif endef @@ -285,7 +285,7 @@ endef # When entering this, the keyboard and subproject are known, so now we need # to determine which keymaps are going to get compiled define PARSE_SUBPROJECT - # If we want to compile the default subproject, then we need to + # If we want to compile the default subproject, then we need to # include the correct makefile to determine the actual name of it CURRENT_SP := $1 ifeq ($$(CURRENT_SP),) @@ -304,7 +304,7 @@ define PARSE_SUBPROJECT endif endif # The special allsp is handled later - ifneq ($$(CURRENT_SP),allsp) + ifneq ($$(CURRENT_SP),allsp) # get a list of all keymaps KEYMAPS := $$(notdir $$(patsubst %/.,%,$$(wildcard $(ROOT_DIR)/keyboards/$$(CURRENT_KB)/keymaps/*/.))) ifneq ($$(CURRENT_SP),) @@ -343,7 +343,7 @@ define PARSE_SUBPROJECT endif endef -# If we want to parse all subprojects, but the keyboard doesn't have any, +# If we want to parse all subprojects, but the keyboard doesn't have any, # then use defaultsp instead define PARSE_ALL_SUBPROJECTS ifeq ($$(SUBPROJECTS),) @@ -448,7 +448,7 @@ endef # Set the silent mode depending on if we are trying to compile multiple keyboards or not -# By default it's on in that case, but it can be overriden by specifying silent=false +# By default it's on in that case, but it can be overriden by specifying silent=false # from the command line define SET_SILENT_MODE ifdef SUB_IS_SILENT @@ -481,11 +481,12 @@ endef # Allow specifying just the subproject, in the keyboard directory, which will compile all keymaps SUBPROJECTS := $(notdir $(patsubst %/Makefile,%,$(wildcard ./*/Makefile))) .PHONY: $(SUBPROJECTS) -$(SUBPROJECTS): %: %-allkm +$(SUBPROJECTS): %: %-allkm # Let's match everything, we handle all the rule parsing ourselves .PHONY: % -%: +ifndef SKIP_GIT +%: # Check if we have the CMP tool installed cmp --version >/dev/null 2>&1; if [ $$? -gt 0 ]; then printf "$(MSG_NO_CMP)"; exit 1; fi; # Check if the submodules are dirty, and display a warning if they are @@ -505,8 +506,24 @@ $(SUBPROJECTS): %: %-allkm # But we return the error code at the end, to trigger travis failures $(foreach COMMAND,$(COMMANDS),$(RUN_COMMAND)) if [ -f $(ERROR_FILE) ]; then printf "$(MSG_ERRORS)" & exit 1; fi; - $(foreach TEST,$(TESTS),$(RUN_TEST)) + $(foreach TEST,$(TESTS),$(RUN_TEST)) if [ -f $(ERROR_FILE) ]; then printf "$(MSG_ERRORS)" & exit 1; fi; +else +%: + # Check if we have the CMP tool installed + cmp --version >/dev/null 2>&1; if [ $$? -gt 0 ]; then printf "$(MSG_NO_CMP)"; exit 1; fi; + rm -f $(ERROR_FILE) > /dev/null 2>&1 + $(eval $(call PARSE_RULE,$@)) + $(eval $(call SET_SILENT_MODE)) + # Run all the commands in the same shell, notice the + at the first line + # it has to be there to allow parallel execution of the submake + # This always tries to compile everything, even if error occurs in the middle + # But we return the error code at the end, to trigger travis failures + $(foreach COMMAND,$(COMMANDS),$(RUN_COMMAND)) + if [ -f $(ERROR_FILE) ]; then printf "$(MSG_ERRORS)" & exit 1; fi; + $(foreach TEST,$(TESTS),$(RUN_TEST)) + if [ -f $(ERROR_FILE) ]; then printf "$(MSG_ERRORS)" & exit 1; fi; +endif # All should compile everything .PHONY: all @@ -526,7 +543,11 @@ test: test-all test-clean: test-all-clean # Generate the version.h file -GIT_VERSION := $(shell git describe --abbrev=6 --dirty --always --tags 2>/dev/null || date +"%Y-%m-%d-%H:%M:%S") +ifndef SKIP_GIT + GIT_VERSION := $(shell git describe --abbrev=6 --dirty --always --tags 2>/dev/null || date +"%Y-%m-%d-%H:%M:%S") +else + GIT_VERSION := NA +endif BUILD_DATE := $(shell date +"%Y-%m-%d-%H:%M:%S") $(shell echo '#define QMK_VERSION "$(GIT_VERSION)"' > $(ROOT_DIR)/quantum/version.h) $(shell echo '#define QMK_BUILDDATE "$(BUILD_DATE)"' >> $(ROOT_DIR)/quantum/version.h) From c06e2486abda43205a490fc6b233f72f34667857 Mon Sep 17 00:00:00 2001 From: Fred Sundvik Date: Sat, 5 Nov 2016 22:45:21 +0200 Subject: [PATCH 10/15] Increase the infinity60 system tick frequency --- keyboards/infinity60/chconf.h | 2 +- keyboards/infinity60/matrix.c | 7 ++++++- 2 files changed, 7 insertions(+), 2 deletions(-) diff --git a/keyboards/infinity60/chconf.h b/keyboards/infinity60/chconf.h index 43c845739a..d9114ec858 100644 --- a/keyboards/infinity60/chconf.h +++ b/keyboards/infinity60/chconf.h @@ -48,7 +48,7 @@ * @details Frequency of the system timer that drives the system ticks. This * setting also defines the system tick time unit. */ -#define CH_CFG_ST_FREQUENCY 1000 +#define CH_CFG_ST_FREQUENCY 100000 /** * @brief Time delta constant for the tick-less mode. diff --git a/keyboards/infinity60/matrix.c b/keyboards/infinity60/matrix.c index 62c165aa53..d2f1852885 100644 --- a/keyboards/infinity60/matrix.c +++ b/keyboards/infinity60/matrix.c @@ -96,7 +96,12 @@ uint8_t matrix_scan(void) } #endif - wait_us(1); // need wait to settle pin state + // need wait to settle pin state + // if you wait too short, or have a too high update rate + // the keyboard might freeze, or there might not be enough + // processing power to update the LCD screen properly. + // 20us, or two ticks at 100000Hz seems to be OK + wait_us(20); // read col data data = (palReadPort(GPIOD)>>1); From 19ebf6161f174902a33816bdab4ea3a209e4113e Mon Sep 17 00:00:00 2001 From: dbroqua Date: Sat, 12 Nov 2016 19:23:38 +0100 Subject: [PATCH 11/15] - Added dbroqua_hhkb layout for Satan PCB --- keyboards/satan/keymaps/dbroqua_hhkb/keymap.c | 110 ++++++++++++++++++ .../satan/keymaps/dbroqua_hhkb/readme.md | 9 ++ 2 files changed, 119 insertions(+) create mode 100644 keyboards/satan/keymaps/dbroqua_hhkb/keymap.c create mode 100644 keyboards/satan/keymaps/dbroqua_hhkb/readme.md diff --git a/keyboards/satan/keymaps/dbroqua_hhkb/keymap.c b/keyboards/satan/keymaps/dbroqua_hhkb/keymap.c new file mode 100644 index 0000000000..98a298e762 --- /dev/null +++ b/keyboards/satan/keymaps/dbroqua_hhkb/keymap.c @@ -0,0 +1,110 @@ +// This is the canonical layout file for the Quantum project. If you want to add another keyboard, +// this is the style you want to emulate. + +#include "satan.h" + +#define _DEFAULT 0 +#define _ALTDISP 1 +#define _FN 2 + +enum planck_keycodes { + DEFAULT = SAFE_RANGE, + ALTDISP +}; + +// Fillers to make layering more clear +#define ______ KC_TRNS + +const uint16_t PROGMEM keymaps[][MATRIX_ROWS][MATRIX_COLS] = { +/* Qwerty alt/gui/space/gui/alt + * ,-----------------------------------------------------------------------------------------. + * | Esc | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 0 | - | = | \ | ` | + * |-----------------------------------------------------------------------------------------+ + * | Tab | Q | W | E | R | T | Y | U | I | O | P | [ | ] | Bksp | + * |-----------------------------------------------------------------------------------------+ + * | Ctrl | A | S | D | F | G | H | J | K | L | ; | ' | Enter | + * |-----------------------------------------------------------------------------------------+ + * | Shift | Z | X | C | V | B | N | M | , | . | / | RShift | FN | + * |-----------------------------------------------------------------------------------------+ + * | LAlt| LGUI | Space | RGUI | RAlt | + * `-----------------------------------------------------------------' + */ + [_DEFAULT] = KEYMAP_HHKB( /* Basic QWERTY */ + KC_ESC, KC_1, KC_2, KC_3, KC_4, KC_5, KC_6, KC_7, KC_8, KC_9, KC_0, KC_MINS, KC_EQL, KC_BSLS, KC_GRV, \ + KC_TAB, KC_Q, KC_W, KC_E, KC_R, KC_T, KC_Y, KC_U, KC_I, KC_O, KC_P, KC_LBRC, KC_RBRC, KC_BSPC, \ + KC_LCTL, KC_A, KC_S, KC_D, KC_F, KC_G, KC_H, KC_J, KC_K, KC_L, KC_SCLN, KC_QUOT, KC_ENT, \ + KC_LSFT, KC_Z, KC_X, KC_C, KC_V, KC_B, KC_N, KC_M, KC_COMM, KC_DOT, KC_SLSH, KC_RSFT, MO(_FN), \ + ______, KC_LALT, KC_LGUI, KC_SPC, KC_RGUI, KC_RALT, ______, ______ \ + ), + +/* Qwerty gui/alt/space/alt/gui + * ,-----------------------------------------------------------------------------------------. + * | Esc | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 0 | - | = | \ | ` | + * |-----------------------------------------------------------------------------------------+ + * | Tab | Q | W | E | R | T | Y | U | I | O | P | [ | ] | Bksp | + * |-----------------------------------------------------------------------------------------+ + * | Ctrl | A | S | D | F | G | H | J | K | L | ; | ' | Enter | + * |-----------------------------------------------------------------------------------------+ + * | Shift | Z | X | C | V | B | N | M | , | . | / | RShift | FN | + * |-----------------------------------------------------------------------------------------+ + * |LGUI | LAlt | Space | RAlt |RGUI | + * `-----------------------------------------------------------------' + */ + [_ALTDISP] = KEYMAP_HHKB( /* Basic QWERTY */ + KC_ESC, KC_1, KC_2, KC_3, KC_4, KC_5, KC_6, KC_7, KC_8, KC_9, KC_0, KC_MINS, KC_EQL, KC_BSLS, KC_GRV, \ + KC_TAB, KC_Q, KC_W, KC_E, KC_R, KC_T, KC_Y, KC_U, KC_I, KC_O, KC_P, KC_LBRC, KC_RBRC, KC_BSPC, \ + KC_LCTL, KC_A, KC_S, KC_D, KC_F, KC_G, KC_H, KC_J, KC_K, KC_L, KC_SCLN, KC_QUOT, KC_ENT, \ + KC_LSFT, KC_Z, KC_X, KC_C, KC_V, KC_B, KC_N, KC_M, KC_COMM, KC_DOT, KC_SLSH, KC_RSFT, MO(_FN), \ + ______, KC_LGUI, KC_LALT, KC_SPC, KC_RALT, KC_RGUI, ______, ______ \ + ), + +/* FN Layer + * ,-----------------------------------------------------------------------------------------. + * | | F1 | F2 | F3 | F4 | F5 | F6 | F7 | F8 | F9 | F10 | F11 | F12 | Ins | Del | + * |-----------------------------------------------------------------------------------------+ + * | CAPS | BL- | BL+ | BL | | | | | Psc | Slck| Paus| Up | | | + * |-----------------------------------------------------------------------------------------+ + * | | Vol-| Vol+| Mute| | | * | / | Home| PgUp| Left|Right| | + * |-----------------------------------------------------------------------------------------+ + * | | Prev| Play| Next| | | + | - | End |PgDn| Down| | | + * |-----------------------------------------------------------------------------------------+ + * | | | | Stop | | + * `-----------------------------------------------------------------' + */ + [_FN] = KEYMAP_HHKB( /* Layer 1 */ + ______, KC_F1, KC_F2, KC_F3, KC_F4, KC_F5, KC_F6, KC_F7, KC_F8, KC_F9, KC_F10, KC_F11, KC_F12, KC_INS, KC_DEL, \ + KC_CAPS, BL_DEC, BL_INC, BL_TOGG, ______, ______, ______, ______, KC_PSCR, KC_SLCK, KC_PAUS, KC_UP, ______, ______, \ + ______, KC_VOLD, KC_VOLU, KC_MUTE, ______, ______, KC_PAST, KC_PSLS,KC_HOME, KC_PGUP, KC_LEFT, KC_RGHT, ______, \ + ______, KC_MPRV, KC_MPLY, KC_MNXT,______,______,KC_PPLS,KC_PMNS,KC_END, KC_PGDN, KC_DOWN, ______,______, \ + ______, DEFAULT, ALTDISP, ______, KC_MSTP, ______, ______, ______ \ + ) +}; + +const macro_t *action_get_macro(keyrecord_t *record, uint8_t id, uint8_t opt) +{ + // MACRODOWN only works in this function + return MACRO_NONE; +}; + +void persistant_default_layer_set(uint16_t default_layer) { + eeconfig_update_default_layer(default_layer); + default_layer_set(default_layer); +} + +bool process_record_user(uint16_t keycode, keyrecord_t *record) { + switch (keycode) { + case DEFAULT: + if (record->event.pressed) { + persistant_default_layer_set(1UL<<_DEFAULT); + } + return false; + break; + case ALTDISP: + if (record->event.pressed) { + persistant_default_layer_set(1UL<<_ALTDISP); + } + return false; + break; + } + return true; +} \ No newline at end of file diff --git a/keyboards/satan/keymaps/dbroqua_hhkb/readme.md b/keyboards/satan/keymaps/dbroqua_hhkb/readme.md new file mode 100644 index 0000000000..39e71beedd --- /dev/null +++ b/keyboards/satan/keymaps/dbroqua_hhkb/readme.md @@ -0,0 +1,9 @@ +# Dbroqua HHKB like Layout + +Like the HHKB but with a Satan GH60 PCB :D. + +# Programming Instructions: +Enter into programming mode and run the following command. +``` +$ sudo KEYMAP=dbroqua_hhkb make dfu +``` \ No newline at end of file From 28249498bc621cd8e766a501de0e0c18e525d3f1 Mon Sep 17 00:00:00 2001 From: Seth Chandler Date: Sat, 12 Nov 2016 23:56:57 -0500 Subject: [PATCH 12/15] update sethbc keymap --- keyboards/satan/keymaps/sethbc/keymap.c | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/keyboards/satan/keymaps/sethbc/keymap.c b/keyboards/satan/keymaps/sethbc/keymap.c index 82c779081a..b59efd1d94 100644 --- a/keyboards/satan/keymaps/sethbc/keymap.c +++ b/keyboards/satan/keymaps/sethbc/keymap.c @@ -32,7 +32,7 @@ const uint16_t PROGMEM keymaps[][MATRIX_ROWS][MATRIX_COLS] = { KC_TAB, KC_Q, KC_W, KC_E, KC_R, KC_T, KC_Y, KC_U, KC_I, KC_O, KC_P, KC_LBRC, KC_RBRC, KC_BSPC, \ KC_LCTL, KC_A, KC_S, KC_D, KC_F, KC_G, KC_H, KC_J, KC_K, KC_L, KC_SCLN, KC_QUOT, KC_ENT, \ KC_LSFT, KC_Z, KC_X, KC_C, KC_V, KC_B, KC_N, KC_M, KC_COMM, KC_DOT, KC_SLSH, KC_RSFT, MO(_FL), \ - KC_LCTL, KC_LGUI, KC_LALT, KC_SPC, KC_RALT, KC_RGUI, KC_MENU, KC_RCTL), + KC_LCTL, KC_LALT, KC_LGUI, KC_SPC, KC_RGUI, KC_RALT, KC_MENU, KC_RCTL), [_FL] = KEYMAP_HHKB( #ifdef RGBLIGHT_ENABLE From 34bf8558cdfa3baa46db704299ef66b79b2d0a15 Mon Sep 17 00:00:00 2001 From: Seth Chandler Date: Sun, 13 Nov 2016 00:56:46 -0500 Subject: [PATCH 13/15] update sethbc ergodox keymap --- keyboards/ergodox/keymaps/sethbc/Makefile | 11 ----------- keyboards/ergodox/keymaps/sethbc/keymap.c | 2 +- keyboards/ergodox/keymaps/sethbc/readme.md | 3 ++- 3 files changed, 3 insertions(+), 13 deletions(-) diff --git a/keyboards/ergodox/keymaps/sethbc/Makefile b/keyboards/ergodox/keymaps/sethbc/Makefile index 8c4ff87845..457a3d01d4 100644 --- a/keyboards/ergodox/keymaps/sethbc/Makefile +++ b/keyboards/ergodox/keymaps/sethbc/Makefile @@ -1,14 +1,3 @@ -BOOTMAGIC_ENABLE = no # Virtual DIP switch configuration(+1000) -MOUSEKEY_ENABLE = yes # Mouse keys(+4700) -EXTRAKEY_ENABLE = yes # Audio control and System control(+450) -CONSOLE_ENABLE = no # Console for debug(+400) -COMMAND_ENABLE = no # Commands for debug and configuration -CUSTOM_MATRIX = yes # Custom matrix file for the ErgoDox EZ -SLEEP_LED_ENABLE = yes # Breathing sleep LED during USB suspend -NKRO_ENABLE = yes # USB Nkey Rollover - if this doesn't work, see here: https://github.com/tmk/tmk_keyboard/wiki/FAQ#nkro-doesnt-work -MIDI_ENABLE = no # MIDI controls -UNICODE_ENABLE = yes # Unicode - ifndef QUANTUM_DIR include ../../../../Makefile endif diff --git a/keyboards/ergodox/keymaps/sethbc/keymap.c b/keyboards/ergodox/keymaps/sethbc/keymap.c index 6846c4d529..8816ad63bb 100644 --- a/keyboards/ergodox/keymaps/sethbc/keymap.c +++ b/keyboards/ergodox/keymaps/sethbc/keymap.c @@ -15,7 +15,7 @@ const uint16_t PROGMEM keymaps[][MATRIX_ROWS][MATRIX_COLS] = { KC_LGUI, KC_GRV, KC_BSLS, KC_LEFT, KC_RGHT, KC_LCTL, KC_LALT, KC_HOME, - KC_SPC, KC_BSPC, KC_END, + KC_BSPC, KC_DEL, KC_END, // right hand MO(FN2), KC_6, KC_7, KC_8, KC_9, KC_0, KC_MINS, KC_LBRC, KC_Y, KC_U, KC_I, KC_O, KC_P, KC_RBRC, diff --git a/keyboards/ergodox/keymaps/sethbc/readme.md b/keyboards/ergodox/keymaps/sethbc/readme.md index 510b2f99c8..57b5d0ec7c 100644 --- a/keyboards/ergodox/keymaps/sethbc/readme.md +++ b/keyboards/ergodox/keymaps/sethbc/readme.md @@ -1,3 +1,4 @@ # sethbc's Ergodox EZ keymap -Largely based on the Ergodox Infinity default keymap +Largely based on the Ergodox Infinity default keymap, but layer locking has been +removed in favor of momentary layer activation From aa76425395028d304e223d43e76145343850f0db Mon Sep 17 00:00:00 2001 From: Seth Chandler Date: Sun, 13 Nov 2016 01:04:10 -0500 Subject: [PATCH 14/15] oops, fixed inverted if statement --- keyboards/satan/keymaps/sethbc/keymap.c | 12 ++++++------ 1 file changed, 6 insertions(+), 6 deletions(-) diff --git a/keyboards/satan/keymaps/sethbc/keymap.c b/keyboards/satan/keymaps/sethbc/keymap.c index b59efd1d94..93610258b3 100644 --- a/keyboards/satan/keymaps/sethbc/keymap.c +++ b/keyboards/satan/keymaps/sethbc/keymap.c @@ -37,16 +37,16 @@ const uint16_t PROGMEM keymaps[][MATRIX_ROWS][MATRIX_COLS] = { [_FL] = KEYMAP_HHKB( #ifdef RGBLIGHT_ENABLE KC_GRV, KC_F1, KC_F2, KC_F3, KC_F4, KC_F5, KC_F6, KC_F7, KC_F8, KC_F9, KC_F10, KC_F11, KC_F12, _______, RESET, \ - KC_CAPS, _______, _______, _______, _______, _______, _______, _______, KC_PSCR, KC_SLCK, KC_PAUS, KC_UP, _______, KC_DEL, \ - _______, KC_VOLD, KC_VOLU, KC_MUTE, _______, _______, KC_PAST, KC_PSLS, KC_HOME, KC_PGUP, KC_LEFT, KC_RGHT, KC_PENT, \ - _______, _______, _______, _______, _______, _______, KC_PPLS, KC_PMNS, KC_END, KC_PGDN, KC_DOWN, _______, _______, \ - _______, _______, _______, _______, _______, _______, _______, _______), - #else - KC_GRV, KC_F1, KC_F2, KC_F3, KC_F4, KC_F5, KC_F6, KC_F7, KC_F8, KC_F9, KC_F10, KC_F11, KC_F12, _______, RESET, \ KC_CAPS, _______, RGB_TOG,RGB_MOD,RGB_HUI, _______, _______, _______, KC_PSCR, KC_SLCK, KC_PAUS, KC_UP, _______, KC_DEL, \ _______, KC_VOLD, RGB_HUD,RGB_SAI,RGB_SAD, _______, KC_PAST, KC_PSLS, KC_HOME, KC_PGUP, KC_LEFT, KC_RGHT, KC_PENT, \ _______, RGB_VAI,RGB_VAD,_______, _______, _______, KC_PPLS, KC_PMNS, KC_END, KC_PGDN, KC_DOWN, _______, _______, \ _______, _______, _______, _______, _______, _______, _______, _______), + #else + KC_GRV, KC_F1, KC_F2, KC_F3, KC_F4, KC_F5, KC_F6, KC_F7, KC_F8, KC_F9, KC_F10, KC_F11, KC_F12, _______, RESET, \ + KC_CAPS, _______, _______, _______, _______, _______, _______, _______, KC_PSCR, KC_SLCK, KC_PAUS, KC_UP, _______, KC_DEL, \ + _______, KC_VOLD, KC_VOLU, KC_MUTE, _______, _______, KC_PAST, KC_PSLS, KC_HOME, KC_PGUP, KC_LEFT, KC_RGHT, KC_PENT, \ + _______, _______, _______, _______, _______, _______, KC_PPLS, KC_PMNS, KC_END, KC_PGDN, KC_DOWN, _______, _______, \ + _______, _______, _______, _______, _______, _______, _______, _______), #endif }; From 162f603b1c36c63aa170170998b361a86413767f Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Hans=20Elleg=C3=A5rd?= Date: Sat, 29 Oct 2016 20:31:12 +0200 Subject: [PATCH 15/15] Added keymap "videck", an ErgoDox keymap for Vi(m) users. --- keyboards/ergodox/keymaps/videck/Makefile | 19 + keyboards/ergodox/keymaps/videck/config.h | 13 + keyboards/ergodox/keymaps/videck/keymap.c | 179 ++++++++ keyboards/ergodox/keymaps/videck/readme.md | 24 + keyboards/ergodox/keymaps/videck/videck.json | 443 +++++++++++++++++++ keyboards/ergodox/keymaps/videck/videck.png | Bin 0 -> 106851 bytes 6 files changed, 678 insertions(+) create mode 100644 keyboards/ergodox/keymaps/videck/Makefile create mode 100644 keyboards/ergodox/keymaps/videck/config.h create mode 100644 keyboards/ergodox/keymaps/videck/keymap.c create mode 100644 keyboards/ergodox/keymaps/videck/readme.md create mode 100644 keyboards/ergodox/keymaps/videck/videck.json create mode 100644 keyboards/ergodox/keymaps/videck/videck.png diff --git a/keyboards/ergodox/keymaps/videck/Makefile b/keyboards/ergodox/keymaps/videck/Makefile new file mode 100644 index 0000000000..5c7d21f2cc --- /dev/null +++ b/keyboards/ergodox/keymaps/videck/Makefile @@ -0,0 +1,19 @@ +AUDIO_ENABLE:=no +BACKLIGHT_ENABLE:=no +BLUETOOTH_ENABLE:=no +BOOTMAGIC_ENABLE:=no +COMMAND_ENABLE:=no +CONSOLE_ENABLE:=no +EXTRAKEY_ENABLE:=yes +MIDI_ENABLE:=no +MOUSEKEY_ENABLE:=yes +NKRO_ENABLE:=no +RGBLIGHT_ENABLE:=no +SLEEP_LED_ENABLE:=no +TAP_DANCE_ENABLE:=yes +UNICODEMAP_ENABLE:=no +UNICODE_ENABLE:=no + +ifndef QUANTUM_DIR + include ../../../../Makefile +endif diff --git a/keyboards/ergodox/keymaps/videck/config.h b/keyboards/ergodox/keymaps/videck/config.h new file mode 100644 index 0000000000..d89aabe779 --- /dev/null +++ b/keyboards/ergodox/keymaps/videck/config.h @@ -0,0 +1,13 @@ +#ifndef CONFIG_USER_H +#define CONFIG_USER_H + +#include "../../config.h" + +#ifndef NO_DEBUG + #define NO_DEBUG +#endif +#ifndef NO_PRINT + #define NO_PRINT +#endif + +#endif diff --git a/keyboards/ergodox/keymaps/videck/keymap.c b/keyboards/ergodox/keymaps/videck/keymap.c new file mode 100644 index 0000000000..7bd6274e94 --- /dev/null +++ b/keyboards/ergodox/keymaps/videck/keymap.c @@ -0,0 +1,179 @@ +#include + +#include "ergodox.h" +#include "action_layer.h" + +enum { + BASE = 0, // Default layer + ARROWS = 1, // Arrows and Fx keys layer + MOUSE = 2, // Mouse movement and buttons layer + PARENS = 3, // Parenthesis easy access layer + + TD_L = 0, // Tap dance index for left shift + TD_R = 1 // Tap dance index for right shift +}; + +// See the videck.png image for a visualization of the layout. +const uint16_t PROGMEM keymaps[][MATRIX_ROWS][MATRIX_COLS] = { + [BASE] = KEYMAP( + // left hand + KC_GRV, KC_1, KC_2, KC_3, KC_4, KC_5, KC_HOME, + KC_EQL, KC_Q, KC_W, KC_E, KC_R, KC_T, KC_END, + MO(PARENS), KC_A, KC_S, KC_D, KC_F, KC_G, + TD(TD_L), KC_Z, KC_X, KC_C, KC_V, KC_B, KC_BSPC, + KC_LCTL, KC_LALT, KC_VOLD, KC_VOLU, KC_MUTE, + KC_ESC, KC_LGUI, + TG(MOUSE), + KC_SPC, KC_TAB, TG(ARROWS), + // right hand + KC_PGUP, KC_6, KC_7, KC_8, KC_9, KC_0, KC_MINS, + KC_PGDN, KC_Y, KC_U, KC_I, KC_O, KC_P, KC_BSLS, + KC_H, KC_J, KC_K, KC_L, KC_SCLN, KC_QUOT, + KC_DELT, KC_N, KC_M, KC_COMM, KC_DOT, KC_SLSH, TD(TD_R), + KC_LBRC, KC_RBRC, KC_EQL, KC_RALT, KC_RCTL, + KC_APP, KC_ESC, + KC_INS, + KC_SLCK, KC_ENT, KC_SPC + ), + [ARROWS] = KEYMAP( + // left hand + KC_TRNS, KC_F1, KC_F2, KC_F3, KC_F4, KC_F5, KC_TRNS, + KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, + KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, + KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, + KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, + KC_TRNS, KC_TRNS, + KC_NO, + KC_TRNS, KC_TRNS, KC_TRNS, + // right hand + KC_TRNS, KC_F6, KC_F7, KC_F8, KC_F9, KC_F10, KC_F11, + KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_F12, + KC_LEFT, KC_DOWN, KC_UP, KC_RGHT, KC_TRNS, KC_TRNS, + KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, + KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, + KC_TRNS, KC_TRNS, + KC_TRNS, + KC_TRNS, KC_TRNS, KC_TRNS + ), + [MOUSE] = KEYMAP( + // left hand + KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, + KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, + KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, + KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, + KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, + KC_BTN3, KC_TRNS, + KC_TRNS, + KC_BTN1, KC_BTN2, KC_NO, + // right hand + KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, + KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, + KC_MS_L, KC_MS_D, KC_MS_U, KC_MS_R, KC_TRNS, KC_TRNS, + KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, + KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, + KC_TRNS, KC_TRNS, + KC_TRNS, + KC_TRNS, KC_TRNS, KC_TRNS + ), + [PARENS] = KEYMAP( + // left hand + KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, + KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, + KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, + KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, + KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, + KC_TRNS, KC_TRNS, + KC_NO, + KC_TRNS, KC_TRNS, KC_NO, + // right hand + KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, + KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_LCBR, KC_RCBR, KC_TRNS, + KC_TRNS, KC_TRNS, KC_TRNS, KC_LPRN, KC_RPRN, KC_TRNS, + KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_LBRC, KC_RBRC, KC_TRNS, + KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, + KC_TRNS, KC_TRNS, + KC_TRNS, + KC_TRNS, KC_TRNS, KC_TRNS + ) +}; + +typedef void (*videck_tap_dance_trigger_t) (const uint16_t kc); + +typedef struct +{ + uint16_t kc1; + uint16_t kc2; + videck_tap_dance_trigger_t trigger; +} videck_tap_dance_tuple_t; + +static void videck_tap_dance_finished (qk_tap_dance_state_t *state, void *user_data) { + videck_tap_dance_tuple_t *const tuple = (videck_tap_dance_tuple_t *)user_data; + + if (state->count == 1) { + register_code16 (tuple->kc1); + } else if (state->count == 2) { + register_code16 (tuple->kc2); + } +} + +static void videck_tap_dance_reset (qk_tap_dance_state_t *state, void *user_data) { + videck_tap_dance_tuple_t *const tuple = (videck_tap_dance_tuple_t *)user_data; + + if (state->count == 1) { + unregister_code16 (tuple->kc1); + } else if (state->count == 2) { + unregister_code16 (tuple->kc2); + tuple->trigger(tuple->kc2); + } +} + +static bool caps_lock_is_on; + +// Toggles caps lock status. +static void videck_caps_trigger (const uint16_t kc) { + caps_lock_is_on ^= true; +} + +#define ACTION_TAP_DANCE_DOUBLE_TRIGGER(kc1, kc2, double_trigger) { \ + .fn = { NULL, videck_tap_dance_finished, videck_tap_dance_reset }, \ + .user_data = (void *)&((videck_tap_dance_tuple_t) { kc1, kc2, double_trigger }), \ + } + +qk_tap_dance_action_t tap_dance_actions[] = { + [TD_L] = ACTION_TAP_DANCE_DOUBLE_TRIGGER(KC_LSFT, KC_CAPS, videck_caps_trigger), + [TD_R] = ACTION_TAP_DANCE_DOUBLE_TRIGGER(KC_RSFT, KC_CAPS, videck_caps_trigger) +}; + +// Runs just one time when the keyboard initializes. +void matrix_init_user(void) { + ergodox_led_all_set(LED_BRIGHTNESS_LO); + caps_lock_is_on = false; +}; + +static void indicate_using_led(const uint8_t led, const bool enabled) { + if (enabled) { + ergodox_right_led_on(led); + } else { + ergodox_right_led_off(led); + } +} + +static inline void indicate_caps_lock_state(const bool enabled) { + indicate_using_led(1, enabled); +} + +static inline void indicate_arrows_layer_state(const bool enabled) { + indicate_using_led(2, enabled); +} + +static inline void indicate_mouse_layer_state(const bool enabled) { + indicate_using_led(3, enabled); +} + +// Runs constantly in the background, in a loop. +void matrix_scan_user(void) { + // Check if we have shift locked. + indicate_caps_lock_state(caps_lock_is_on); + indicate_arrows_layer_state(IS_LAYER_ON(ARROWS)); + indicate_mouse_layer_state(IS_LAYER_ON(MOUSE)); +}; diff --git a/keyboards/ergodox/keymaps/videck/readme.md b/keyboards/ergodox/keymaps/videck/readme.md new file mode 100644 index 0000000000..759e81bac5 --- /dev/null +++ b/keyboards/ergodox/keymaps/videck/readme.md @@ -0,0 +1,24 @@ +ViDeck keymap for ErgoDox +========================= + +This is a QWERTY layout based on the US layout, where Vi functionality has been +especially considered. + +# Features +* Mouse movements using the Vi movement keys. +* Vi movement keys doubling as arrow keys. +* Shift lock using double tap. +* A coder's modifier key for easy input of parenthesis. +* Acess to the escape key using either thumb. +* Reasonably accessible Scroll Lock key (useful if you, like me, want to switch + to a non-US layout once in a while in X). + +# Missing keys +* Caps Lock (shift lock is used instead). +* Pause/Break. +* Print Screen. + +# LEDs +* Shift lock is indicated using first LED. +* Arrow keys layer is indicated using second LED. +* Mouse keys layer is indicated using third LED. diff --git a/keyboards/ergodox/keymaps/videck/videck.json b/keyboards/ergodox/keymaps/videck/videck.json new file mode 100644 index 0000000000..7068cf5485 --- /dev/null +++ b/keyboards/ergodox/keymaps/videck/videck.json @@ -0,0 +1,443 @@ +[ + { + "backcolor": "#333333", + "background": { + "name": "PBT Black", + "style": "background-image: url('/bg/plastic/pbt-black.png');" + }, + "switchMount": "cherry", + "switchBrand": "gateron", + "switchType": "KS-3-Red" + }, + [ + { + "x": 3.5, + "c": "#323232", + "t": "#ffffff\n\n\n#ac97d8" + }, + "#\n3\n\nF3", + { + "x": 10.5 + }, + "*\n8\n\nF8" + ], + [ + { + "y": -0.875, + "x": 2.5 + }, + "@\n2\n\nF2", + { + "x": 1 + }, + "$\n4\n\nF4", + { + "x": 8.5 + }, + "&\n7\n\nF7", + { + "x": 1, + "t": "#ffffff\n\n\n#ac97d8\n\n\n\n#555454" + }, + "(\n9\n\nF9" + ], + [ + { + "y": -0.875, + "x": 5.5, + "t": "#ffffff\n\n\n#ac97d8" + }, + "%\n5\n\nF5", + { + "t": "#ffffff" + }, + "home", + { + "x": 4.5 + }, + "pgup", + { + "t": "#ffffff\n\n\n#ac97d8" + }, + "^\n6\n\nF6" + ], + [ + { + "y": -0.875, + "t": "#ffffff", + "w": 1.5 + }, + "~\n`", + { + "t": "#ffffff\n\n\n#ac97d8" + }, + "!\n1\n\nF1", + { + "x": 14.5 + }, + ")\n0\n\nF10", + { + "w": 1.5 + }, + "_\n-\n\nF11" + ], + [ + { + "y": -0.375, + "x": 3.5, + "t": "#ffffff" + }, + "E", + { + "x": 10.5 + }, + "I" + ], + [ + { + "y": -0.875, + "x": 2.5 + }, + "W", + { + "x": 1 + }, + "R", + { + "x": 8.5 + }, + "U", + { + "x": 1, + "t": "#ffffff\n\n\n\n\n\n\n\n\n#f8d615" + }, + "O\n\n\n\n\n\n\n\n\n{" + ], + [ + { + "y": -0.875, + "x": 5.5, + "t": "#ffffff" + }, + "T", + { + "h": 1.5 + }, + "end", + { + "x": 4.5, + "h": 1.5 + }, + "pgdn", + "Y" + ], + [ + { + "y": -0.875, + "w": 1.5 + }, + "+\n=", + "Q", + { + "x": 14.5, + "t": "#ffffff\n\n\n\n\n\n\n\n\n#f8d615" + }, + "P\n\n\n\n\n\n\n\n\n}", + { + "t": "#ffffff\n\n\n#ac97d8", + "w": 1.5 + }, + "|\n\\\n\nF12" + ], + [ + { + "y": -0.375, + "x": 3.5, + "t": "#ffffff" + }, + "D", + { + "x": 10.5, + "t": "#ffffff\n\n#5eb1e7\n#ac97d8" + }, + "K\n\n\n" + ], + [ + { + "y": -0.875, + "x": 2.5, + "t": "#ffffff" + }, + "S", + { + "x": 1, + "n": true + }, + "F", + { + "x": 8.5, + "t": "#ffffff\n\n#5eb1e7\n#ac97d8", + "n": true + }, + "J\n\n\n", + { + "x": 1, + "t": "#ffffff\n\n#5eb1e7\n#ac97d8\n\n\n\n\n\n#f8d615" + }, + "L\n\n\n\n\n\n\n\n\n(" + ], + [ + { + "y": -0.875, + "x": 5.5, + "t": "#ffffff" + }, + "G", + { + "x": 6.5, + "t": "#ffffff\n\n#5eb1e7\n#ac97d8" + }, + "H\n\n\n" + ], + [ + { + "y": -0.875, + "t": "#f8d615", + "a": 6, + "w": 1.5 + }, + "( ) [ ] { }", + { + "t": "#ffffff", + "a": 4 + }, + "A", + { + "x": 14.5, + "t": "#ffffff\n\n\n\n\n\n\n#60605b\n\n#f8d615" + }, + ":\n;\n\n\n\n\n\nÖ\n\n)", + { + "t": "#ffffff\n\n\n\n\n\n\n#60605b", + "w": 1.5 + }, + "\"\n'\n\n\n\n\n\nÄ" + ], + [ + { + "y": -0.625, + "x": 6.5, + "t": "#ffffff", + "h": 1.5 + }, + "", + { + "x": 4.5, + "h": 1.5 + }, + "" + ], + [ + { + "y": -0.75, + "x": 3.5 + }, + "C", + { + "x": 10.5 + }, + "<\n," + ], + [ + { + "y": -0.875, + "x": 2.5 + }, + "X", + { + "x": 1 + }, + "V", + { + "x": 8.5 + }, + "M", + { + "x": 1, + "t": "#ffffff\n\n\n\n\n\n\n\n\n#f8d615" + }, + ">\n.\n\n\n\n\n\n\n\n[" + ], + [ + { + "y": -0.875, + "x": 5.5, + "t": "#ffffff" + }, + "B", + { + "x": 6.5 + }, + "N" + ], + [ + { + "y": -0.875, + "t": "#ffffff\n\n#f67f00", + "a": 6, + "fa": [ + 5 + ], + "w": 1.5 + }, + "⇑\n\n2-tap
locks", + { + "t": "#ffffff", + "a": 4, + "f": 3 + }, + "Z", + { + "x": 14.5, + "t": "#ffffff\n\n\n\n\n\n\n\n\n#f8d615", + "f": 3 + }, + "?\n/\n\n\n\n\n\n\n\n]", + { + "t": "#ffffff\n\n#f67f00", + "a": 6, + "f": 3, + "w": 1.5 + }, + "⇑\n\n2-tap
locks" + ], + [ + { + "y": -0.375, + "x": 3.5, + "t": "#ffffff", + "a": 4 + }, + "\n", + { + "x": 10.5, + "f": 3 + }, + "}\n]" + ], + [ + { + "y": -0.875, + "x": 2.5 + }, + "\n", + { + "x": 1 + }, + "\n", + { + "x": 8.5, + "t": "#ffffff\n\n\n\n\n\n\n#60605b", + "f": 3 + }, + "{\n[\n\n\n\n\n\nÅ", + { + "x": 1, + "t": "#ffffff", + "f": 3 + }, + "+\n=" + ], + [ + { + "y": -0.75, + "x": 0.5, + "f": 3 + }, + "ctrl", + { + "f": 3 + }, + "alt", + { + "x": 14.5, + "f": 3 + }, + "altgr", + { + "f": 3 + }, + "ctrl" + ], + [ + { + "r": 30, + "rx": 6.5, + "ry": 4.25, + "y": -1, + "x": 1, + "t": "#ffffff\n\n\n\n\n\n\n\n\n\n#5eb1e7", + "f": 3 + }, + "esc\n\n\n\n\n\n\n\n\n\nM", + { + "t": "#ffffff", + "f": 7 + }, + "" + ], + [ + { + "t": "#ffffff\n\n\n\n\n\n\n\n\n\n#5eb1e7", + "f": 3, + "h": 2 + }, + "space\n\n\n\n\n\n\n\n\n\nL", + { + "h": 2 + }, + "\n\n\n\n\n\n\n\n\n\nR", + { + "t": "#5eb1e7" + }, + "" + ], + [ + { + "x": 2, + "t": "#ac97d8" + }, + "" + ], + [ + { + "r": -30, + "rx": 13, + "y": -1, + "x": -3, + "t": "#ffffff" + }, + "", + "esc" + ], + [ + { + "x": -3 + }, + "ins", + { + "h": 2 + }, + "", + { + "h": 2 + }, + "space" + ], + [ + { + "x": -3 + }, + "scroll
lock" + ] +] \ No newline at end of file diff --git a/keyboards/ergodox/keymaps/videck/videck.png b/keyboards/ergodox/keymaps/videck/videck.png new file mode 100644 index 0000000000000000000000000000000000000000..c99323f53b1849872b261310a197addba435fe41 GIT binary patch literal 106851 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 f