process_records.c 5.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167
  1. #include "process_records.h"
  2. #include "alt_tab.h"
  3. extern bool onMac;
  4. // ======== INCREMENTAL MACROS STUFF =============
  5. #define MAX_INCREMENTAL_MACRO 20
  6. #define TAP_ROTATION_TIMEOUT 400
  7. uint16_t latest_kc = 0;
  8. uint16_t latest_rotation = 0;
  9. int key_count = 0;
  10. const char incremental_macros[][MAX_INCREMENTAL_MACRO] = { "String1"SS_TAP(X_HOME)"X-", "String2"SS_TAP(X_HOME) };
  11. bool process_incremental_macro(uint16_t kc) {
  12. if (kc < INC_MACROS_START || kc > INC_MACROS_END) {
  13. return false;
  14. }
  15. int macro_idx = (int)(kc - INC_MACROS_START) - 1;
  16. char tempstring[3] = {0};
  17. tempstring[0] = incremental_macros[macro_idx][key_count];
  18. // Special cases of SS_TAP SS_UP and SS_DOWN, they require two characters so get both once and skip on next iteration
  19. if (tempstring[0] == '\1' || tempstring[0] == '\2' || tempstring[0] == '\3') {
  20. tempstring[1] = incremental_macros[macro_idx][++key_count];
  21. }
  22. if (tempstring[0] == '\0') {
  23. key_count = 0;
  24. }
  25. send_string(tempstring);
  26. return true;
  27. };
  28. void refresh_incremental_macros(uint16_t kc) {
  29. if (kc == latest_kc) {
  30. if ((timer_elapsed(latest_rotation) > TAP_ROTATION_TIMEOUT) || (key_count >= MAX_INCREMENTAL_MACRO))
  31. key_count = 0;
  32. else
  33. key_count++;
  34. } else {
  35. key_count = 0;
  36. latest_kc = kc;
  37. }
  38. latest_rotation = timer_read();
  39. }
  40. // Send control or GUI depending if we are on windows or mac
  41. bool CMD(uint16_t kc) {
  42. if(onMac){ tap_code16(LGUI(kc)); } else { tap_code16(LCTL(kc)); }
  43. return false;
  44. }
  45. bool process_record_user(uint16_t keycode, keyrecord_t *record) {
  46. bool pressed = record->event.pressed;
  47. if(pressed){
  48. refresh_incremental_macros(keycode);
  49. if(process_incremental_macro(keycode)){
  50. return false;
  51. }
  52. switch (keycode) {
  53. case MAC_TGL:
  54. onMac = !onMac;
  55. onMac ? SEND_STRING("On mac") : SEND_STRING("Not on MAC");
  56. return false;
  57. }
  58. }
  59. switch (keycode) {
  60. case QWERTY:
  61. if (record->event.pressed) {
  62. #ifdef AUDIO_ENABLE
  63. PLAY_SONG(tone_qwerty);
  64. #endif
  65. layer_on(_QWERTY);
  66. }
  67. return false;
  68. case LOWER:
  69. if (record->event.pressed) {
  70. layer_on(_LOWER);
  71. } else {
  72. layer_off(_LOWER);
  73. }
  74. return false;
  75. case RAISE:
  76. if (record->event.pressed) {
  77. layer_on(_RAISE);
  78. } else {
  79. layer_off(_RAISE);
  80. }
  81. return false;
  82. case ADJUST:
  83. if (record->event.pressed) {
  84. layer_on(_ADJUST);
  85. } else {
  86. layer_off(_ADJUST);
  87. }
  88. return false;
  89. // == Macros START ===
  90. case IARROW: if (record->event.pressed) SEND_STRING("<-"); return false;
  91. case ARROW: if (record->event.pressed) SEND_STRING("->"); return false;
  92. case F_ARROW: if (record->event.pressed) SEND_STRING("=>"); return false;
  93. case GREP: if (record->event.pressed) SEND_STRING(" | grep "); return false;
  94. case CLN_EQ: if (record->event.pressed) SEND_STRING(":="); return false;
  95. // == Macros END ===
  96. // == Multi Os START ===
  97. case KC_HOME:// make the home behave the same on OSX
  98. if (record->event.pressed && onMac) {
  99. SEND_STRING(SS_LCTRL("a"));
  100. return false;
  101. }
  102. case KC_END:// make the end behave the same on OSX
  103. if (record->event.pressed && onMac) {
  104. tap_code16(C(KC_E));
  105. return false;
  106. }
  107. case AC_A:// Accent á
  108. if (record->event.pressed) SEND_STRING(SS_LALT("e") "a"); return false;
  109. case AC_E:// Accent é
  110. if (record->event.pressed) SEND_STRING(SS_LALT("e") "e"); return false;
  111. case AC_I:// Accent í
  112. if (record->event.pressed) SEND_STRING(SS_LALT("e") "i"); return false;
  113. case AC_O:// Accent ó
  114. if (record->event.pressed) SEND_STRING(SS_LALT("e") "o"); return false;
  115. case CUT: if (record->event.pressed) return CMD(KC_X);
  116. case COPY:
  117. if (record->event.pressed) {
  118. onMac ? SEND_STRING(SS_LGUI("c")) : SEND_STRING(SS_LCTRL("c"));
  119. }
  120. return false;
  121. case PASTE:
  122. if (record->event.pressed) {
  123. onMac ? SEND_STRING(SS_LGUI("v")) : SEND_STRING(SS_LCTRL("v"));
  124. }
  125. return false;
  126. case SAVE:
  127. if (record->event.pressed) {
  128. onMac ? SEND_STRING(SS_LGUI("s")) : SEND_STRING(SS_LCTRL("s"));
  129. }
  130. return false;
  131. case UNDO:
  132. if (record->event.pressed) {
  133. onMac ? SEND_STRING(SS_LGUI("z")) : SEND_STRING(SS_LCTRL("z"));
  134. }
  135. return false;
  136. case FIND:
  137. if (record->event.pressed) {
  138. onMac ? SEND_STRING(SS_LGUI("f")) : SEND_STRING(SS_LCTRL("f"));
  139. }
  140. return false;
  141. case CHG_LAYOUT:
  142. if (record->event.pressed) {
  143. onMac ? SEND_STRING(SS_LCTRL(" ")) : SEND_STRING(SS_LCTRL("f"));
  144. }
  145. return false;
  146. // == Multi Os END ===
  147. #ifdef RGBLIGHT_ENABLE
  148. case RGB_SLD:
  149. if (record->event.pressed) { rgblight_mode(1); }
  150. return false;
  151. break;
  152. //First time alt + tab, and alt stays sticky. Next press we just send tab. Any other key releases the alt
  153. #endif
  154. }
  155. // =============== ALT_TAB single key handling
  156. return process_alt_tab(keycode, record);
  157. };