keymap.c 5.9 KB

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