keymap.c 44 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878879880881882883884885886887888889890891892893894895896897898899900901902903904905906907908909910911912913914915916917918919920921922923924925926927928929930931932933934935936937938939940941942943944945946947948949950951952953954955956957958959960961962963964965966967968969970971972973974975976977978979980981982983984985986987988989990991992993994995996997998999100010011002100310041005100610071008100910101011101210131014101510161017101810191020102110221023102410251026102710281029103010311032103310341035103610371038103910401041104210431044104510461047104810491050105110521053105410551056105710581059106010611062106310641065106610671068106910701071107210731074107510761077107810791080108110821083108410851086108710881089109010911092109310941095109610971098109911001101110211031104110511061107110811091110111111121113111411151116111711181119112011211122112311241125112611271128112911301131113211331134113511361137113811391140114111421143114411451146114711481149115011511152115311541155115611571158115911601161116211631164116511661167116811691170117111721173117411751176117711781179118011811182118311841185118611871188118911901191119211931194119511961197119811991200120112021203120412051206
  1. /*
  2. * algernon's ErgoDox EZ layout, please see the readme.md file!
  3. */
  4. #include "ergodox.h"
  5. #include "led.h"
  6. #include "debug.h"
  7. #include "action_layer.h"
  8. #include "action_util.h"
  9. #include "mousekey.h"
  10. #include "timer.h"
  11. #include "keymap_plover.h"
  12. #include "eeconfig.h"
  13. #include "wait.h"
  14. #include "version.h"
  15. /* Layers */
  16. enum {
  17. BASE = 0,
  18. ADORE,
  19. ARRW,
  20. APPSEL,
  21. HUN,
  22. NMDIA,
  23. PLVR,
  24. };
  25. /* Macros */
  26. enum {
  27. NONE = 0,
  28. // Buttons that do extra stuff
  29. A_GUI,
  30. A_PLVR,
  31. A_ESC,
  32. A_MPN,
  33. // Function / number keys
  34. KF_1, // 1, F1
  35. KF_2, // 2, F2
  36. KF_3, // ...
  37. KF_4,
  38. KF_5,
  39. KF_6,
  40. KF_7,
  41. KF_8,
  42. KF_9,
  43. KF_10,
  44. KF_11, // =, F11
  45. // Application select keys
  46. APP_SLK, // Slack
  47. APP_EMCS, // Emacs
  48. APP_TERM, // Terminal
  49. APP_CHRM, // Chrome
  50. APP_MSIC, // Music
  51. // Diagonal mouse movement
  52. A_MUL,
  53. A_MUR,
  54. A_MDL,
  55. A_MDR,
  56. // Hungarian layer keys
  57. HU_AA, // Á
  58. HU_OO, // Ó
  59. HU_EE, // É
  60. HU_UU, // Ú
  61. HU_II, // Í
  62. HU_OE, // Ö
  63. HU_UE, // Ü
  64. HU_OEE, // Ő
  65. HU_UEE, // Ű
  66. };
  67. /* Fn keys */
  68. enum {
  69. F_BSE = 0,
  70. F_HUN,
  71. F_GUI,
  72. F_SFT,
  73. F_ALT,
  74. F_CTRL
  75. };
  76. /* Custom keycodes */
  77. enum {
  78. CT_CLN = 0,
  79. CT_MNS,
  80. CT_TA,
  81. CT_LBP,
  82. CT_RBP
  83. };
  84. /* States & timers */
  85. uint16_t gui_timer = 0;
  86. uint16_t kf_timers[12];
  87. #if KEYLOGGER_ENABLE
  88. bool log_enable = false;
  89. #endif
  90. bool time_travel = false;
  91. /* The Keymap */
  92. const uint16_t PROGMEM keymaps[][MATRIX_ROWS][MATRIX_COLS] = {
  93. /* Keymap 0: Base Layer
  94. *
  95. * ,-----------------------------------------------------. ,-----------------------------------------------------.
  96. * | Next/Prev | 1 F1 | 2 F2 | 3 F3 | 4 F4 | 5 F5 | Plvr | | Apps | 6 F6 | 7 F7 | 8 F8 | 9 F9 | 0 F10| F11 |
  97. * |-----------+------+------+------+------+-------------| |------+------+------+------+------+------+-----------|
  98. * | ~ | ' | , | . | P | Y | [ | | ] | F | G | C | R | L | \ |
  99. * |-----------+------+------+------+------+------| | | |------+------+------+------+------+-----------|
  100. * | Tab/ARROW | A | O | E | U | I |------| |------| D | H | T | N | S | = / Arrow |
  101. * |-----------+------+------+------+------+------| ( | | ) |------+------+------+------+------+-----------|
  102. * | Play/Pause| / | Q | J | K | X | | | | B | M | W | V | Z | Stop |
  103. * `-----------+------+------+------+------+-------------' `-------------+------+------+------+------+-----------'
  104. * | | | | | : | | - | | | | |
  105. * `-----------------------------------' `-----------------------------------'
  106. * ,-------------. ,-------------.
  107. * | LAlt | GUI | | MDIA | Del |
  108. * ,------|------|------| |------+------+------.
  109. * | | | Ctrl | | LEAD | | |
  110. * |Backsp|LShift|------| |------| Enter| Space|
  111. * | | | ESC | | HUN | | |
  112. * `--------------------' `--------------------'
  113. */
  114. [BASE] = KEYMAP(
  115. // left hand
  116. M(A_MPN) ,M(KF_1) ,M(KF_2) ,M(KF_3),M(KF_4),M(KF_5),M(A_PLVR)
  117. ,KC_GRV ,KC_QUOT ,KC_COMM ,KC_DOT ,KC_P ,KC_Y ,KC_LBRC
  118. ,TD(CT_TA) ,KC_A ,KC_O ,KC_E ,KC_U ,KC_I
  119. ,KC_MPLY ,KC_SLSH ,KC_Q ,KC_J ,KC_K ,KC_X ,KC_LPRN
  120. ,KC_NO ,KC_NO ,KC_NO ,KC_NO ,TD(CT_CLN)
  121. ,F(F_ALT),F(F_GUI)
  122. ,F(F_CTRL)
  123. ,KC_BSPC,F(F_SFT),M(A_ESC)
  124. // right hand
  125. ,KC_APP ,M(KF_6),M(KF_7) ,M(KF_8),M(KF_9) ,M(KF_10) ,KC_F11
  126. ,KC_RBRC ,KC_F ,KC_G ,KC_C ,KC_R ,KC_L ,KC_BSLS
  127. ,KC_D ,KC_H ,KC_T ,KC_N ,KC_S ,KC_EQL
  128. ,KC_RPRN ,KC_B ,KC_M ,KC_W ,KC_V ,KC_Z ,KC_MSTP
  129. ,TD(CT_MNS),KC_NO ,KC_NO ,KC_NO ,KC_NO
  130. ,OSL(NMDIA),KC_DEL
  131. ,KC_LEAD
  132. ,F(F_HUN) ,KC_ENT ,KC_SPC
  133. ),
  134. /* Keymap 1: Adore layer
  135. *
  136. * ,-----------------------------------------------------. ,-----------------------------------------------------.
  137. * | Play/Pause| 1 F1 | 2 F2 | 3 F3 | 4 F4 | 5 F5 | Plvr | | Apps | 6 F6 | 7 F7 | 8 F8 | 9 F9 | 0 F10| F11 |
  138. * |-----------+------+------+------+------+-------------| |------+------+------+------+------+------+-----------|
  139. * | `~ | X | W | K | L | M | ( | | ) | F | H | C | P | Y | \ |
  140. * |-----------+------+------+------+------+------| [ | | ] |------+------+------+------+------+-----------|
  141. * | Tab/Arrow | A | O | E | I | U |------| |------| D | R | T | N | S | = |
  142. * |-----------+------+------+------+------+------| | | |------+------+------+------+------+-----------|
  143. * | | Z | Q | ' | , | . | : | | - | B | G | V | J | / | |
  144. * `-----------+------+------+------+------+-------------' `-------------+------+------+------+------+-----------'
  145. * | | | | | | | | | | | |
  146. * `-----------------------------------' `-----------------------------------'
  147. * ,-------------. ,-------------.
  148. * | LAlt | GUI | | MDIA | Del |
  149. * ,------|------|------| |------+------+------.
  150. * | | | Ctrl | | HUN | | |
  151. * |Backsp|LShift|------| |------| Enter| Space|
  152. * | | | ESC | | LEAD | | |
  153. * `--------------------' `--------------------'
  154. */
  155. [ADORE] = KEYMAP(
  156. // left hand
  157. KC_MPLY ,M(KF_1) ,M(KF_2) ,M(KF_3),M(KF_4),M(KF_5),M(A_PLVR)
  158. ,KC_GRV ,KC_X ,KC_W ,KC_K ,KC_L ,KC_M ,TD(CT_LBP)
  159. ,TD(CT_TA) ,KC_A ,KC_O ,KC_E ,KC_I ,KC_U
  160. ,KC_NO ,KC_Z ,KC_Q ,KC_QUOT,KC_COMM,KC_DOT ,TD(CT_CLN)
  161. ,KC_NO ,KC_NO ,KC_NO ,KC_NO ,KC_NO
  162. ,F(F_ALT),F(F_GUI)
  163. ,F(F_CTRL)
  164. ,KC_BSPC,F(F_SFT),M(A_ESC)
  165. // right hand
  166. ,KC_APP ,M(KF_6),M(KF_7),M(KF_8),M(KF_9) ,M(KF_10) ,KC_F11
  167. ,TD(CT_RBP),KC_F ,KC_H ,KC_C ,KC_P ,KC_Y ,KC_BSLS
  168. ,KC_D ,KC_R ,KC_T ,KC_N ,KC_S ,KC_EQL
  169. ,TD(CT_MNS),KC_B ,KC_G ,KC_V ,KC_J ,KC_SLSH ,KC_NO
  170. ,KC_NO ,KC_NO ,KC_NO ,KC_NO ,KC_NO
  171. ,OSL(NMDIA),KC_DEL
  172. ,F(F_HUN)
  173. ,KC_LEAD ,KC_ENT ,KC_SPC
  174. ),
  175. /* Keymap 2: Arrow layer
  176. *
  177. * ,-----------------------------------------------------. ,-----------------------------------------------------.
  178. * | | | | | | | | | | | | | | | |
  179. * |-----------+------+------+------+------+-------------| |------+------+------+------+------+------+-----------|
  180. * | | | | | | | | | | | Home | Up | End | | |
  181. * |-----------+------+------+------+------+------| | | |------+------+------+------+------+-----------|
  182. * | | | | | | |------| |------| | Left | Down | Rght | | |
  183. * |-----------+------+------+------+------+------| | | |------+------+------+------+------+-----------|
  184. * | | | | | | | | | | | | | | | |
  185. * `-----------+------+------+------+------+-------------' `-------------+------+------+------+------+-----------'
  186. * | | | | | | | | | | | |
  187. * `----------------------------------' `----------------------------------'
  188. * ,-------------. ,-------------.
  189. * | | | | | |
  190. * ,------|------|------| |------+------+------.
  191. * | | | | | | | |
  192. * | Enter| |------| |------| PgUp | PgDn |
  193. * | | | | | | | |
  194. * `--------------------' `--------------------'
  195. */
  196. [ARRW] = KEYMAP(
  197. // left hand
  198. KC_TRNS ,KC_TRNS ,KC_TRNS ,KC_TRNS ,KC_TRNS ,KC_TRNS ,KC_TRNS
  199. ,KC_TRNS ,KC_TRNS ,KC_TRNS ,KC_TRNS ,KC_TRNS ,KC_TRNS ,KC_TRNS
  200. ,KC_TRNS ,KC_TRNS ,KC_TRNS ,KC_TRNS ,KC_TRNS ,KC_TRNS
  201. ,KC_TRNS ,KC_TRNS ,KC_TRNS ,KC_TRNS ,KC_TRNS ,KC_TRNS ,KC_TRNS
  202. ,KC_TRNS ,KC_TRNS ,KC_TRNS ,KC_TRNS ,KC_TRNS
  203. ,KC_TRNS ,KC_TRNS
  204. ,KC_TRNS
  205. ,KC_ENT ,KC_TRNS ,KC_TRNS
  206. // right hand
  207. ,KC_TRNS ,KC_TRNS ,KC_TRNS ,KC_TRNS ,KC_TRNS ,KC_TRNS ,KC_TRNS
  208. ,KC_TRNS ,KC_TRNS ,KC_HOME ,KC_UP ,KC_END ,KC_TRNS ,KC_TRNS
  209. ,KC_TRNS ,KC_LEFT ,KC_DOWN ,KC_RGHT ,KC_TRNS ,KC_TRNS
  210. ,KC_TRNS ,KC_TRNS ,KC_TRNS ,KC_TRNS ,KC_TRNS ,KC_TRNS ,KC_TRNS
  211. ,KC_TRNS ,KC_TRNS ,KC_TRNS ,KC_TRNS ,KC_TRNS
  212. ,KC_TRNS ,KC_TRNS
  213. ,KC_TRNS
  214. ,KC_TRNS ,KC_PGUP ,KC_PGDN
  215. ),
  216. /* Keymap 3: Application select layer
  217. *
  218. * ,-----------------------------------------------------. ,-----------------------------------------------------.
  219. * | |Music |Slack |Emacs |Term |Chrome| | | | | | | | | |
  220. * |-----------+------+------+------+------+-------------| |------+------+------+------+------+------+-----------|
  221. * | | | | | | | | | | | | | | | |
  222. * |-----------+------+------+------+------+------| | | |------+------+------+------+------+-----------|
  223. * | | | | | | |------| |------| | | | | | |
  224. * |-----------+------+------+------+------+------| | | |------+------+------+------+------+-----------|
  225. * | | | | | | | | | | | | | | | |
  226. * `-----------+------+------+------+------+-------------' `-------------+------+------+------+------+-----------'
  227. * | | | | | | | | | | | |
  228. * `----------------------------------' `----------------------------------'
  229. * ,-------------. ,-------------.
  230. * | | | | | |
  231. * ,------|------|------| |------+------+------.
  232. * | | | | | | | |
  233. * | | |------| |------| | |
  234. * | | | | | | | |
  235. * `--------------------' `--------------------'
  236. */
  237. [APPSEL] = KEYMAP(
  238. // left hand
  239. KC_TRNS ,M(APP_MSIC),M(APP_SLK),M(APP_EMCS),M(APP_TERM),M(APP_CHRM),KC_TRNS
  240. ,KC_TRNS ,KC_TRNS ,KC_TRNS ,KC_TRNS ,KC_TRNS ,KC_TRNS ,KC_TRNS
  241. ,KC_TRNS ,KC_TRNS ,KC_TRNS ,KC_TRNS ,KC_TRNS ,KC_TRNS
  242. ,KC_TRNS ,KC_TRNS ,KC_TRNS ,KC_TRNS ,KC_TRNS ,KC_TRNS ,KC_TRNS
  243. ,KC_TRNS ,KC_TRNS ,KC_TRNS ,KC_TRNS ,KC_TRNS
  244. ,KC_TRNS ,KC_TRNS
  245. ,KC_TRNS
  246. ,KC_TRNS ,KC_TRNS ,KC_TRNS
  247. // right hand
  248. ,KC_TRNS ,KC_NO ,KC_NO ,KC_NO ,KC_NO ,KC_NO ,KC_TRNS
  249. ,KC_TRNS ,KC_TRNS ,KC_TRNS ,KC_TRNS ,KC_TRNS ,KC_TRNS ,KC_TRNS
  250. ,KC_TRNS ,KC_TRNS ,KC_TRNS ,KC_TRNS ,KC_TRNS ,KC_TRNS
  251. ,KC_TRNS ,KC_TRNS ,KC_TRNS ,KC_TRNS ,KC_TRNS ,KC_TRNS ,KC_TRNS
  252. ,KC_TRNS ,KC_TRNS ,KC_TRNS ,KC_TRNS ,KC_TRNS
  253. ,KC_TRNS ,KC_TRNS
  254. ,KC_TRNS
  255. ,KC_TRNS ,KC_TRNS ,KC_TRNS
  256. ),
  257. /* Keymap 4: Hungarian Layer
  258. *
  259. * ,-----------------------------------------------------. ,-----------------------------------------------------.
  260. * | | | | | | | | | | | | | | | |
  261. * |-----------+------+------+------+------+-------------| |------+------+------+------+------+------+-----------|
  262. * | | | Ő | | Ű | | | | | | | | | | |
  263. * |-----------+------+------+------+------+------| | | |------+------+------+------+------+-----------|
  264. * | | Á | Ó | É | Ú | Í |------| |------| | | | | | |
  265. * |-----------+------+------+------+------+------| | | |------+------+------+------+------+-----------|
  266. * | | | Ö | | Ü | | | | | | | | | | |
  267. * `-----------+------+------+------+------+-------------' `-------------+------+------+------+------+-----------'
  268. * | | | | | | | | | | | |
  269. * `----------------------------------' `----------------------------------'
  270. * ,-------------. ,-------------.
  271. * | | | | | |
  272. * ,------|------|------| |------+------+------.
  273. * | | | | | | | |
  274. * | | |------| |------| | |
  275. * | | | | | BASE | | |
  276. * `--------------------' `--------------------'
  277. */
  278. [HUN] = KEYMAP(
  279. // left hand
  280. KC_NO ,KC_NO ,KC_NO ,KC_NO ,KC_NO ,KC_NO ,KC_NO
  281. ,KC_NO ,KC_NO ,M(HU_OEE),KC_NO ,M(HU_UEE),KC_NO ,KC_NO
  282. ,KC_NO ,M(HU_AA),M(HU_OO) ,M(HU_EE),M(HU_UU) ,M(HU_II)
  283. ,KC_NO ,KC_NO ,M(HU_OE) ,KC_NO ,M(HU_UE) ,KC_NO ,KC_NO
  284. ,KC_NO ,KC_NO ,KC_NO ,KC_NO ,KC_NO
  285. ,KC_NO ,KC_NO
  286. ,KC_NO
  287. ,KC_NO ,KC_TRNS ,KC_TRNS
  288. // right hand
  289. ,KC_TRNS ,KC_NO ,KC_NO ,KC_NO ,KC_NO ,KC_NO ,KC_NO
  290. ,KC_NO ,KC_NO ,KC_NO ,KC_NO ,KC_NO ,KC_NO ,KC_NO
  291. ,KC_NO ,KC_NO ,KC_NO ,KC_NO ,KC_NO ,KC_NO
  292. ,KC_NO ,KC_NO ,KC_NO ,KC_NO ,KC_NO ,KC_NO ,KC_NO
  293. ,KC_NO ,KC_NO ,KC_NO ,KC_NO ,KC_NO
  294. ,KC_NO ,KC_NO
  295. ,KC_NO
  296. ,F(F_BSE),KC_TRNS ,KC_TRNS
  297. ),
  298. /* Keymap 5: Navigation & Media layer
  299. *
  300. * ,-----------------------------------------------------. ,-----------------------------------------------------.
  301. * | MS Slow | | | | | |ScrLCK| |ScrLCK| | | | | | |
  302. * |-----------+------+------+------+------+-------------| |------+------+------+------+------+------+-----------|
  303. * | MS Normal | | Home | Up | PgUp | | | |Scroll| |MsUpL | MsUp |MsUpR | |PrintScreen|
  304. * |-----------+------+------+------+------+------| | | Up |------+------+------+------+------+-----------|
  305. * | MS Fast | | Left | Down | Right| |------| |------| |MsLeft| MsDn |MsRght| | |
  306. * |-----------+------+------+------+------+------| | |Scroll|------+------+------+------+------+-----------|
  307. * | Play/Pause| | End | Down | PgDn | | | | Down | |MsDnL | MsDn |MsDnR | | Stop |
  308. * `-----------+------+------+------+------+-------------' `-------------+------+------+------+------+-----------'
  309. * | | | | | | | | | | | |
  310. * `----------------------------------' `----------------------------------'
  311. * ,-------------. ,-------------.
  312. * | Mute | VlUp | | BASE | MClk |
  313. * ,------|------|------| |------+------+------.
  314. * | | | VlDn | | Prev |Left |Right |
  315. * | SPC | Enter|------| |------| Click| Click|
  316. * | | | ESC | | Next | | |
  317. * `--------------------' `--------------------'
  318. */
  319. [NMDIA] = KEYMAP(
  320. // left hand
  321. KC_ACL0 ,KC_NO ,KC_NO ,KC_NO ,KC_NO ,KC_NO ,LGUI(KC_L)
  322. ,KC_ACL1 ,KC_NO ,KC_HOME ,KC_UP ,KC_PGUP ,KC_NO ,KC_NO
  323. ,KC_ACL2 ,KC_NO ,KC_LEFT ,KC_DOWN ,KC_RIGHT,KC_NO
  324. ,KC_MPLY ,KC_NO ,KC_END ,KC_DOWN ,KC_PGDN ,KC_NO ,KC_NO
  325. ,KC_NO ,KC_NO ,KC_NO ,KC_NO ,KC_NO
  326. ,KC_MUTE ,KC_VOLU
  327. ,KC_VOLD
  328. ,KC_SPC,KC_ENTER,M(A_ESC)
  329. // right hand
  330. ,LGUI(KC_L),KC_NO ,KC_NO ,KC_NO ,KC_NO ,KC_NO ,KC_NO
  331. ,KC_WH_U ,KC_NO ,M(A_MUL),KC_MS_U ,M(A_MUR),KC_NO ,KC_PSCR
  332. ,KC_NO ,KC_MS_L ,KC_MS_D ,KC_MS_R ,KC_NO ,KC_NO
  333. ,KC_WH_D ,KC_NO ,M(A_MDL),KC_MS_D ,M(A_MDR),KC_NO ,KC_MSTP
  334. ,KC_NO ,KC_NO ,KC_NO ,KC_NO ,KC_NO
  335. ,KC_TRNS ,KC_MS_BTN3
  336. ,KC_MPRV
  337. ,KC_MNXT ,KC_BTN1 ,KC_BTN2
  338. ),
  339. /* Keymap 6: Steno for Plover
  340. *
  341. * ,--------------------------------------------------. ,--------------------------------------------------.
  342. * | | | | | | | BASE | | | | | | | | |
  343. * |--------+------+------+------+------+-------------| |------+------+------+------+------+------+--------|
  344. * | | # | # | # | # | # | # | | # | # | # | # | # | # | # |
  345. * |--------+------+------+------+------+------| | | |------+------+------+------+------+--------|
  346. * | | | T | P | H | |------| |------| | F | P | L | T | D |
  347. * |--------+ S +------+------+------+ * | * | | * | * +------+------+------+------+--------|
  348. * | | | K | W | R | | | | | | R | B | G | S | Z |
  349. * `--------+------+------+------+------+-------------' `-------------+------+------+------+------+--------'
  350. * | | | | | | | | | | | |
  351. * `----------------------------------' `----------------------------------'
  352. * ,-------------. ,-------------.
  353. * | | | | | |
  354. * ,------|------|------| |------+------+------.
  355. * | | | | | | | |
  356. * | A | O |------| |------| E | U |
  357. * | | | | | | | |
  358. * `--------------------' `--------------------'
  359. */
  360. [PLVR] = KEYMAP(
  361. // left hand
  362. KC_NO, KC_NO, KC_NO, KC_NO, KC_NO, KC_NO, M(A_PLVR),
  363. KC_NO, PV_NUM, PV_NUM, PV_NUM, PV_NUM, PV_NUM, PV_NUM,
  364. KC_NO, PV_LS, PV_LT, PV_LP, PV_LH, PV_STAR,
  365. KC_NO, PV_LS, PV_LK, PV_LW, PV_LR, PV_STAR, PV_STAR,
  366. KC_NO, KC_NO, KC_NO, KC_NO, KC_NO,
  367. KC_NO, KC_NO,
  368. KC_NO,
  369. PV_A, PV_O, KC_NO,
  370. // right hand
  371. KC_NO, KC_NO, KC_NO, KC_NO, KC_NO, KC_NO, KC_NO,
  372. PV_NUM, PV_NUM, PV_NUM, PV_NUM, PV_NUM, PV_NUM, PV_NUM,
  373. PV_STAR, PV_RF, PV_RP, PV_RL, PV_RT, PV_RD,
  374. PV_STAR, PV_STAR, PV_RR, PV_RB, PV_RG, PV_RS, PV_RZ,
  375. KC_NO, KC_NO, KC_NO, KC_NO, KC_NO,
  376. KC_NO, KC_NO,
  377. KC_NO,
  378. KC_NO,PV_E, PV_U
  379. ),
  380. };
  381. const uint16_t PROGMEM fn_actions[] = {
  382. [F_BSE] = ACTION_LAYER_CLEAR(ON_PRESS)
  383. ,[F_HUN] = ACTION_LAYER_INVERT(HUN, ON_PRESS)
  384. ,[F_GUI] = ACTION_MACRO_TAP(A_GUI)
  385. ,[F_SFT] = ACTION_MODS_ONESHOT (MOD_LSFT)
  386. ,[F_ALT] = ACTION_MODS_ONESHOT (MOD_LALT)
  387. ,[F_CTRL] = ACTION_MODS_ONESHOT (MOD_LCTL)
  388. };
  389. void toggle_steno(int pressed)
  390. {
  391. uint8_t layer = biton32(layer_state);
  392. if (pressed) {
  393. if (layer != PLVR) layer_on(PLVR); else layer_off(PLVR);
  394. register_code(PV_LP);
  395. register_code(PV_LH);
  396. register_code(PV_LR);
  397. register_code(PV_O);
  398. register_code(PV_RL);
  399. register_code(PV_RG);
  400. } else {
  401. unregister_code(PV_LP);
  402. unregister_code(PV_LH);
  403. unregister_code(PV_LR);
  404. unregister_code(PV_O);
  405. unregister_code(PV_RL);
  406. unregister_code(PV_RG);
  407. }
  408. }
  409. macro_t *ang_do_hun (keyrecord_t *record, uint16_t accent, uint16_t hun_char)
  410. {
  411. uint8_t need_shift = 0;
  412. uint8_t hold_shift = 0;
  413. if (!record->event.pressed)
  414. return MACRO_NONE;
  415. layer_off (HUN);
  416. if (keyboard_report->mods & MOD_BIT (KC_LSFT)) {
  417. hold_shift = 1;
  418. need_shift = 1;
  419. unregister_code (KC_LSFT);
  420. }
  421. if ((get_oneshot_mods () & MOD_BIT(KC_LSFT)) && !has_oneshot_mods_timed_out ()) {
  422. need_shift = 1;
  423. hold_shift = 0;
  424. unregister_code (KC_LSFT);
  425. }
  426. clear_oneshot_mods ();
  427. register_code (KC_RALT);
  428. unregister_code (KC_RALT);
  429. if (accent == (KC_DQT)) {
  430. register_code (KC_RSFT);
  431. }
  432. register_code (accent);
  433. unregister_code (accent);
  434. if (need_shift && accent != (KC_DQT)) {
  435. register_code (KC_RSFT);
  436. } else if (accent == (KC_DQT) && !need_shift) {
  437. unregister_code (KC_RSFT);
  438. }
  439. register_code (hun_char);
  440. unregister_code (hun_char);
  441. if (need_shift || accent == (KC_DQT))
  442. unregister_code (KC_RSFT);
  443. if (hold_shift)
  444. register_code (KC_LSFT);
  445. return MACRO_NONE;
  446. }
  447. void ang_handle_kf (keyrecord_t *record, uint8_t id)
  448. {
  449. uint8_t code = id - KF_1;
  450. if (record->event.pressed) {
  451. kf_timers[code] = timer_read ();
  452. } else {
  453. uint8_t kc;
  454. if (timer_elapsed (kf_timers[code]) > TAPPING_TERM) {
  455. // Long press
  456. kc = KC_F1 + code;
  457. } else {
  458. if (id == KF_11)
  459. kc = KC_EQL;
  460. else
  461. kc = KC_1 + code;
  462. }
  463. register_code (kc);
  464. unregister_code (kc);
  465. }
  466. }
  467. const macro_t *action_get_macro(keyrecord_t *record, uint8_t id, uint8_t opt)
  468. {
  469. switch(id) {
  470. case A_ESC:
  471. if (record->event.pressed) {
  472. if ((get_oneshot_mods ()) && !has_oneshot_mods_timed_out ()) {
  473. clear_oneshot_mods ();
  474. } else {
  475. register_code (KC_ESC);
  476. }
  477. layer_off (HUN);
  478. } else {
  479. unregister_code (KC_ESC);
  480. }
  481. break;
  482. case A_MPN:
  483. if (record->event.pressed) {
  484. if (keyboard_report->mods & MOD_BIT(KC_LSFT) ||
  485. ((get_oneshot_mods() & MOD_BIT(KC_LSFT)) && !has_oneshot_mods_timed_out())) {
  486. int oneshot = ((get_oneshot_mods() & MOD_BIT(KC_LSFT)) && !has_oneshot_mods_timed_out());
  487. if (oneshot)
  488. clear_oneshot_mods ();
  489. unregister_code (KC_LSFT);
  490. register_code (KC_MPRV);
  491. unregister_code (KC_MPRV);
  492. if (!oneshot)
  493. register_code (KC_LSFT);
  494. } else {
  495. return MACRO (T(MNXT), END);
  496. }
  497. }
  498. break;
  499. /* Hungarian layer */
  500. case HU_AA:
  501. return ang_do_hun (record, KC_QUOT, KC_A);
  502. case HU_OO:
  503. return ang_do_hun (record, KC_QUOT, KC_O);
  504. case HU_EE:
  505. return ang_do_hun (record, KC_QUOT, KC_E);
  506. case HU_UU:
  507. return ang_do_hun (record, KC_QUOT, KC_U);
  508. case HU_II:
  509. return ang_do_hun (record, KC_QUOT, KC_I);
  510. case HU_OE:
  511. return ang_do_hun (record, KC_DQT, KC_O);
  512. case HU_UE:
  513. return ang_do_hun (record, KC_DQT, KC_U);
  514. case HU_OEE:
  515. return ang_do_hun (record, KC_EQL, KC_O);
  516. case HU_UEE:
  517. return ang_do_hun (record, KC_EQL, KC_U);
  518. /* Mouse movement */
  519. case A_MUL:
  520. if (record->event.pressed) {
  521. mousekey_on(KC_MS_UP);
  522. mousekey_on(KC_MS_LEFT);
  523. } else {
  524. mousekey_off(KC_MS_UP);
  525. mousekey_off(KC_MS_LEFT);
  526. }
  527. mousekey_send();
  528. break;
  529. case A_MUR:
  530. if (record->event.pressed) {
  531. mousekey_on(KC_MS_UP);
  532. mousekey_on(KC_MS_RIGHT);
  533. } else {
  534. mousekey_off(KC_MS_UP);
  535. mousekey_off(KC_MS_RIGHT);
  536. }
  537. mousekey_send();
  538. break;
  539. case A_MDL:
  540. if (record->event.pressed) {
  541. mousekey_on(KC_MS_DOWN);
  542. mousekey_on(KC_MS_LEFT);
  543. } else {
  544. mousekey_off(KC_MS_DOWN);
  545. mousekey_off(KC_MS_LEFT);
  546. }
  547. mousekey_send();
  548. break;
  549. case A_MDR:
  550. if (record->event.pressed) {
  551. mousekey_on(KC_MS_DOWN);
  552. mousekey_on(KC_MS_RIGHT);
  553. } else {
  554. mousekey_off(KC_MS_DOWN);
  555. mousekey_off(KC_MS_RIGHT);
  556. }
  557. mousekey_send();
  558. break;
  559. /* Plover base */
  560. case A_PLVR:
  561. toggle_steno(record->event.pressed);
  562. break;
  563. /* GUI & AppSel */
  564. case A_GUI:
  565. if (record->event.pressed) {
  566. register_code (KC_LGUI);
  567. if (record->tap.count && !record->tap.interrupted) {
  568. if (record->tap.count >= 2) {
  569. register_code (KC_W);
  570. layer_on (APPSEL);
  571. set_oneshot_layer (APPSEL, ONESHOT_START);
  572. }
  573. } else {
  574. record->tap.count = 0;
  575. }
  576. gui_timer = 0;
  577. } else {
  578. if (record->tap.count >= 2)
  579. {
  580. unregister_code (KC_W);
  581. clear_oneshot_layer_state (ONESHOT_PRESSED);
  582. }
  583. gui_timer = timer_read ();
  584. }
  585. break;
  586. case APP_SLK:
  587. return MACRODOWN(T(S), T(L), T(A), T(C), T(K), T(ENT), END);
  588. case APP_EMCS:
  589. return MACRODOWN(T(G), T(N), T(U), T(SPC), T(E), T(M), T(A), T(C), T(S), T(SPC), T(2), T(4), T(ENT), END);
  590. case APP_TERM:
  591. return MACRODOWN(T(T), T(E), T(R), T(M), T(ENT), END);
  592. case APP_CHRM:
  593. return MACRODOWN(T(C), T(H), T(R), T(O), T(M), T(ENT), END);
  594. case APP_MSIC:
  595. return MACRODOWN(T(R), T(H), T(Y), T(T), T(H), T(M), T(B), T(O), T(X), T(ENT), END);
  596. /* Function keys */
  597. case KF_1 ... KF_11:
  598. ang_handle_kf (record, id);
  599. break;
  600. }
  601. return MACRO_NONE;
  602. };
  603. uint8_t is_adore = 0;
  604. // Runs just one time when the keyboard initializes.
  605. void matrix_init_user(void) {
  606. uint8_t dl;
  607. ergodox_led_all_on();
  608. for (int i = LED_BRIGHTNESS_HI; i > LED_BRIGHTNESS_LO; i--) {
  609. ergodox_led_all_set (i);
  610. wait_ms (5);
  611. }
  612. wait_ms(1000);
  613. for (int i = LED_BRIGHTNESS_LO; i > 0; i--) {
  614. ergodox_led_all_set (i);
  615. wait_ms (10);
  616. }
  617. ergodox_led_all_off();
  618. if (!eeconfig_is_enabled())
  619. eeconfig_init();
  620. dl = eeconfig_read_default_layer ();
  621. if (dl == (1UL << ADORE)) {
  622. is_adore = 1;
  623. #if ADORE_AUTOLOG
  624. log_enable = true;
  625. #endif
  626. }
  627. };
  628. LEADER_EXTERNS();
  629. void ang_do_unicode (void) {
  630. register_code (KC_RCTL);
  631. register_code (KC_RSFT);
  632. register_code (KC_U);
  633. unregister_code (KC_U);
  634. unregister_code (KC_RSFT);
  635. unregister_code (KC_RCTL);
  636. wait_ms (100);
  637. }
  638. void ang_tap (uint16_t codes[]) {
  639. for (int i = 0; codes[i] != 0; i++) {
  640. register_code (codes[i]);
  641. unregister_code (codes[i]);
  642. wait_ms (50);
  643. }
  644. }
  645. #define TAP_ONCE(code) \
  646. register_code (code); \
  647. unregister_code (code)
  648. void ang_tap_dance_bp_finished (qk_tap_dance_state_t *state, void *user_data) {
  649. bool left, parens;
  650. if (state->count > 2) {
  651. state->count = 0;
  652. return;
  653. }
  654. if (state->keycode == TD(CT_LBP))
  655. left = true;
  656. else
  657. left = false;
  658. if (state->count == 1)
  659. parens = false;
  660. else
  661. parens = true;
  662. if (parens) {
  663. register_code (KC_RSFT);
  664. if (left) {
  665. TAP_ONCE(KC_9);
  666. } else {
  667. TAP_ONCE(KC_0);
  668. }
  669. unregister_code (KC_RSFT);
  670. } else {
  671. if (left) {
  672. TAP_ONCE (KC_LBRC);
  673. } else {
  674. TAP_ONCE (KC_RBRC);
  675. }
  676. }
  677. }
  678. void ang_tap_dance_cln_finished (qk_tap_dance_state_t *state, void *user_data) {
  679. if (state->count == 1) {
  680. register_code (KC_RSFT);
  681. register_code (KC_SCLN);
  682. } else if (state->count == 2) {
  683. register_code (KC_SCLN);
  684. }
  685. }
  686. void ang_tap_dance_cln_reset (qk_tap_dance_state_t *state, void *user_data) {
  687. if (state->count == 1) {
  688. unregister_code (KC_SCLN);
  689. unregister_code (KC_RSFT);
  690. } else if (state->count == 2) {
  691. unregister_code (KC_SCLN);
  692. }
  693. }
  694. void ang_tap_dance_mns_finished (qk_tap_dance_state_t *state, void *user_data) {
  695. if (state->count == 1) {
  696. register_code (KC_MINS);
  697. } else if (state->count == 2) {
  698. register_code (KC_RSFT);
  699. register_code (KC_MINS);
  700. }
  701. }
  702. void ang_tap_dance_mns_reset (qk_tap_dance_state_t *state, void *user_data) {
  703. if (state->count == 1) {
  704. unregister_code (KC_MINS);
  705. } else if (state->count == 2) {
  706. unregister_code (KC_RSFT);
  707. unregister_code (KC_MINS);
  708. }
  709. }
  710. typedef struct {
  711. bool layer_toggle;
  712. bool sticky;
  713. bool finished_once;
  714. } td_ta_state_t;
  715. void ang_tap_dance_ta_finished (qk_tap_dance_state_t *state, void *user_data) {
  716. td_ta_state_t *td_ta = (td_ta_state_t *) user_data;
  717. if (td_ta->finished_once) {
  718. return;
  719. }
  720. if (td_ta->sticky) {
  721. td_ta->sticky = false;
  722. td_ta->layer_toggle = false;
  723. layer_off (ARRW);
  724. return;
  725. }
  726. td_ta->finished_once = true;
  727. if (state->count == 1 && !state->pressed) {
  728. register_code (KC_TAB);
  729. td_ta->sticky = false;
  730. td_ta->layer_toggle = false;
  731. } else {
  732. td_ta->layer_toggle = true;
  733. layer_on (ARRW);
  734. td_ta->sticky = (state->count == 2);
  735. }
  736. }
  737. void ang_tap_dance_ta_reset (qk_tap_dance_state_t *state, void *user_data) {
  738. td_ta_state_t *td_ta = (td_ta_state_t *) user_data;
  739. if (!td_ta->layer_toggle)
  740. unregister_code (KC_TAB);
  741. if (!td_ta->sticky)
  742. layer_off (ARRW);
  743. td_ta->finished_once = false;
  744. }
  745. const qk_tap_dance_action_t tap_dance_actions[] = {
  746. [CT_CLN] = ACTION_TAP_DANCE_FN_ADVANCED (NULL, ang_tap_dance_cln_finished, ang_tap_dance_cln_reset)
  747. ,[CT_MNS] = ACTION_TAP_DANCE_FN_ADVANCED (NULL, ang_tap_dance_mns_finished, ang_tap_dance_mns_reset)
  748. ,[CT_TA] = {
  749. .fn = { NULL, ang_tap_dance_ta_finished, ang_tap_dance_ta_reset },
  750. .user_data = (void *)&((td_ta_state_t) { false, false, false })
  751. }
  752. ,[CT_LBP] = ACTION_TAP_DANCE_FN (ang_tap_dance_bp_finished)
  753. ,[CT_RBP] = ACTION_TAP_DANCE_FN (ang_tap_dance_bp_finished)
  754. };
  755. static uint16_t uni[32];
  756. static uint8_t unicnt;
  757. static bool unimagic = false;
  758. // Runs constantly in the background, in a loop.
  759. void matrix_scan_user(void) {
  760. uint8_t layer = biton32(layer_state);
  761. if (gui_timer && timer_elapsed (gui_timer) > TAPPING_TERM)
  762. unregister_code (KC_LGUI);
  763. if (layer == HUN) {
  764. ergodox_right_led_2_on();
  765. ergodox_right_led_3_on();
  766. } else if (layer == NMDIA) {
  767. ergodox_right_led_1_on();
  768. ergodox_right_led_2_on();
  769. } else if (layer == PLVR) {
  770. ergodox_right_led_1_on ();
  771. ergodox_right_led_2_on ();
  772. ergodox_right_led_3_on ();
  773. } else if (layer == ADORE) {
  774. ergodox_right_led_1_on ();
  775. ergodox_right_led_2_on ();
  776. ergodox_right_led_3_on ();
  777. ergodox_right_led_2_set (LED_BRIGHTNESS_HI);
  778. }
  779. if (keyboard_report->mods & MOD_BIT(KC_LSFT) ||
  780. ((get_oneshot_mods() & MOD_BIT(KC_LSFT)) && !has_oneshot_mods_timed_out())) {
  781. ergodox_right_led_1_set (LED_BRIGHTNESS_HI);
  782. ergodox_right_led_1_on ();
  783. } else {
  784. ergodox_right_led_1_set (LED_BRIGHTNESS_LO);
  785. if (layer != NMDIA && layer != PLVR && layer != ADORE)
  786. ergodox_right_led_1_off ();
  787. }
  788. if (keyboard_report->mods & MOD_BIT(KC_LALT) ||
  789. ((get_oneshot_mods() & MOD_BIT(KC_LALT)) && !has_oneshot_mods_timed_out())) {
  790. ergodox_right_led_2_set (LED_BRIGHTNESS_HI);
  791. ergodox_right_led_2_on ();
  792. } else {
  793. ergodox_right_led_2_set (LED_BRIGHTNESS_LO);
  794. if (layer != HUN && layer != NMDIA && layer != PLVR && layer != ADORE)
  795. ergodox_right_led_2_off ();
  796. }
  797. if (keyboard_report->mods & MOD_BIT(KC_LCTRL) ||
  798. ((get_oneshot_mods() & MOD_BIT(KC_LCTRL)) && !has_oneshot_mods_timed_out())) {
  799. ergodox_right_led_3_set (LED_BRIGHTNESS_HI);
  800. ergodox_right_led_3_on ();
  801. } else {
  802. ergodox_right_led_3_set (LED_BRIGHTNESS_LO);
  803. if (layer != HUN && layer != PLVR && layer != ADORE)
  804. ergodox_right_led_3_off ();
  805. }
  806. LEADER_DICTIONARY() {
  807. leading = false;
  808. leader_end ();
  809. #if KEYLOGGER_ENABLE
  810. SEQ_ONE_KEY (KC_D) {
  811. ergodox_led_all_on();
  812. wait_ms(100);
  813. ergodox_led_all_off();
  814. log_enable = !log_enable;
  815. }
  816. #endif
  817. SEQ_ONE_KEY (KC_T) {
  818. time_travel = !time_travel;
  819. }
  820. SEQ_ONE_KEY (KC_U) {
  821. ang_do_unicode ();
  822. }
  823. SEQ_TWO_KEYS (KC_LEAD, KC_U) {
  824. unicnt = 0;
  825. unimagic = true;
  826. register_code(KC_RSFT);
  827. TAP_ONCE(KC_U);
  828. unregister_code(KC_RSFT);
  829. }
  830. SEQ_ONE_KEY (KC_V) {
  831. SEND_STRING (QMK_KEYBOARD "/" QMK_KEYMAP " @ (" QMK_VERSION "/" KEYMAP_VERSION ")");
  832. }
  833. SEQ_ONE_KEY (KC_L) {
  834. /* λ */
  835. ang_do_unicode ();
  836. uint16_t codes[] = {KC_0, KC_3, KC_B, KC_B, KC_ENT, 0};
  837. ang_tap (codes);
  838. }
  839. SEQ_ONE_KEY (KC_Y) {
  840. uint16_t codes[] = {KC_BSLS, KC_O, KC_SLSH, 0};
  841. ang_tap (codes);
  842. }
  843. SEQ_ONE_KEY (KC_S) {
  844. ang_do_unicode (); TAP_ONCE (KC_A); TAP_ONCE (KC_F); TAP_ONCE (KC_SPC);
  845. TAP_ONCE (KC_BSLS);
  846. register_code (KC_RSFT); TAP_ONCE (KC_MINS); TAP_ONCE (KC_9); unregister_code (KC_RSFT);
  847. ang_do_unicode (); TAP_ONCE (KC_3); TAP_ONCE (KC_0); TAP_ONCE (KC_C); TAP_ONCE (KC_4); TAP_ONCE (KC_SPC);
  848. register_code (KC_RSFT); TAP_ONCE (KC_0); TAP_ONCE (KC_MINS); unregister_code (KC_RSFT);
  849. TAP_ONCE (KC_SLSH);
  850. ang_do_unicode (); TAP_ONCE (KC_A); TAP_ONCE (KC_F); TAP_ONCE (KC_SPC);
  851. }
  852. SEQ_TWO_KEYS (KC_W, KC_M) {
  853. register_code (KC_LALT);
  854. register_code (KC_F2);
  855. unregister_code (KC_F2);
  856. unregister_code (KC_LALT);
  857. wait_ms (1000);
  858. uint16_t codes[] = {KC_M, KC_A, KC_X, KC_MINS, KC_F, KC_O, KC_C, KC_U, KC_S, KC_E, KC_D, KC_ENT, 0};
  859. ang_tap (codes);
  860. register_code (KC_LGUI);
  861. register_code (KC_UP);
  862. unregister_code (KC_UP);
  863. unregister_code (KC_LGUI);
  864. }
  865. SEQ_ONE_KEY (KC_A) {
  866. if (is_adore == 0) {
  867. default_layer_and (0);
  868. default_layer_or ((1UL << ADORE));
  869. eeconfig_update_default_layer ((1UL << ADORE));
  870. is_adore = 1;
  871. ergodox_led_all_off ();
  872. ergodox_right_led_3_on ();
  873. wait_ms (100);
  874. ergodox_right_led_2_on ();
  875. wait_ms (100);
  876. ergodox_right_led_3_off ();
  877. ergodox_right_led_1_on ();
  878. wait_ms (100);
  879. ergodox_right_led_2_off ();
  880. wait_ms (100);
  881. ergodox_right_led_1_off ();
  882. #if ADORE_AUTOLOG
  883. log_enable = true;
  884. #endif
  885. } else {
  886. #if ADORE_AUTOLOG
  887. log_enable = false;
  888. #endif
  889. is_adore = 0;
  890. default_layer_and (0);
  891. default_layer_or (1UL << BASE);
  892. eeconfig_update_default_layer ((1UL << BASE));
  893. ergodox_led_all_off ();
  894. ergodox_right_led_1_on ();
  895. wait_ms (100);
  896. ergodox_right_led_2_on ();
  897. wait_ms (100);
  898. ergodox_right_led_1_off ();
  899. ergodox_right_led_3_on ();
  900. wait_ms (100);
  901. ergodox_right_led_2_off ();
  902. wait_ms (100);
  903. ergodox_right_led_3_off ();
  904. }
  905. }
  906. }
  907. }
  908. static uint16_t last4[4];
  909. bool is_uni_seq(char *seq) {
  910. uint8_t i;
  911. for (i = 0; seq[i]; i++) {
  912. uint16_t code;
  913. if (('1' <= seq[i]) && (seq[i] <= '9'))
  914. code = seq[i] - '1' + KC_1;
  915. else if (seq[i] == '0')
  916. code = KC_0;
  917. else
  918. code = seq[i] - 'a' + KC_A;
  919. if (i > unicnt)
  920. return false;
  921. if (uni[i] != code)
  922. return false;
  923. }
  924. if (uni[i] == KC_ENT || uni[i] == KC_SPC)
  925. return true;
  926. return false;
  927. }
  928. uint16_t hex_to_keycode(uint8_t hex)
  929. {
  930. if (hex == 0x0) {
  931. return KC_0;
  932. } else if (hex < 0xA) {
  933. return KC_1 + (hex - 0x1);
  934. } else {
  935. return KC_A + (hex - 0xA);
  936. }
  937. }
  938. void register_hex(uint16_t hex) {
  939. bool leading_zeros = true;
  940. for(int i = 3; i >= 0; i--) {
  941. uint8_t digit = ((hex >> (i*4)) & 0xF);
  942. if (digit != 0)
  943. leading_zeros = false;
  944. else if (leading_zeros)
  945. continue;
  946. register_code(hex_to_keycode(digit));
  947. unregister_code(hex_to_keycode(digit));
  948. wait_ms(10);
  949. }
  950. }
  951. typedef struct {
  952. char *symbol;
  953. uint16_t codes[4];
  954. } qk_ucis_symbol_t;
  955. static qk_ucis_symbol_t ucis_symbol_table[] = {
  956. {"poop", {0x1, 0xf4a9, 0}},
  957. {"rofl", {0x1, 0xf923, 0}},
  958. {"kiss", {0x1, 0xf619, 0}},
  959. {"snowman", {0x2603, 0}},
  960. {NULL, {}}
  961. };
  962. bool process_record_ucis (uint16_t keycode, keyrecord_t *record) {
  963. uint8_t i;
  964. if (!unimagic)
  965. return true;
  966. if (!record->event.pressed)
  967. return true;
  968. uni[unicnt] = keycode;
  969. unicnt++;
  970. if (keycode == KC_BSPC) {
  971. if (unicnt >= 2) {
  972. unicnt-= 2;
  973. return true;
  974. } else {
  975. unicnt--;
  976. return false;
  977. }
  978. }
  979. if (keycode == KC_ENT || keycode == KC_SPC) {
  980. bool symbol_found = false;
  981. for (i = unicnt; i > 0; i--) {
  982. register_code (KC_BSPC);
  983. unregister_code (KC_BSPC);
  984. wait_ms(10);
  985. }
  986. ang_do_unicode();
  987. wait_ms(10);
  988. for (i = 0; ucis_symbol_table[i].symbol; i++) {
  989. if (is_uni_seq (ucis_symbol_table[i].symbol)) {
  990. symbol_found = true;
  991. for (uint8_t j = 0; ucis_symbol_table[i].codes[j]; j++) {
  992. register_hex(ucis_symbol_table[i].codes[j]);
  993. }
  994. break;
  995. }
  996. }
  997. if (!symbol_found) {
  998. for (i = 0; i < unicnt - 1; i++) {
  999. uint8_t code;
  1000. if (uni[i] > KF_1)
  1001. code = uni[i] - KF_1 + KC_1;
  1002. else
  1003. code = uni[i];
  1004. TAP_ONCE(code);
  1005. wait_ms (10);
  1006. }
  1007. }
  1008. unimagic = false;
  1009. return true;
  1010. }
  1011. return true;
  1012. }
  1013. bool process_record_user (uint16_t keycode, keyrecord_t *record) {
  1014. #if KEYLOGGER_ENABLE
  1015. if (log_enable) {
  1016. xprintf ("KL: col=%d, row=%d\n", record->event.key.col,
  1017. record->event.key.row);
  1018. }
  1019. #endif
  1020. if (!process_record_ucis (keycode, record))
  1021. return false;
  1022. if (time_travel && !record->event.pressed) {
  1023. uint8_t p;
  1024. // shift cache one to the left
  1025. for (p = 0; p < 3; p++) {
  1026. last4[p] = last4[p + 1];
  1027. }
  1028. last4[3] = keycode;
  1029. if (last4[0] == KC_D && last4[1] == KC_A && last4[2] == KC_T && last4[3] == KC_E) {
  1030. uint16_t codes[] = {KC_E, KC_SPC, KC_MINS, KC_D, KC_SPC, KC_QUOT, 0};
  1031. ang_tap (codes);
  1032. register_code (KC_RSFT);
  1033. register_code (KC_EQL);
  1034. unregister_code (KC_EQL);
  1035. unregister_code (KC_RSFT);
  1036. uint16_t codes2[] = {KC_4, KC_SPC, KC_D, KC_A, KC_Y, KC_S, KC_QUOT, 0};
  1037. ang_tap (codes2);
  1038. return false;
  1039. }
  1040. }
  1041. return true;
  1042. }