#include QMK_KEYBOARD_H enum custom_keycodes { CTL_SPC = SAFE_RANGE, LS, NVIM, VI, RM, GREP, DOAS, TMUX, TMUX_C, TMUX_N, TMUX_S, TMUX_X, TMUX_H, TMUX_J, TMUX_K, TMUX_L, TMUX_LB, TMUX_RB, TMUX_SERVER, SHIFT_COPY, SHIFT_PASTE }; bool get_custom_auto_shifted_key(uint16_t keycode, keyrecord_t *record) { if (IS_RETRO(keycode)) return true; return false; } bool process_record_user(uint16_t keycode, keyrecord_t *record) { static uint16_t pressed_timer; switch (keycode) { case CTL_SPC: if (record->event.pressed) { pressed_timer = timer_read(); register_code(KC_LGUI); } else { unregister_code(KC_LGUI); if (timer_elapsed(pressed_timer) < TAPPING_TERM) { register_code(KC_LCTL); SEND_STRING(" "); unregister_code(KC_LCTL); } } return false; case LS: if (record->event.pressed) { SEND_STRING("ls -la\n"); } return false; case RM: if (record->event.pressed) { SEND_STRING("rm -rfi "); } return false; case VI: if (record->event.pressed) { SEND_STRING("vi "); } return false; case DOAS: if (record->event.pressed) { SEND_STRING("doas "); } return false; case GREP: if (record->event.pressed) { SEND_STRING("grep -r "); } return false; case TMUX: if (record->event.pressed) { SEND_STRING("tmux attach -t \t\t"); } return false; case TMUX_C: if (record->event.pressed) { register_code(KC_LCTL); SEND_STRING(" "); unregister_code(KC_LCTL); SEND_STRING("c\n"); } return false; case TMUX_X: if (record->event.pressed) { register_code(KC_LCTL); SEND_STRING(" "); unregister_code(KC_LCTL); SEND_STRING("xy"); } return false; case TMUX_N: if (record->event.pressed) { register_code(KC_LCTL); SEND_STRING(" "); unregister_code(KC_LCTL); SEND_STRING("n\n"); } return false; case TMUX_S: if (record->event.pressed) { register_code(KC_LCTL); SEND_STRING(" "); unregister_code(KC_LCTL); SEND_STRING("S\n"); } return false; case TMUX_H: if (record->event.pressed) { register_code(KC_LCTL); SEND_STRING(" "); unregister_code(KC_LCTL); SEND_STRING("h"); } return false; case TMUX_J: if (record->event.pressed) { register_code(KC_LCTL); SEND_STRING(" "); unregister_code(KC_LCTL); SEND_STRING("j"); } return false; case TMUX_K: if (record->event.pressed) { register_code(KC_LCTL); SEND_STRING(" "); unregister_code(KC_LCTL); SEND_STRING("k"); } return false; case TMUX_L: if (record->event.pressed) { register_code(KC_LCTL); SEND_STRING(" "); unregister_code(KC_LCTL); SEND_STRING("l"); } return false; case TMUX_RB: if (record->event.pressed) { register_code(KC_LCTL); SEND_STRING(" "); unregister_code(KC_LCTL); SEND_STRING(")"); } return false; case TMUX_LB: if (record->event.pressed) { register_code(KC_LCTL); SEND_STRING(" "); unregister_code(KC_LCTL); SEND_STRING("("); } return false; case TMUX_SERVER: if (record->event.pressed) { register_code(KC_LCTL); SEND_STRING("a"); unregister_code(KC_LCTL); } return false; case SHIFT_COPY: if (record->event.pressed) { register_code(KC_LCTL); register_code(KC_LSFT); SEND_STRING("c"); unregister_code(KC_LSFT); unregister_code(KC_LCTL); } case SHIFT_PASTE: if (record->event.pressed) { register_code(KC_LCTL); register_code(KC_LSFT); SEND_STRING("v"); unregister_code(KC_LSFT); unregister_code(KC_LCTL); } return false; } return true; } uint16_t get_tapping_term(uint16_t keycode, keyrecord_t *record) { switch (keycode) { case MT(MOD_LSFT, KC_A): case LT(4, KC_R): case LT(2, KC_S): case LT(1, KC_T): case LT(3, KC_G): case LT(3, KC_M): case LT(1, KC_N): case LT(2, KC_E): case LT(4, KC_I): case MT(MOD_RSFT, KC_O): case MT(MOD_RCTL, KC_H): case MT(MOD_LCTL, KC_D): return TAPPING_TERM + 65; default: return TAPPING_TERM; } } const uint16_t PROGMEM keymaps[][MATRIX_ROWS][MATRIX_COLS] = { [0] = LAYOUT_split_3x6_3( LALT_T(KC_TAB), MT(MOD_LALT,KC_Q), KC_W, KC_F, KC_P, KC_B, KC_J, KC_L, KC_U, KC_Y, MT(MOD_RALT,KC_SCLN), KC_BSPC, LCTL_T(KC_ESC), MT(MOD_LSFT,KC_A), LT(4,KC_R), LT(2,KC_S), LT(1,KC_T), LT(3,KC_G), LT(3,KC_M), LT(1,KC_N), LT(2,KC_E), LT(4,KC_I), MT(MOD_RSFT,KC_O), RCTL_T(KC_QUOT), SC_LSPO, KC_Z, KC_X, LT(5,KC_C), MT(MOD_LCTL, KC_D), KC_V, KC_K, MT(MOD_RCTL, KC_H), LT(5,KC_COMM), KC_DOT, KC_SLSH, SC_RSPC, DM_REC1, KC_SPC, CTL_SPC, RALT_T(KC_TAB), KC_ENT, DM_PLY1 ), [1] = LAYOUT_split_3x6_3( LALT_T(KC_TAB), KC_EXLM, KC_AT, KC_HASH, KC_DLR, KC_PERC, KC_CIRC, KC_AMPR, KC_ASTR, KC_LPRN, KC_RPRN, KC_DEL, LCTL_T(KC_ESC), KC_NO, KC_AMPR, KC_ASTR, KC_CIRC, CW_TOGG, KC_MINS, KC_EQL, KC_LBRC, KC_RBRC, KC_BSLS, KC_GRV, KC_LSFT, KC_NO, KC_NO, KC_NO, C(KC_L), KC_NO, KC_UNDS, KC_PLUS, KC_LCBR, KC_RCBR, KC_PIPE, KC_TILD, DM_REC1, KC_SPC, CTL_SPC, RALT_T(KC_TAB), LT(3,KC_ENT), DM_PLY1 ), [2] = LAYOUT_split_3x6_3( LALT_T(KC_TAB), KC_F1, KC_F2, KC_F3, KC_F4, KC_F5, KC_CIRC, KC_7, KC_8, KC_9, KC_0, KC_BSPC, LCTL_T(KC_ESC), KC_F6, KC_F7, KC_F8, KC_F9, KC_F10, KC_COMM, KC_4, KC_5, KC_6, KC_MINS, KC_EQL, SC_LSPO, KC_NO, KC_NO, KC_DEL, KC_F11, KC_F12, KC_DOT, KC_1, KC_2, KC_3, KC_SLSH, KC_ASTR, DM_REC1, KC_SPC, CTL_SPC, KC_RSFT, LT(3,KC_ENT), DM_PLY1 ), [3] = LAYOUT_split_3x6_3( KC_MUTE, KC_MPRV, KC_MNXT, KC_VOLD, KC_VOLU, KC_MPLY, KC_MS_D, KC_MS_R, KC_WH_R, KC_NO, KC_NO, KC_ACL0, LCTL_T(KC_ESC), KC_NO, KC_NO, KC_BTN3, KC_BTN1, KC_BTN2, KC_NO, KC_WH_U, KC_WH_D, KC_NO, OSL(4), KC_ACL1, KC_LSFT, KC_NO, KC_NO, KC_NO, KC_NO, KC_NO, KC_MS_U, KC_MS_L, KC_WH_L, KC_NO, KC_NO, KC_ACL2, DM_REC1, KC_SPC, CTL_SPC, KC_NO, KC_NO, DM_PLY1 ), [4] = LAYOUT_split_3x6_3( RGB_TOG, RGB_M_B, RGB_M_P, RGB_VAD, RGB_VAI, KC_NO, KC_DOWN, KC_RGHT, KC_PGUP, KC_HOME, AS_TOGG, KC_BSPC, LCTL_T(KC_ESC), RGB_M_R, RGB_M_SW, RGB_HUD, RGB_HUI, RGB_M_TW, KC_NO, KC_NO, KC_NO, KC_NO, KC_PSCR, RCTL_T(KC_QUOT), KC_LSFT, RGB_M_G, RGB_SAD, RGB_SAI, KC_LCTL, KC_NO, KC_UP, KC_LEFT, KC_PGDN, KC_END, KC_NO, KC_NO, DM_REC1, KC_SPC, CTL_SPC, KC_LGUI, KC_ENT, DM_PLY1 ), [5] = LAYOUT_split_3x6_3( KC_NO, KC_NO, KC_NO, KC_NO, SHIFT_PASTE, KC_NO, TMUX_J, TMUX_L, KC_NO, KC_NO, SHIFT_COPY, KC_NO, KC_NO, TMUX_SERVER, RM, TMUX_S, TMUX, GREP, KC_NO, TMUX_N, KC_NO, KC_NO, KC_NO, KC_NO, TMUX_LB, KC_NO, TMUX_X, TMUX_C, DOAS, VI, TMUX_K, TMUX_H, KC_NO, KC_NO, KC_NO, TMUX_RB, DM_REC1, KC_SPC, CTL_SPC, RALT_T(KC_TAB), LT(3,KC_ENT), DM_PLY1 ), };