2
0

keymap.c 4.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245
  1. #include QMK_KEYBOARD_H
  2. extern keymap_config_t keymap_config;
  3. static uint16_t tap_timers[10] = { 0, 0, 0, 0, 0, 0, 0, 0, 0, 0};
  4. char last_mod = -1;
  5. enum planck_layers {
  6. _DVORAK,
  7. _RISE
  8. };
  9. // where the 'T_' communicates how the key does something different when tapped.
  10. enum planck_keycodes {
  11. DVORAK = SAFE_RANGE,
  12. KC_T_LALT,
  13. KC_T_RALT,
  14. KC_T_LGUI,
  15. KC_T_RGUI,
  16. KC_T_LCTL,
  17. KC_T_RCTL,
  18. KC_T_LSFT,
  19. KC_T_RSFT,
  20. KC_T_LRSE,
  21. KC_T_RRSE,
  22. KC_EZRGHT,
  23. KC_EZLEFT,
  24. KC_EZUP,
  25. KC_EZDOWN,
  26. KC_EZUNDO,
  27. KC_EZCOPY,
  28. KC_EZCUT,
  29. KC_EZPSTE
  30. };
  31. const uint16_t PROGMEM keymaps[][MATRIX_ROWS][MATRIX_COLS] = {
  32. [_DVORAK] =
  33. {{ KC_T_LRSE, KC_QUOT, KC_COMM, KC_DOT, KC_P, KC_Y, KC_F, KC_G, KC_C, KC_R, KC_L, KC_T_RRSE},
  34. { KC_T_LSFT, KC_A, KC_O, KC_E, KC_U, KC_I, KC_D, KC_H, KC_T, KC_N, KC_S, KC_T_RSFT},
  35. { KC_T_LCTL, KC_SCLN, KC_Q, KC_J, KC_K, KC_X, KC_B, KC_M, KC_W, KC_V, KC_Z, KC_T_RCTL},
  36. { KC_T_LGUI, KC_T_LALT, KC_UP, KC_DOWN, KC_BSPC, KC_TAB, KC_ENT, KC_SPC, KC_LEFT, KC_RIGHT, KC_T_RALT, KC_T_RGUI}
  37. },
  38. [_RISE] =
  39. {{ KC_TRANSPARENT, KC_EZUNDO, KC_EZCOPY, KC_EZCUT, KC_EZPSTE, KC_INS, KC_EQL, KC_7, KC_8, KC_9, KC_F11, KC_TRANSPARENT},
  40. { KC_TRANSPARENT, KC_ESC, KC_CAPS, KC_PGUP, KC_PGDN, KC_F4, KC_ASTR, KC_4, KC_5, KC_6, KC_0, KC_TRANSPARENT},
  41. { KC_TRANSPARENT, KC_EXLM, KC_AT, KC_HASH, KC_DLR, KC_PERC, KC_CIRC, KC_1, KC_2, KC_3, KC_F12, KC_TRANSPARENT},
  42. { KC_TRANSPARENT, KC_TRANSPARENT, KC_EZUP, KC_EZDOWN, KC_TRANSPARENT, KC_AMPR, KC_PIPE, KC_TRANSPARENT, KC_EZLEFT, KC_EZRGHT, KC_TRANSPARENT, KC_TRANSPARENT}
  43. },
  44. };
  45. void mod_press(uint16_t hold_code, int id) {
  46. tap_timers[id] = timer_read();
  47. last_mod = id;
  48. register_code(hold_code);
  49. }
  50. void mod_lift(uint16_t tap_code, uint16_t hold_code, int id) {
  51. unregister_code(hold_code);
  52. if (last_mod == id && timer_elapsed(tap_timers[id]) < TAPPING_TERM) {
  53. tap_code16(tap_code);
  54. last_mod = -1;
  55. }
  56. }
  57. bool process_record_user(uint16_t keycode, keyrecord_t *record) {
  58. switch (keycode) {
  59. case DVORAK:
  60. if (record->event.pressed) {
  61. set_single_persistent_default_layer(_DVORAK);
  62. }
  63. return false;
  64. break;
  65. case KC_T_LALT:
  66. if (record->event.pressed) {
  67. mod_press(KC_LALT, 0);
  68. } else {
  69. mod_lift(S(KC_9), KC_LALT, 0);
  70. }
  71. return false;
  72. break;
  73. case KC_T_RALT:
  74. if (record->event.pressed) {
  75. mod_press(KC_RALT, 1);
  76. } else {
  77. mod_lift(S(KC_0), KC_RALT, 1);
  78. }
  79. return false;
  80. break;
  81. case KC_T_LGUI:
  82. if (record->event.pressed) {
  83. mod_press(KC_LGUI, 2);
  84. } else {
  85. mod_lift(KC_GRAVE, KC_LGUI, 2);
  86. }
  87. return false;
  88. break;
  89. case KC_T_RGUI:
  90. if (record->event.pressed) {
  91. mod_press(KC_RGUI, 3);
  92. } else {
  93. mod_lift(KC_BSLASH, KC_RGUI, 3);
  94. }
  95. return false;
  96. break;
  97. case KC_T_LCTL:
  98. if (record->event.pressed) {
  99. mod_press(KC_LCTL, 4);
  100. } else {
  101. mod_lift(KC_LBRACKET, KC_LCTL, 4);
  102. }
  103. return false;
  104. break;
  105. case KC_T_RCTL:
  106. if (record->event.pressed) {
  107. mod_press(KC_RCTL, 5);
  108. } else {
  109. mod_lift(KC_RBRACKET, KC_RCTL, 5);
  110. }
  111. return false;
  112. break;
  113. case KC_T_LSFT:
  114. if (record->event.pressed) {
  115. mod_press(KC_LSFT, 6);
  116. } else {
  117. mod_lift(KC_EQUAL, KC_LSFT, 6);
  118. }
  119. return false;
  120. break;
  121. case KC_T_RSFT:
  122. if (record->event.pressed) {
  123. mod_press(KC_RSFT, 7);
  124. } else {
  125. mod_lift(KC_MINUS, KC_RSFT, 7);
  126. }
  127. return false;
  128. break;
  129. case KC_T_LRSE:
  130. if (record->event.pressed) {
  131. tap_timers[8] = timer_read();
  132. last_mod = 8;
  133. layer_on(_RISE);
  134. } else {
  135. layer_off(_RISE);
  136. if (last_mod == 8 && timer_elapsed(tap_timers[8]) < TAPPING_TERM) {
  137. tap_code16(KC_DELETE);
  138. last_mod = -1;
  139. }
  140. }
  141. return false;
  142. break;
  143. case KC_T_RRSE:
  144. if (record->event.pressed) {
  145. tap_timers[9] = timer_read();
  146. last_mod = 9;
  147. layer_on(_RISE);
  148. } else {
  149. layer_off(_RISE);
  150. if (last_mod == 9 && timer_elapsed(tap_timers[9]) < TAPPING_TERM) {
  151. tap_code16(KC_SLASH);
  152. last_mod = -1;
  153. }
  154. }
  155. return false;
  156. break;
  157. case KC_EZRGHT:
  158. if (record->event.pressed) {
  159. register_code(KC_LCTL);
  160. tap_code16(S(KC_RGHT));
  161. unregister_code(KC_LCTL);
  162. last_mod = -1;
  163. }
  164. return false;
  165. break;
  166. case KC_EZLEFT:
  167. if (record->event.pressed) {
  168. register_code(KC_LCTL);
  169. tap_code16(S(KC_LEFT));
  170. unregister_code(KC_LCTL);
  171. last_mod = -1;
  172. }
  173. return false;
  174. break;
  175. case KC_EZDOWN:
  176. if (record->event.pressed) {
  177. register_code(KC_LCTL);
  178. tap_code16(S(KC_DOWN));
  179. unregister_code(KC_LCTL);
  180. last_mod = -1;
  181. }
  182. return false;
  183. break;
  184. case KC_EZUP:
  185. if (record->event.pressed) {
  186. register_code(KC_LCTL);
  187. tap_code16(S(KC_UP));
  188. unregister_code(KC_LCTL);
  189. last_mod = -1;
  190. }
  191. return false;
  192. break;
  193. case KC_EZUNDO:
  194. if (record->event.pressed) {
  195. tap_code16(C(KC_Z));
  196. last_mod = -1;
  197. }
  198. return false;
  199. break;
  200. case KC_EZCOPY:
  201. if (record->event.pressed) {
  202. tap_code16(C(KC_C));
  203. last_mod = -1;
  204. }
  205. return false;
  206. break;
  207. case KC_EZCUT:
  208. if (record->event.pressed) {
  209. tap_code16(C(KC_X));
  210. last_mod = -1;
  211. }
  212. return false;
  213. break;
  214. case KC_EZPSTE:
  215. if (record->event.pressed) {
  216. tap_code16(C(KC_P));
  217. last_mod = -1;
  218. }
  219. return false;
  220. break;
  221. }
  222. last_mod = -1;
  223. return true;
  224. }