summaryrefslogtreecommitdiff
path: root/keyboards/planck/keymaps/dvorak2space/keymap.c
diff options
context:
space:
mode:
Diffstat (limited to 'keyboards/planck/keymaps/dvorak2space/keymap.c')
-rw-r--r--keyboards/planck/keymaps/dvorak2space/keymap.c242
1 files changed, 0 insertions, 242 deletions
diff --git a/keyboards/planck/keymaps/dvorak2space/keymap.c b/keyboards/planck/keymaps/dvorak2space/keymap.c
deleted file mode 100644
index 4b07759452..0000000000
--- a/keyboards/planck/keymaps/dvorak2space/keymap.c
+++ /dev/null
@@ -1,242 +0,0 @@
-#include QMK_KEYBOARD_H
-#include "passwords.c" //Instead of extern just to cut down on compile time. Holds a single array.
-#define MOUSEL KC_BTN1
-#define MOUSER KC_BTN2
-#define CTRLL LCTL(KC_LEFT)
-#define CTRLR LCTL(KC_RGHT)
-#define CAD LCTL(LALT(KC_DEL))
-
-#define BASE_L 0
-#define SHFT_L 1
-#define MOD_L 2
-#define NAV_L 3
-#define AHK_L 4
-#define LOCK_L 5
-#define PASS_L 6
-
-static host_driver_t *host_driver = 0;
-
-enum {
- HK_SLP = SAFE_RANGE,
- HK_IF,
- HK_ELSE,
- HK_COSL
-};
-
-enum {
- FB = 0,
- LPN,
- RPN,
- BCK,
- DSH
-};
-
-enum {
- SINGLE_TAP = 1,
- SINGLE_HOLD = 2,
- DOUBLE_TAP = 3,
- DOUBLE_HOLD = 4,
- DOUBLE_SINGLE_TAP = 5, //Distinguishes between double tapping and typing, "tapping", for example. Not sure how accurate it is, and I have no need, so avoiding it at the moment.
- TRIPLE_TAP = 6,
- TRIPLE_HOLD = 7
-};
-
-const uint16_t PROGMEM keymaps[][MATRIX_ROWS][MATRIX_COLS] = {
-/* Base
- * ,-----------------------------------------------------------------------------------.
- * | Tab | ' | , | . | p | y | f | g | c | r | l | Bksp |
- * |------+------+------+------+------+-------------+------+------+------+------+------|
- * | Nav | a | o | e | u | i | d | h | t | n | s | Enter|
- * |------+------+------+------+------+------|------+------+------+------+------+------|
- * | Shft | ; | q | j | k | x | b | m | w | v | z | Shft |
- * |------+------+------+------+------+------+------+------+------+------+------+------|
- * | Esc | RClk | LClk | Ctrl | Space | Modifier | GUI | VolD | VolU |Macros|
- * `-----------------------------------------------------------------------------------'
- */
- [0] = LAYOUT_planck_2x2u(
- KC_TAB, KC_QUOT,KC_COMM, KC_DOT, KC_P, KC_Y, KC_F, KC_G, KC_C, KC_R, KC_L, TD(BCK),
- MO(NAV_L),KC_A, KC_O, KC_E, KC_U, KC_I, KC_D, KC_H, KC_T, KC_N, KC_S, KC_ENT,
- KC_LSFT, KC_SCLN,KC_Q, KC_J, KC_K, KC_X, KC_B, KC_M, KC_W, KC_V, KC_Z, KC_RSFT,
- KC_ESC, MOUSER, MOUSEL, KC_LCTL, KC_SPC, MO(MOD_L), KC_LGUI, KC_VOLD, KC_VOLU, OSL(AHK_L)
- ),
-/* Custom Shifts
- * ,-----------------------------------------------------------------------------------.
- * | | | ? | ! | | | | | | | | |
- * |------+------+------+------+------+-------------+------+------+------+------+------|
- * | | | | | | | | | | | | |
- * |------+------+------+------+------+------|------+------+------+------+------+------|
- * | | | | | | | | | | | | |
- * |------+------+------+------+------+------+------+------+------+------+------+------|
- * | | | | | | | | | | |
- * `-----------------------------------------------------------------------------------'
- */
- [1] = LAYOUT_planck_2x2u(
- KC_TRNS,KC_TRNS,KC_SLSH,KC_1, 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_TRNS,KC_TRNS, KC_TRNS,KC_NO, KC_TRNS,KC_TRNS,KC_TRNS,KC_TRNS
- ),
-/* Modifier
- * ,-----------------------------------------------------------------------------------.
- * | Tab | + | - | * | / \ | if | else | ( [ | ) ] | { | } | Bksp |
- * |------+------+------+------+------+-------------+------+------+------+------+------|
- * | = | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 0 | Enter|
- * |------+------+------+------+------+------|------+------+------+------+------+------|
- * | ` | < | > | & | | | _ | $ | @ | # | % | ^ | ~ |
- * |------+------+------+------+------+------+------+------+------+------+------+------|
- * | | | | | Space | | | | | |
- * `-----------------------------------------------------------------------------------'
- */
- [2] = LAYOUT_planck_2x2u(
- KC_TRNS,KC_PLUS,TD(DSH),KC_ASTR,TD(FB), HK_IF, HK_ELSE,TD(LPN),TD(RPN),KC_LCBR,KC_RCBR,KC_TRNS,
- KC_EQL, KC_1, KC_2, KC_3, KC_4, KC_5, KC_6, KC_7, KC_8, KC_9, KC_0, KC_TRNS,
- KC_GRV, KC_LT, KC_GT, KC_AMPR,KC_PIPE,KC_UNDS,KC_DLR, KC_AT, KC_HASH,KC_PERC,KC_CIRC,LSFT(KC_GRV),
- KC_NO, KC_NO, KC_NO, KC_NO, KC_SPC, KC_TRNS, KC_NO, KC_NO, KC_NO, KC_NO
- ),
-//Nav
- [3] = LAYOUT_planck_2x2u(
- KC_TRNS,KC_NO, KC_NO, KC_NO, KC_NO, KC_NO, KC_NO, KC_HOME,KC_UP, KC_END, KC_NO, KC_TRNS,
- KC_TRNS,KC_NO, KC_NO, KC_NO, KC_NO, KC_NO, CTRLL, KC_LEFT,KC_DOWN,KC_RGHT, CTRLR, KC_TRNS,
- KC_LSFT,KC_NO, KC_NO, KC_NO, KC_NO, KC_NO, KC_NO, KC_NO, KC_NO, KC_NO, KC_NO, KC_NO,
- KC_NO, KC_NO, KC_NO, KC_NO, KC_SPC, KC_NO, KC_NO, KC_NO, KC_NO, KC_NO
- ),
-//AHK-Bindable Macros
- [4] = LAYOUT_planck_2x2u(
- KC_F13, KC_F14, KC_F15, KC_F16, KC_F17, KC_F18, KC_F19, KC_F20, KC_F21, KC_F22, KC_F23, KC_F24,
- LCTL(KC_F13),LCTL(KC_F14),LCTL(KC_F15),LCTL(KC_F16),LCTL(KC_F17),LCTL(KC_F18),LCTL(KC_F19),LCTL(KC_F20),LCTL(KC_F21),LCTL(KC_F22),LCTL(KC_F23),LCTL(KC_F24),
- LSFT(KC_F13),LSFT(KC_F14),LSFT(KC_F15),LSFT(KC_F16),LSFT(KC_F17),LSFT(KC_F18),LSFT(KC_F19),LSFT(KC_F20),LSFT(KC_F21),LSFT(KC_F22),LSFT(KC_F23),LSFT(KC_F24),
- RESET, LALT(KC_F14),LALT(KC_F15),OSL(PASS_L), CAD, LALT(KC_F19), LALT(KC_F21),LALT(KC_F22),HK_SLP, HK_COSL
- ),
-//Locked Screen
- [5] = LAYOUT_planck_2x2u(
- KC_NO, KC_NO, KC_NO, KC_NO, KC_NO, KC_NO, KC_NO, KC_NO, KC_NO, KC_NO, KC_NO, KC_NO,
- KC_NO, KC_NO, KC_NO, KC_NO, KC_NO, KC_NO, KC_NO, KC_NO, KC_NO, KC_NO, KC_NO, KC_NO,
- KC_NO, KC_NO, KC_NO, KC_NO, KC_NO, KC_NO, KC_NO, KC_NO, KC_NO, KC_NO, KC_NO, KC_NO,
- KC_NO, KC_NO, KC_NO, KC_NO, KC_NO, KC_NO, KC_NO, KC_NO, HK_SLP, KC_NO
- ),
-//Passwords (by first letter of service name, at least better than just one)
- [6] = LAYOUT_planck_2x2u(
- KC_NO, KC_NO, KC_NO, KC_NO, KC_P, KC_Y, KC_F, KC_G, KC_C, KC_R, KC_L, KC_NO,
- KC_NO, KC_A, KC_O, KC_E, KC_U, KC_I, KC_D, KC_H, KC_T, KC_N, KC_S, KC_NO,
- KC_NO, KC_NO, KC_Q, KC_J, KC_K, KC_X, KC_B, KC_M, KC_W, KC_V, KC_Z, KC_NO,
- KC_NO, KC_NO, KC_NO, HK_COSL, KC_NO, KC_NO, KC_NO, KC_NO, KC_NO, KC_NO
- )
-};
-
-bool process_record_user(uint16_t keycode, keyrecord_t *record) { //X_KEY doesn't support aliases
- switch(keycode) {
- //if shift pressed and not shift layer or released and other shift not pressed
- //in separate things because MOD_BIT (probably?) isn't toggled until after this returns true and shift is actually toggled
- case KC_LSFT: //if pressed and not shift layer or released and other shift not pressed
- if((record->event.pressed && IS_LAYER_OFF(SHFT_L)) || (!record->event.pressed && !(get_mods() & MOD_BIT(KC_RSFT)))) { layer_invert(SHFT_L); }
- break;
- case KC_RSFT:
- if((record->event.pressed && IS_LAYER_OFF(SHFT_L)) || (!record->event.pressed && !(get_mods() & MOD_BIT(KC_LSFT)))) { layer_invert(SHFT_L); }
- break;
- case KC_ENT: //won't repeat on hold and I can't find a solution other than hardcoding timers but I kinda prefer it anyway. Swaps enter and shift enter
- if(record->event.pressed) {
- (IS_LAYER_ON(SHFT_L)) //if shifted release correct shift, send, and press same shift, else send shift enter
- ? (get_mods() & MOD_BIT(KC_LSFT))
- ? SEND_STRING(SS_UP(X_LSHIFT) SS_TAP(X_ENTER) SS_DOWN(X_LSHIFT))
- : SEND_STRING(SS_UP(X_RSHIFT) SS_TAP(X_ENTER) SS_DOWN(X_RSHIFT))
- : SEND_STRING(SS_LSFT(SS_TAP(X_ENTER)));
- }
- return false;
- case HK_IF:
- if(record->event.pressed) { SEND_STRING("if"); }
- break;
- case HK_ELSE:
- if(record->event.pressed) { SEND_STRING("else"); }
- break;
- case HK_COSL:
- clear_keyboard();
- break;
- case HK_SLP:
- if(record->event.pressed) {
- if(IS_LAYER_OFF(LOCK_L)) {
- host_driver = host_get_driver();
- SEND_STRING(SS_LALT(SS_TAP(X_F23)));
- host_set_driver(0);
- }
- else {
- host_set_driver(host_driver);
- SEND_STRING(SS_LALT(SS_TAP(X_F24)));
- }
- return false;
- }
- layer_invert(LOCK_L);
- if(IS_LAYER_ON(AHK_L))
- layer_invert(AHK_L);
- break;
- default:
- if(IS_LAYER_ON(PASS_L) && keycode <= KC_Z) {
- SEND_STRING(passwords[keycode - KC_A]);
- layer_invert(PASS_L);
- return false;
- }
- }
- return true;
-};
-
-//tapdance state evaluation
-int cur_dance(qk_tap_dance_state_t *state) {
- int press = 0;
- switch(state->count) {
- case 1:
- press = (state->interrupted || !state->pressed)
- ? SINGLE_TAP
- : SINGLE_HOLD;
- break;
- case 2:
- press = DOUBLE_TAP;
- break;
- case 3:
- press = TRIPLE_TAP;
- }
- return press;
-}
-
-void back_tap(qk_tap_dance_state_t *state, void *user_data) { tap_code(KC_BSPACE); }
-
-void back_finished(qk_tap_dance_state_t *state, void *user_data) { if(!(state->interrupted || !state->pressed)) tap_code16(LCTL(KC_BSPACE)); }
-
-void slash_finished(qk_tap_dance_state_t *state, void *user_data) {
- int td_state = cur_dance(state);
- switch(td_state) {
- case SINGLE_TAP:
- clear_mods();
- clear_weak_mods();
- tap_code(KC_SLSH);
- break;
- case DOUBLE_TAP:
- tap_code(KC_NUBS);
- }
-}
-
-void dash_finished(qk_tap_dance_state_t *state, void *user_data) {
- int td_state = cur_dance(state);
- switch(td_state) {
- case SINGLE_TAP:
- tap_code(KC_PMNS);
- break;
- case SINGLE_HOLD:
- register_mods(MOD_BIT(KC_LALT));
- tap_code(KC_KP_0);
- tap_code(KC_KP_1);
- tap_code(KC_KP_5);
- tap_code(KC_KP_1);
- unregister_mods(MOD_BIT(KC_LALT));
- break;
- case DOUBLE_TAP:
- tap_code(KC_PMNS);
- tap_code(KC_PMNS);
- }
-}
-
-qk_tap_dance_action_t tap_dance_actions[] = {
- [LPN] = ACTION_TAP_DANCE_DOUBLE(KC_LPRN, KC_LBRC),
- [RPN] = ACTION_TAP_DANCE_DOUBLE(KC_RPRN, KC_RBRC),
- [FB] = ACTION_TAP_DANCE_FN_ADVANCED(NULL, slash_finished, NULL),
- [BCK] = ACTION_TAP_DANCE_FN_ADVANCED(back_tap, back_finished, NULL), //each tap, on finished, and reset. Normally register_code on press unregister on reset so keys can be held down.
- [DSH] = ACTION_TAP_DANCE_FN_ADVANCED(NULL, dash_finished, NULL)
-};