2
0

keymap.c 6.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181
  1. // This is the personal keymap of Jeremy Cowgar (@jcowgar). It is written for the programmer.
  2. // Configuration options
  3. #define PREVENT_STUCK_MODIFIERS
  4. #pragma message "You may need to add LAYOUT_planck_grid to your keymap layers - see default for an example"
  5. #include "planck.h"
  6. #include "action_layer.h"
  7. #include "eeconfig.h"
  8. // Each layer gets a name for readability, which is then used in the keymap matrix below.
  9. enum my_layers {
  10. ALPH = 0,
  11. NUMS,
  12. CURS,
  13. SYMB,
  14. FKEY
  15. };
  16. // Each macro gets a name for readability.
  17. enum my_keycodes {
  18. MY_ABVE = SAFE_RANGE,
  19. MY_BELW,
  20. MY_TERM,
  21. MY_DEQL, // /=
  22. MY_MEQL, // *=
  23. MY_SEQL, // -=
  24. MY_PEQL, // +=
  25. MY_NEQL, // !=
  26. MY_LTGT, // <>
  27. MY_DPIP, // ||
  28. MY_DAMP, // &&
  29. };
  30. const uint16_t PROGMEM keymaps[][MATRIX_ROWS][MATRIX_COLS] = {
  31. [ALPH] = {
  32. {KC_Q, KC_W, KC_E, KC_R, KC_T, KC_LBRC, KC_RBRC, KC_Y, KC_U, KC_I, KC_O, KC_P},
  33. {KC_A, KC_S, KC_D, KC_F, KC_G, KC_LPRN, KC_RPRN, KC_H, KC_J, KC_K, KC_L, KC_SCLN},
  34. {SFT_T(KC_Z), KC_X, KC_C, KC_V, KC_B, KC_LCBR, KC_RCBR, KC_N, KC_M, KC_COMM, KC_DOT, SFT_T(KC_SLSH)},
  35. {CTL_T(KC_TAB), OSL(FKEY), OSL(NUMS), OSL(SYMB), KC_SPC, ALT_T(KC_BSPC), GUI_T(KC_DELT), KC_ENT, OSL(SYMB), OSL(CURS), TG(CURS), CTL_T(KC_ESC)}
  36. },
  37. [NUMS] = {
  38. {KC_NO, KC_NO, KC_NO, KC_NO, KC_NO, KC_TRNS, KC_TRNS, KC_COMM, KC_7, KC_8, KC_9, KC_SLSH},
  39. {KC_LSFT, KC_LGUI, KC_LALT, KC_LCTL, KC_NO, KC_TRNS, KC_TRNS, KC_LPRN, KC_4, KC_5, KC_6, KC_ASTR},
  40. {KC_NO, KC_NO, KC_NO, KC_NO, KC_NO, KC_TRNS, KC_TRNS, KC_RPRN, KC_1, KC_2, KC_3, KC_MINS},
  41. {KC_NO, KC_NO, KC_TRNS, TG(NUMS), KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_0, KC_DOT, KC_EQL, KC_PLUS}
  42. },
  43. [CURS] = {
  44. {KC_MPLY, KC_BSPC, KC_UP, KC_DELT, KC_PGUP, KC_TRNS, KC_TRNS, KC_NO, KC_NO, KC_NO, KC_NO, KC_NO},
  45. {KC_VOLU, KC_LEFT, KC_DOWN, KC_RGHT, KC_PGDN, KC_TRNS, KC_TRNS, KC_NO, KC_LCTL, KC_LALT, KC_LGUI, KC_LSFT},
  46. {KC_VOLD, KC_NO, MY_ABVE, MY_TERM, KC_NO, KC_TRNS, KC_TRNS, KC_NO, KC_NO, KC_NO, KC_NO, KC_LSFT},
  47. {KC_MUTE, KC_NO, MY_BELW, KC_NO, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_NO, KC_TRNS, KC_TRNS, KC_NO}
  48. },
  49. [SYMB] = {
  50. {MY_DEQL, MY_MEQL, MY_SEQL, MY_PEQL, MY_NEQL, KC_NO, KC_NO, MY_LTGT, KC_LABK, KC_RABK, KC_COLN, KC_DLR},
  51. {KC_SLSH, KC_ASTR, KC_MINS, KC_PLUS, KC_EQL, KC_NO, KC_PIPE, MY_DPIP, KC_GRV, KC_QUOT, KC_DQUO, KC_HASH},
  52. {KC_BSLS, KC_CIRC, KC_PERC, KC_UNDS, KC_NO, KC_NO, KC_AMPR, MY_DAMP, KC_TILD, KC_AT, KC_EXLM, KC_QUES},
  53. {KC_NO, KC_NO, KC_NO, KC_TRNS, KC_NO, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_NO, KC_NO, KC_NO}
  54. },
  55. [FKEY] = {
  56. {KC_NO, KC_NO, KC_NO, KC_NO, KC_NO, KC_NO, KC_NO, KC_NO, KC_F9, KC_F10, KC_F11, KC_F12},
  57. {KC_LSFT, KC_LGUI, KC_LALT, KC_LCTL, KC_NO, KC_NO, KC_NO, KC_NO, KC_F5, KC_F6, KC_F7, KC_F8},
  58. {KC_NO, KC_NO, KC_NO, KC_NO, KC_NO, KC_NO, KC_NO, KC_NO, KC_F1, KC_F2, KC_F3, KC_F4},
  59. {KC_NO, KC_TRNS, KC_NO, KC_NO, KC_NO, KC_NO, KC_NO, KC_NO, KC_NO, KC_NO, KC_NO, KC_NO}
  60. }
  61. };
  62. void press_key(uint16_t key) {
  63. register_code(key);
  64. unregister_code(key);
  65. }
  66. void press_two_keys(uint16_t key1, uint16_t key2) {
  67. register_code(key1);
  68. register_code(key2);
  69. unregister_code(key2);
  70. unregister_code(key1);
  71. }
  72. void press_three_keys(uint16_t key1, uint16_t key2, uint16_t key3) {
  73. register_code(key1);
  74. register_code(key2);
  75. register_code(key3);
  76. unregister_code(key3);
  77. unregister_code(key2);
  78. unregister_code(key1);
  79. }
  80. bool process_record_user(uint16_t keycode, keyrecord_t *record) {
  81. switch (keycode) {
  82. case MY_BELW:
  83. if (record->event.pressed) {
  84. press_two_keys(KC_LGUI, KC_RGHT);
  85. press_key(KC_ENT);
  86. }
  87. return false;
  88. case MY_ABVE:
  89. if (record->event.pressed) {
  90. press_two_keys(KC_LGUI, KC_LEFT);
  91. press_key(KC_ENT);
  92. press_key(KC_UP);
  93. }
  94. return false;
  95. case MY_TERM:
  96. if (record->event.pressed) {
  97. press_three_keys(KC_LGUI, KC_LSFT, KC_ENT);
  98. }
  99. return false;
  100. case MY_DEQL: // /=
  101. if (record->event.pressed) {
  102. press_key(KC_SLSH);
  103. press_key(KC_EQL);
  104. }
  105. return false;
  106. case MY_MEQL: // *=
  107. if (record->event.pressed) {
  108. press_two_keys(KC_LSFT, KC_ASTR);
  109. press_key(KC_EQL);
  110. }
  111. return false;
  112. case MY_SEQL: // -=
  113. if (record->event.pressed) {
  114. press_key(KC_MINS);
  115. press_key(KC_EQL);
  116. }
  117. return false;
  118. case MY_PEQL: // +=
  119. if (record->event.pressed) {
  120. press_two_keys(KC_LSFT, KC_PLUS);
  121. press_key(KC_EQL);
  122. }
  123. return false;
  124. case MY_NEQL: // !=
  125. if (record->event.pressed) {
  126. press_two_keys(KC_LSFT, KC_EXLM);
  127. press_key(KC_EQL);
  128. }
  129. return false;
  130. case MY_LTGT: // <>
  131. if (record->event.pressed) {
  132. press_two_keys(KC_LSFT, KC_LABK);
  133. press_two_keys(KC_LSFT, KC_RABK);
  134. }
  135. return false;
  136. case MY_DPIP: // ||
  137. if (record->event.pressed) {
  138. press_two_keys(KC_LSFT, KC_PIPE);
  139. press_two_keys(KC_LSFT, KC_PIPE);
  140. }
  141. return false;
  142. case MY_DAMP: // &&
  143. if (record->event.pressed) {
  144. press_two_keys(KC_LSFT, KC_AMPR);
  145. press_two_keys(KC_LSFT, KC_AMPR);
  146. }
  147. return false;
  148. }
  149. return true;
  150. }