keymap.c 3.8 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889
  1. // This is the personal keymap of Ian Sterling (@xyverz). It is based on the keymap by
  2. // Chris Gerber (@gerbercj), with the addition of persistent layers like the Planck and
  3. // Preonic keyboards by Jack Humbert.
  4. #include "atreus.h"
  5. #include "action_layer.h"
  6. #include "eeconfig.h"
  7. extern keymap_config_t keymap_config;
  8. // Each layer gets a name for readability, which is then used in the keymap matrix below.
  9. // The underscores don't mean anything - you can have a layer called STUFF or any other name.
  10. // Layer names don't all need to be of the same length, obviously, and you can also skip them
  11. // entirely and just use numbers.
  12. #define _DV 0
  13. #define _QW 1
  14. #define _CM 2
  15. #define _L1 3
  16. #define _L2 4
  17. // Macro name shortcuts
  18. #define DVORAK M(_DV)
  19. #define QWERTY M(_QW)
  20. #define COLEMAK M(_CM)
  21. const uint16_t PROGMEM keymaps[][MATRIX_ROWS][MATRIX_COLS] = {
  22. [_DV] = { /* Dvorak */
  23. {KC_QUOT, KC_COMM, KC_DOT, KC_P, KC_Y, KC_NO, KC_F, KC_G, KC_C, KC_R, KC_L },
  24. {KC_A, KC_O, KC_E, KC_U, KC_I, KC_NO, KC_D, KC_H, KC_T, KC_N, KC_S },
  25. {SFT_T(KC_SCLN), KC_Q, KC_J, KC_K, KC_X, CTL_T(KC_DEL), KC_B, KC_M, KC_W, KC_V, SFT_T(KC_Z) },
  26. {KC_ESC, KC_TAB, KC_LGUI, MO(_L2), KC_BSPC, ALT_T(KC_ENT), KC_SPC, MO(_L1), KC_MINS, KC_SLSH, KC_EQL}
  27. },
  28. [_QW] = { /* Qwerty */
  29. {KC_Q, KC_W, KC_E, KC_R, KC_T, KC_NO, KC_Y, KC_U, KC_I, KC_O, KC_P },
  30. {KC_A, KC_S, KC_D, KC_F, KC_G, KC_NO, KC_H, KC_J, KC_K, KC_L, KC_SCLN},
  31. {SFT_T(KC_Z), KC_X, KC_C, KC_V, KC_B, CTL_T(KC_DEL), KC_N, KC_M, KC_COMM, KC_DOT, SFT_T(KC_SLSH) },
  32. {KC_ESC, KC_TAB, KC_LGUI, MO(_L2), KC_BSPC, ALT_T(KC_ENT), KC_SPC, MO(_L1), KC_MINS, KC_QUOT, KC_ENT}
  33. },
  34. [_CM] = { /* Colemak */
  35. {KC_Q, KC_W, KC_F, KC_P, KC_G, KC_NO, KC_J, KC_L, KC_U, KC_Y, KC_SCLN},
  36. {KC_A, KC_R, KC_S, KC_T, KC_D, KC_NO, KC_H, KC_N, KC_E, KC_I, KC_O },
  37. {SFT_T(KC_Z), KC_X, KC_C, KC_V, KC_B, CTL_T(KC_DEL), KC_K, KC_M, KC_COMM, KC_DOT, SFT_T(KC_SLSH) },
  38. {KC_ESC, KC_TAB, KC_LGUI, MO(_L2), KC_BSPC, ALT_T(KC_ENT), KC_SPC, MO(_L1), KC_MINS, KC_QUOT, KC_ENT}
  39. },
  40. [_L1] = { /* LAYER 1 */
  41. {KC_1, KC_2, KC_3, KC_4, KC_5, KC_NO, KC_6, KC_7, KC_8, KC_9, KC_0 },
  42. {KC_TAB, KC_INS, KC_UP, KC_DEL, KC_HOME, KC_NO, KC_PGUP, KC_MUTE, KC_VOLD, KC_VOLU, KC_EQL },
  43. {KC_TRNS, KC_LEFT, KC_DOWN, KC_RGHT, KC_END, KC_LCTL, KC_PGDN, KC_MPRV, KC_MPLY, KC_MNXT, KC_BSLS},
  44. {KC_TRNS, KC_GRV, KC_LGUI, KC_TRNS, KC_DEL, KC_LALT, KC_SPC, KC_TRNS, KC_LBRC, KC_RBRC, KC_ENT }
  45. },
  46. [_L2] = { /* LAYER 2 */
  47. {KC_EXLM, KC_AT, KC_HASH, KC_DLR, KC_PERC, KC_NO, KC_CIRC, KC_AMPR, KC_ASTR, KC_LPRN, KC_RPRN},
  48. {KC_F1, KC_F2, KC_F3, KC_F4, KC_F5, KC_NO, KC_TRNS, KC_F6, KC_F7, KC_F8, KC_PLUS},
  49. {KC_TRNS, KC_TRNS, DVORAK, QWERTY, COLEMAK, KC_LCTL, KC_TRNS, KC_F9, KC_F10, KC_F11, KC_F12 },
  50. {KC_TRNS, KC_TRNS, KC_LGUI, KC_TRNS, KC_BSPC, KC_LALT, KC_SPC, KC_TRNS, LSFT(KC_LBRC), LSFT(KC_RBRC), RESET}
  51. }
  52. };
  53. const uint16_t PROGMEM fn_actions[] = {
  54. };
  55. void persistant_default_layer_set(uint16_t default_layer) {
  56. eeconfig_update_default_layer(default_layer);
  57. default_layer_set(default_layer);
  58. }
  59. const macro_t *action_get_macro(keyrecord_t *record, uint8_t id, uint8_t opt)
  60. {
  61. switch(id) {
  62. case _DV:
  63. if (record->event.pressed) {
  64. persistant_default_layer_set(1UL<<_DV);
  65. }
  66. break;
  67. case _QW:
  68. if (record->event.pressed) {
  69. persistant_default_layer_set(1UL<<_QW);
  70. }
  71. break;
  72. case _CM:
  73. if (record->event.pressed) {
  74. persistant_default_layer_set(1UL<<_CM);
  75. }
  76. break;
  77. }
  78. return MACRO_NONE;
  79. };