keymap.c 40 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878879880881882883884885886887888889890891892893894895896897898899900901902903904905906907908909910911912913914915916917918919920921922923924925926927928929930931932933934935936937938939940941942943944945946947948949950951952953954955956957958959960961962963964965966967968969970971972973974975976977978979980981982983984985986987988989990991992993994995996997998999100010011002100310041005100610071008100910101011101210131014101510161017101810191020102110221023102410251026102710281029103010311032103310341035
  1. /*
  2. * algernon's ErgoDox EZ layout, please see the readme.md file!
  3. */
  4. #include <stdarg.h>
  5. #include "ergodox.h"
  6. #include "led.h"
  7. #include "debug.h"
  8. #include "action_layer.h"
  9. #include "action_util.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_MPN,
  32. // Application select keys
  33. APP_SLK, // Slack
  34. APP_EMCS, // Emacs
  35. APP_TERM, // Terminal
  36. APP_CHRM, // Chrome
  37. APP_MSIC, // Music
  38. // Hungarian layer keys
  39. HU_AA, // Á
  40. HU_OO, // Ó
  41. HU_EE, // É
  42. HU_UU, // Ú
  43. HU_II, // Í
  44. HU_OE, // Ö
  45. HU_UE, // Ü
  46. HU_OEE, // Ő
  47. HU_UEE, // Ű
  48. // number/symbol keys
  49. A_1, // 1
  50. A_2, // 2
  51. A_3, // ...
  52. A_4,
  53. A_5,
  54. A_6,
  55. A_7,
  56. A_8,
  57. A_9,
  58. A_0,
  59. };
  60. /* Fn keys */
  61. enum {
  62. F_BSE = 0,
  63. F_HUN,
  64. F_GUI,
  65. F_SFT,
  66. F_ALT,
  67. F_CTRL
  68. };
  69. /* Custom keycodes */
  70. enum {
  71. CT_CLN = 0,
  72. CT_TA,
  73. CT_LBP,
  74. CT_RBP,
  75. CT_TMUX,
  76. CT_TPS,
  77. };
  78. /* States & timers */
  79. uint16_t gui_timer = 0;
  80. uint16_t kf_timers[12];
  81. #if KEYLOGGER_ENABLE
  82. # ifdef AUTOLOG_ENABLE
  83. bool log_enable = true;
  84. # else
  85. bool log_enable = false;
  86. # endif
  87. #endif
  88. bool time_travel = false;
  89. static uint8_t is_adore = 0;
  90. /* The Keymap */
  91. const uint16_t PROGMEM keymaps[][MATRIX_ROWS][MATRIX_COLS] = {
  92. /* Keymap 0: Base Layer
  93. *
  94. * ,-----------------------------------------------------. ,-----------------------------------------------------.
  95. * | Next/Prev | 9 | 7 @ | 5 * | 3 ^ | 1 $ | F11 | | F12 | 0 % | 2 ! | 4 # | 6 & | 8 | Plover |
  96. * |-----------+------+------+------+------+-------------| |------+------+------+------+------+------+-----------|
  97. * | ~ | ' | , | . | P | Y | ( | | ) | F | G | C | R | L | \ |
  98. * |-----------+------+------+------+------+------| [ | | ] |------+------+------+------+------+-----------|
  99. * | Tab/ARROW | A | O | E | U | I |------| |------| D | H | T | N | S | = / Arrow |
  100. * |-----------+------+------+------+------+------| tmux | | tmux |------+------+------+------+------+-----------|
  101. * | Play/Pause| / | Q | J | K | X | | | Pane | B | M | W | V | Z | Stop |
  102. * `-----------+------+------+------+------+-------------' `-------------+------+------+------+------+-----------'
  103. * | | | | | : | | - | | | | |
  104. * `-----------------------------------' `-----------------------------------'
  105. * ,-------------. ,-------------.
  106. * | LAlt | GUI | | MDIA | Del |
  107. * ,------|------|------| |------+------+------.
  108. * | | | Ctrl | | LEAD | | |
  109. * |Backsp|LShift|------| |------| Enter| Space|
  110. * | | | ESC | | HUN | | |
  111. * `--------------------' `--------------------'
  112. */
  113. [BASE] = KEYMAP(
  114. // left hand
  115. M(A_MPN) ,M(A_9) ,M(A_7) ,M(A_5) ,M(A_3) ,M(A_1) ,KC_F11
  116. ,KC_GRV ,KC_QUOT ,KC_COMM ,KC_DOT ,KC_P ,KC_Y ,TD(CT_LBP)
  117. ,TD(CT_TA) ,KC_A ,KC_O ,KC_E ,KC_U ,KC_I
  118. ,KC_MPLY ,KC_SLSH ,KC_Q ,KC_J ,KC_K ,KC_X ,TD(CT_TMUX)
  119. ,KC_NO ,KC_NO ,KC_NO ,KC_NO ,TD(CT_CLN)
  120. ,F(F_ALT),F(F_GUI)
  121. ,F(F_CTRL)
  122. ,KC_BSPC,F(F_SFT),KC_ESC
  123. // right hand
  124. ,KC_F12 ,M(A_0) ,M(A_2) ,M(A_4) ,M(A_6) ,M(A_8) ,M(A_PLVR)
  125. ,TD(CT_RBP),KC_F ,KC_G ,KC_C ,KC_R ,KC_L ,KC_BSLS
  126. ,KC_D ,KC_H ,KC_T ,KC_N ,KC_S ,KC_EQL
  127. ,TD(CT_TPS),KC_B ,KC_M ,KC_W ,KC_V ,KC_Z ,KC_MSTP
  128. ,KC_MINS ,KC_NO ,KC_NO ,KC_NO ,KC_NO
  129. ,OSL(NMDIA),KC_DEL
  130. ,KC_LEAD
  131. ,F(F_HUN) ,KC_ENT ,KC_SPC
  132. ),
  133. /* Keymap 1: Adore layer
  134. *
  135. * ,-----------------------------------------------------. ,-----------------------------------------------------.
  136. * | Play/Pause| 9 | 7 @ | 5 * | 3 ^ | 1 $ | F11 | | F12 | 0 % | 2 ! | 4 # | 6 & | 8 | Plover |
  137. * |-----------+------+------+------+------+-------------| |------+------+------+------+------+------+-----------|
  138. * | `~ | X | W | G | L | M | ( | | ) | F | H | C | P | Y | \ |
  139. * |-----------+------+------+------+------+------| [ | | ] |------+------+------+------+------+-----------|
  140. * | Tab/Arrow | A | O | E | I | U |------| |------| D | R | T | N | S | = |
  141. * |-----------+------+------+------+------+------| tmux | | tmux |------+------+------+------+------+-----------|
  142. * | | Z | Q | ' | , | . | | | pane | B | K | V | J | / | |
  143. * `-----------+------+------+------+------+-------------' `-------------+------+------+------+------+-----------'
  144. * | | | | | : | | - | | | | |
  145. * `-----------------------------------' `-----------------------------------'
  146. * ,-------------. ,-------------.
  147. * | LAlt | GUI | | MDIA | Del |
  148. * ,------|------|------| |------+------+------.
  149. * | | | Ctrl | | HUN | | |
  150. * |Backsp|LShift|------| |------| Enter| Space|
  151. * | | | ESC | | LEAD | | |
  152. * `--------------------' `--------------------'
  153. */
  154. [ADORE] = KEYMAP(
  155. // left hand
  156. KC_MPLY ,M(A_9) ,M(A_7) ,M(A_5) ,M(A_3) ,M(A_1) ,KC_F11
  157. ,KC_GRV ,KC_X ,KC_W ,KC_G ,KC_L ,KC_M ,TD(CT_LBP)
  158. ,TD(CT_TA) ,KC_A ,KC_O ,KC_E ,KC_I ,KC_U
  159. ,KC_NO ,KC_Z ,KC_Q ,KC_QUOT ,KC_COMM ,KC_DOT ,TD(CT_TMUX)
  160. ,KC_NO ,KC_NO ,KC_NO ,KC_NO ,TD(CT_CLN)
  161. ,F(F_ALT),F(F_GUI)
  162. ,F(F_CTRL)
  163. ,KC_BSPC,F(F_SFT),KC_ESC
  164. // right hand
  165. ,KC_F12 ,M(A_0) ,M(A_2) ,M(A_4) ,M(A_6) ,M(A_8) ,M(A_PLVR)
  166. ,TD(CT_RBP),KC_F ,KC_H ,KC_C ,KC_P ,KC_Y ,KC_BSLS
  167. ,KC_D ,KC_R ,KC_T ,KC_N ,KC_S ,KC_EQL
  168. ,TD(CT_TPS),KC_B ,KC_K ,KC_V ,KC_J ,KC_SLSH ,KC_NO
  169. ,KC_MINS ,KC_NO ,KC_NO ,KC_NO ,KC_NO
  170. ,OSL(NMDIA),KC_DEL
  171. ,F(F_HUN)
  172. ,KC_LEAD ,KC_ENT ,KC_SPC
  173. ),
  174. /* Keymap 2: Arrow layer
  175. *
  176. * ,-----------------------------------------------------. ,-----------------------------------------------------.
  177. * | | | | | | | | | | | | | | | |
  178. * |-----------+------+------+------+------+-------------| |------+------+------+------+------+------+-----------|
  179. * | | | | | | | | | | | Home | Up | End | | |
  180. * |-----------+------+------+------+------+------| | | |------+------+------+------+------+-----------|
  181. * | | | | | | |------| |------| | Left | Down | Rght | | |
  182. * |-----------+------+------+------+------+------| | | |------+------+------+------+------+-----------|
  183. * | | | | | | | | | | | | | | | |
  184. * `-----------+------+------+------+------+-------------' `-------------+------+------+------+------+-----------'
  185. * | | | | | | | | | | | |
  186. * `----------------------------------' `----------------------------------'
  187. * ,-------------. ,-------------.
  188. * | | | | | |
  189. * ,------|------|------| |------+------+------.
  190. * | | | | | | | |
  191. * | Enter| |------| |------| PgUp | PgDn |
  192. * | | | | | | | |
  193. * `--------------------' `--------------------'
  194. */
  195. [ARRW] = KEYMAP(
  196. // left hand
  197. KC_TRNS ,KC_TRNS ,KC_TRNS ,KC_TRNS ,KC_TRNS ,KC_TRNS ,KC_TRNS
  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
  200. ,KC_TRNS ,KC_TRNS ,KC_TRNS ,KC_TRNS ,KC_TRNS ,KC_TRNS ,KC_TRNS
  201. ,KC_TRNS ,KC_TRNS ,KC_TRNS ,KC_TRNS ,KC_TRNS
  202. ,KC_TRNS ,KC_TRNS
  203. ,KC_TRNS
  204. ,KC_ENT ,KC_TRNS ,KC_TRNS
  205. // right hand
  206. ,KC_TRNS ,KC_TRNS ,KC_TRNS ,KC_TRNS ,KC_TRNS ,KC_TRNS ,KC_TRNS
  207. ,KC_TRNS ,KC_TRNS ,KC_HOME ,KC_UP ,KC_END ,KC_TRNS ,KC_TRNS
  208. ,KC_TRNS ,KC_LEFT ,KC_DOWN ,KC_RGHT ,KC_TRNS ,KC_TRNS
  209. ,KC_TRNS ,KC_TRNS ,KC_TRNS ,KC_TRNS ,KC_TRNS ,KC_TRNS ,KC_TRNS
  210. ,KC_TRNS ,KC_TRNS ,KC_TRNS ,KC_TRNS ,KC_TRNS
  211. ,KC_TRNS ,KC_TRNS
  212. ,KC_TRNS
  213. ,KC_TRNS ,KC_PGUP ,KC_PGDN
  214. ),
  215. /* Keymap 3: Application select layer
  216. *
  217. * ,-----------------------------------------------------. ,-----------------------------------------------------.
  218. * | |Music |Slack |Emacs |Term |Chrome| | | | | | | | | |
  219. * |-----------+------+------+------+------+-------------| |------+------+------+------+------+------+-----------|
  220. * | | | | | | | | | | | | | | | |
  221. * |-----------+------+------+------+------+------| | | |------+------+------+------+------+-----------|
  222. * | | | | | | |------| |------| | | | | | |
  223. * |-----------+------+------+------+------+------| | | |------+------+------+------+------+-----------|
  224. * | | | | | | | | | | | | | | | |
  225. * `-----------+------+------+------+------+-------------' `-------------+------+------+------+------+-----------'
  226. * | | | | | | | | | | | |
  227. * `----------------------------------' `----------------------------------'
  228. * ,-------------. ,-------------.
  229. * | | | | | |
  230. * ,------|------|------| |------+------+------.
  231. * | | | | | | | |
  232. * | | |------| |------| | |
  233. * | | | | | | | |
  234. * `--------------------' `--------------------'
  235. */
  236. [APPSEL] = KEYMAP(
  237. // left hand
  238. KC_TRNS ,M(APP_MSIC),M(APP_SLK),M(APP_EMCS),M(APP_TERM),M(APP_CHRM),KC_TRNS
  239. ,KC_TRNS ,KC_TRNS ,KC_TRNS ,KC_TRNS ,KC_TRNS ,KC_TRNS ,KC_TRNS
  240. ,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 ,KC_TRNS
  242. ,KC_TRNS ,KC_TRNS ,KC_TRNS ,KC_TRNS ,KC_TRNS
  243. ,KC_TRNS ,KC_TRNS
  244. ,KC_TRNS
  245. ,KC_TRNS ,KC_TRNS ,KC_TRNS
  246. // right hand
  247. ,KC_TRNS ,KC_NO ,KC_NO ,KC_NO ,KC_NO ,KC_NO ,KC_TRNS
  248. ,KC_TRNS ,KC_TRNS ,KC_TRNS ,KC_TRNS ,KC_TRNS ,KC_TRNS ,KC_TRNS
  249. ,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 ,KC_TRNS
  251. ,KC_TRNS ,KC_TRNS ,KC_TRNS ,KC_TRNS ,KC_TRNS
  252. ,KC_TRNS ,KC_TRNS
  253. ,KC_TRNS
  254. ,KC_TRNS ,KC_TRNS ,KC_TRNS
  255. ),
  256. /* Keymap 4: Hungarian Layer
  257. *
  258. * ,-----------------------------------------------------. ,-----------------------------------------------------.
  259. * | | | | | | | | | | | | | | | |
  260. * |-----------+------+------+------+------+-------------| |------+------+------+------+------+------+-----------|
  261. * | | | Ő | | Ű | | | | | | | | | | |
  262. * |-----------+------+------+------+------+------| | | |------+------+------+------+------+-----------|
  263. * | | Á | Ó | É | Ú | Í |------| |------| | | | | | |
  264. * |-----------+------+------+------+------+------| | | |------+------+------+------+------+-----------|
  265. * | | | Ö | | Ü | | | | | | | | | | |
  266. * `-----------+------+------+------+------+-------------' `-------------+------+------+------+------+-----------'
  267. * | | | | | | | | | | | |
  268. * `----------------------------------' `----------------------------------'
  269. * ,-------------. ,-------------.
  270. * | | | | | |
  271. * ,------|------|------| |------+------+------.
  272. * | | | | | | | |
  273. * | | |------| |------| | |
  274. * | | | | | BASE | | |
  275. * `--------------------' `--------------------'
  276. */
  277. [HUN] = KEYMAP(
  278. // left hand
  279. KC_NO ,KC_NO ,KC_NO ,KC_NO ,KC_NO ,KC_NO ,KC_NO
  280. ,KC_NO ,KC_NO ,M(HU_OEE),KC_NO ,M(HU_UEE),KC_NO ,KC_NO
  281. ,KC_NO ,M(HU_AA),M(HU_OO) ,M(HU_EE),M(HU_UU) ,M(HU_II)
  282. ,KC_NO ,KC_NO ,M(HU_OE) ,KC_NO ,M(HU_UE) ,KC_NO ,KC_NO
  283. ,KC_NO ,KC_NO ,KC_NO ,KC_NO ,KC_NO
  284. ,KC_NO ,KC_NO
  285. ,KC_NO
  286. ,KC_NO ,KC_TRNS ,KC_TRNS
  287. // right hand
  288. ,KC_TRNS ,KC_NO ,KC_NO ,KC_NO ,KC_NO ,KC_NO ,KC_NO
  289. ,KC_NO ,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
  291. ,KC_NO ,KC_NO ,KC_NO ,KC_NO ,KC_NO ,KC_NO ,KC_NO
  292. ,KC_NO ,KC_NO ,KC_NO ,KC_NO ,KC_NO
  293. ,KC_NO ,KC_NO
  294. ,KC_NO
  295. ,F(F_BSE),KC_TRNS ,KC_TRNS
  296. ),
  297. /* Keymap 5: Navigation & Media layer
  298. *
  299. * ,-----------------------------------------------------. ,-----------------------------------------------------.
  300. * | | F9 | F7 | F5 | F3 | F1 | | |ScrLCK| F10 | F2 | F4 | F6 | F8 | |
  301. * |-----------+------+------+------+------+-------------| |------+------+------+------+------+------+-----------|
  302. * | | | | | | | | | | | | | | | |
  303. * |-----------+------+------+------+------+------| | | |------+------+------+------+------+-----------|
  304. * | | | | | | |------| |------| | | | | | |
  305. * |-----------+------+------+------+------+------| | | |------+------+------+------+------+-----------|
  306. * | | | | | | | | | | | | | | | |
  307. * `-----------+------+------+------+------+-------------' `-------------+------+------+------+------+-----------'
  308. * | | | | | | | | | | | |
  309. * `----------------------------------' `----------------------------------'
  310. * ,-------------. ,-------------.
  311. * | Mute | VlUp | | BASE | |
  312. * ,------|------|------| |------+------+------.
  313. * | | | VlDn | | | | |
  314. * | | |------| |------| | |
  315. * | | | | | | | |
  316. * `--------------------' `--------------------'
  317. */
  318. [NMDIA] = KEYMAP(
  319. // left hand
  320. KC_NO ,KC_F9 ,KC_F7 ,KC_F5 ,KC_F3 ,KC_F1 ,KC_NO
  321. ,KC_NO ,KC_NO ,KC_NO ,KC_NO ,KC_NO ,KC_NO ,KC_NO
  322. ,KC_NO ,KC_NO ,KC_NO ,KC_NO ,KC_NO ,KC_NO
  323. ,KC_NO ,KC_NO ,KC_NO ,KC_NO ,KC_NO ,KC_NO ,KC_NO
  324. ,KC_NO ,KC_NO ,KC_NO ,KC_NO ,KC_NO
  325. ,KC_MUTE ,KC_VOLU
  326. ,KC_VOLD
  327. ,KC_NO ,KC_NO ,KC_TRNS
  328. // right hand
  329. ,LGUI(KC_L),KC_F10 ,KC_F2 ,KC_F4 ,KC_F6 ,KC_F8 ,KC_NO
  330. ,KC_NO ,KC_NO ,KC_NO ,KC_NO ,KC_NO ,KC_NO ,KC_NO
  331. ,KC_NO ,KC_NO ,KC_NO ,KC_NO ,KC_NO ,KC_NO
  332. ,KC_NO ,KC_NO ,KC_NO ,KC_NO ,KC_NO ,KC_NO ,KC_NO
  333. ,KC_NO ,KC_NO ,KC_NO ,KC_NO ,KC_NO
  334. ,KC_TRNS ,KC_NO
  335. ,KC_NO
  336. ,KC_NO ,KC_NO ,KC_NO
  337. ),
  338. /* Keymap 6: Steno for Plover
  339. *
  340. * ,--------------------------------------------------. ,--------------------------------------------------.
  341. * | | | | | | | BASE | | | | | | | | |
  342. * |--------+------+------+------+------+-------------| |------+------+------+------+------+------+--------|
  343. * | | # | # | # | # | # | # | | # | # | # | # | # | # | # |
  344. * |--------+------+------+------+------+------| | | |------+------+------+------+------+--------|
  345. * | | | T | P | H | |------| |------| | F | P | L | T | D |
  346. * |--------+ S +------+------+------+ * | * | | * | * +------+------+------+------+--------|
  347. * | | | K | W | R | | | | | | R | B | G | S | Z |
  348. * `--------+------+------+------+------+-------------' `-------------+------+------+------+------+--------'
  349. * | | | | | | | | | | | |
  350. * `----------------------------------' `----------------------------------'
  351. * ,-------------. ,-------------.
  352. * | | | | | |
  353. * ,------|------|------| |------+------+------.
  354. * | | | | | | | |
  355. * | A | O |------| |------| E | U |
  356. * | | | | | | | |
  357. * `--------------------' `--------------------'
  358. */
  359. [PLVR] = KEYMAP(
  360. // left hand
  361. KC_NO, KC_NO, KC_NO, KC_NO, KC_NO, KC_NO, M(A_PLVR),
  362. KC_NO, PV_NUM, PV_NUM, PV_NUM, PV_NUM, PV_NUM, PV_NUM,
  363. KC_NO, PV_LS, PV_LT, PV_LP, PV_LH, PV_STAR,
  364. KC_NO, PV_LS, PV_LK, PV_LW, PV_LR, PV_STAR, PV_STAR,
  365. KC_NO, KC_NO, KC_NO, KC_NO, KC_NO,
  366. KC_NO, KC_NO,
  367. KC_NO,
  368. PV_A, PV_O, KC_NO,
  369. // right hand
  370. KC_NO, KC_NO, KC_NO, KC_NO, KC_NO, KC_NO, KC_NO,
  371. PV_NUM, PV_NUM, PV_NUM, PV_NUM, PV_NUM, PV_NUM, PV_NUM,
  372. PV_STAR, PV_RF, PV_RP, PV_RL, PV_RT, PV_RD,
  373. PV_STAR, PV_STAR, PV_RR, PV_RB, PV_RG, PV_RS, PV_RZ,
  374. KC_NO, KC_NO, KC_NO, KC_NO, KC_NO,
  375. KC_NO, KC_NO,
  376. KC_NO,
  377. KC_NO,PV_E, PV_U
  378. ),
  379. };
  380. const uint16_t PROGMEM fn_actions[] = {
  381. [F_BSE] = ACTION_LAYER_CLEAR(ON_PRESS)
  382. ,[F_HUN] = ACTION_LAYER_INVERT(HUN, ON_PRESS)
  383. ,[F_GUI] = ACTION_MACRO_TAP(A_GUI)
  384. ,[F_SFT] = ACTION_MODS_ONESHOT (MOD_LSFT)
  385. ,[F_ALT] = ACTION_MODS_ONESHOT (MOD_LALT)
  386. ,[F_CTRL] = ACTION_MODS_ONESHOT (MOD_LCTL)
  387. };
  388. static void toggle_steno(int pressed)
  389. {
  390. uint8_t layer = biton32(layer_state);
  391. if (pressed) {
  392. if (layer != PLVR) layer_on(PLVR); else layer_off(PLVR);
  393. register_code(PV_LP);
  394. register_code(PV_LH);
  395. register_code(PV_LR);
  396. register_code(PV_O);
  397. register_code(PV_RL);
  398. register_code(PV_RG);
  399. } else {
  400. unregister_code(PV_LP);
  401. unregister_code(PV_LH);
  402. unregister_code(PV_LR);
  403. unregister_code(PV_O);
  404. unregister_code(PV_RL);
  405. unregister_code(PV_RG);
  406. }
  407. }
  408. static macro_t *ang_do_hun (keyrecord_t *record, uint16_t accent, uint16_t hun_char)
  409. {
  410. uint8_t need_shift = 0;
  411. uint8_t hold_shift = 0;
  412. if (!record->event.pressed)
  413. return MACRO_NONE;
  414. layer_off (HUN);
  415. if (keyboard_report->mods & MOD_BIT (KC_LSFT)) {
  416. hold_shift = 1;
  417. need_shift = 1;
  418. unregister_code (KC_LSFT);
  419. }
  420. if ((get_oneshot_mods () & MOD_BIT(KC_LSFT)) && !has_oneshot_mods_timed_out ()) {
  421. need_shift = 1;
  422. hold_shift = 0;
  423. unregister_code (KC_LSFT);
  424. }
  425. clear_oneshot_mods ();
  426. register_code (KC_RALT);
  427. unregister_code (KC_RALT);
  428. if (accent == (KC_DQT)) {
  429. register_code (KC_RSFT);
  430. }
  431. register_code (accent);
  432. unregister_code (accent);
  433. if (need_shift && accent != (KC_DQT)) {
  434. register_code (KC_RSFT);
  435. } else if (accent == (KC_DQT) && !need_shift) {
  436. unregister_code (KC_RSFT);
  437. }
  438. register_code (hun_char);
  439. unregister_code (hun_char);
  440. if (need_shift || accent == (KC_DQT))
  441. unregister_code (KC_RSFT);
  442. if (hold_shift)
  443. register_code (KC_LSFT);
  444. return MACRO_NONE;
  445. }
  446. static void ang_handle_num_row(uint8_t id, keyrecord_t *record) {
  447. uint8_t idx = id - A_1;
  448. uint8_t kc;
  449. static bool shifted[10];
  450. if (keyboard_report->mods & MOD_BIT(KC_LSFT) ||
  451. ((get_oneshot_mods() & MOD_BIT(KC_LSFT)) && !has_oneshot_mods_timed_out())) {
  452. if (record->event.pressed)
  453. shifted[idx] = true;
  454. }
  455. if (!shifted[idx]) {
  456. kc = idx + KC_1;
  457. } else {
  458. switch (id) {
  459. case A_8:
  460. case A_9:
  461. shifted[idx] = false;
  462. return;
  463. case A_7:
  464. kc = KC_2;
  465. break;
  466. case A_5:
  467. kc = KC_8;
  468. break;
  469. case A_3:
  470. kc = KC_6;
  471. break;
  472. case A_1:
  473. kc = KC_4;
  474. break;
  475. case A_0:
  476. kc = KC_5;
  477. break;
  478. case A_2:
  479. kc = KC_1;
  480. break;
  481. case A_4:
  482. kc = KC_3;
  483. break;
  484. case A_6:
  485. kc = KC_7;
  486. break;
  487. }
  488. }
  489. if (record->event.pressed) {
  490. register_code (kc);
  491. } else {
  492. unregister_code (kc);
  493. shifted[idx] = false;
  494. }
  495. }
  496. const macro_t *action_get_macro(keyrecord_t *record, uint8_t id, uint8_t opt)
  497. {
  498. switch(id) {
  499. case A_MPN:
  500. if (record->event.pressed) {
  501. if (keyboard_report->mods & MOD_BIT(KC_LSFT) ||
  502. ((get_oneshot_mods() & MOD_BIT(KC_LSFT)) && !has_oneshot_mods_timed_out())) {
  503. int oneshot = ((get_oneshot_mods() & MOD_BIT(KC_LSFT)) && !has_oneshot_mods_timed_out());
  504. if (oneshot)
  505. clear_oneshot_mods ();
  506. unregister_code (KC_LSFT);
  507. register_code (KC_MPRV);
  508. unregister_code (KC_MPRV);
  509. if (!oneshot)
  510. register_code (KC_LSFT);
  511. } else {
  512. return MACRO (T(MNXT), END);
  513. }
  514. }
  515. break;
  516. /* Hungarian layer */
  517. case HU_AA:
  518. return ang_do_hun (record, KC_QUOT, KC_A);
  519. case HU_OO:
  520. return ang_do_hun (record, KC_QUOT, KC_O);
  521. case HU_EE:
  522. return ang_do_hun (record, KC_QUOT, KC_E);
  523. case HU_UU:
  524. return ang_do_hun (record, KC_QUOT, KC_U);
  525. case HU_II:
  526. return ang_do_hun (record, KC_QUOT, KC_I);
  527. case HU_OE:
  528. return ang_do_hun (record, KC_DQT, KC_O);
  529. case HU_UE:
  530. return ang_do_hun (record, KC_DQT, KC_U);
  531. case HU_OEE:
  532. return ang_do_hun (record, KC_EQL, KC_O);
  533. case HU_UEE:
  534. return ang_do_hun (record, KC_EQL, KC_U);
  535. /* Plover base */
  536. case A_PLVR:
  537. toggle_steno(record->event.pressed);
  538. break;
  539. /* GUI & AppSel */
  540. case A_GUI:
  541. if (record->event.pressed) {
  542. register_code (KC_LGUI);
  543. if (record->tap.count && !record->tap.interrupted) {
  544. if (record->tap.count >= 2) {
  545. layer_on (APPSEL);
  546. set_oneshot_layer (APPSEL, ONESHOT_START);
  547. }
  548. } else {
  549. record->tap.count = 0;
  550. }
  551. gui_timer = 0;
  552. } else {
  553. if (record->tap.count >= 2)
  554. {
  555. clear_oneshot_layer_state (ONESHOT_PRESSED);
  556. }
  557. gui_timer = timer_read ();
  558. }
  559. break;
  560. case APP_SLK:
  561. if (record->event.pressed)
  562. uprintf("CMD:appsel_slack\n");
  563. break;
  564. case APP_EMCS:
  565. if (record->event.pressed)
  566. uprintf("CMD:appsel_emacs\n");
  567. break;
  568. case APP_TERM:
  569. if (record->event.pressed)
  570. uprintf("CMD:appsel_term\n");
  571. break;
  572. case APP_CHRM:
  573. if (record->event.pressed)
  574. uprintf("CMD:appsel_chrome\n");
  575. break;
  576. case APP_MSIC:
  577. if (record->event.pressed)
  578. uprintf("CMD:appsel_music\n");
  579. break;
  580. // number row and symbols
  581. case A_1 ... A_0:
  582. ang_handle_num_row(id, record);
  583. break;
  584. }
  585. return MACRO_NONE;
  586. };
  587. // Runs just one time when the keyboard initializes.
  588. void matrix_init_user(void) {
  589. uint8_t dl;
  590. set_unicode_input_mode(UC_LNX);
  591. ergodox_led_all_on();
  592. for (int i = LED_BRIGHTNESS_HI; i > LED_BRIGHTNESS_LO; i--) {
  593. ergodox_led_all_set (i);
  594. wait_ms (5);
  595. }
  596. wait_ms(1000);
  597. for (int i = LED_BRIGHTNESS_LO; i > 0; i--) {
  598. ergodox_led_all_set (i);
  599. wait_ms (10);
  600. }
  601. ergodox_led_all_off();
  602. if (!eeconfig_is_enabled())
  603. eeconfig_init();
  604. dl = eeconfig_read_default_layer ();
  605. if (dl == (1UL << ADORE)) {
  606. is_adore = 1;
  607. }
  608. };
  609. LEADER_EXTERNS();
  610. static void ang_tap (uint8_t code, ...) {
  611. uint8_t kc = code;
  612. va_list ap;
  613. va_start(ap, code);
  614. do {
  615. register_code(kc);
  616. unregister_code(kc);
  617. wait_ms(50);
  618. kc = va_arg(ap, int);
  619. } while (kc != 0);
  620. va_end(ap);
  621. }
  622. #define TAP_ONCE(code) \
  623. register_code (code); \
  624. unregister_code (code)
  625. typedef struct {
  626. bool layer_toggle;
  627. bool sticky;
  628. } td_ta_state_t;
  629. static void ang_tap_dance_ta_finished (qk_tap_dance_state_t *state, void *user_data) {
  630. td_ta_state_t *td_ta = (td_ta_state_t *) user_data;
  631. if (td_ta->sticky) {
  632. td_ta->sticky = false;
  633. td_ta->layer_toggle = false;
  634. layer_off (ARRW);
  635. return;
  636. }
  637. if (state->count == 1 && !state->pressed) {
  638. register_code (KC_TAB);
  639. td_ta->sticky = false;
  640. td_ta->layer_toggle = false;
  641. } else {
  642. td_ta->layer_toggle = true;
  643. layer_on (ARRW);
  644. td_ta->sticky = (state->count == 2);
  645. }
  646. }
  647. static void ang_tap_dance_ta_reset (qk_tap_dance_state_t *state, void *user_data) {
  648. td_ta_state_t *td_ta = (td_ta_state_t *) user_data;
  649. if (!td_ta->layer_toggle)
  650. unregister_code (KC_TAB);
  651. if (!td_ta->sticky)
  652. layer_off (ARRW);
  653. }
  654. static void ang_tap_dance_tmux_finished (qk_tap_dance_state_t *state, void *user_data) {
  655. if (state->count == 1) {
  656. register_code(KC_LALT);
  657. register_code(KC_SPC);
  658. unregister_code(KC_SPC);
  659. unregister_code(KC_LALT);
  660. } else {
  661. register_code(KC_LCTL);
  662. register_code(KC_A);
  663. unregister_code(KC_A);
  664. unregister_code(KC_LCTL);
  665. }
  666. }
  667. static void ang_tap_dance_tmux_pane_select (qk_tap_dance_state_t *state, void *user_data) {
  668. uint8_t kc = KC_P;
  669. if (state->count >= 2) {
  670. kc = KC_Z;
  671. }
  672. register_code(KC_LALT);
  673. register_code(KC_SPC);
  674. unregister_code(KC_SPC);
  675. unregister_code(KC_LALT);
  676. register_code(kc);
  677. unregister_code(kc);
  678. }
  679. qk_tap_dance_action_t tap_dance_actions[] = {
  680. [CT_CLN] = ACTION_TAP_DANCE_DOUBLE (KC_COLN, KC_SCLN)
  681. ,[CT_TA] = {
  682. .fn = { NULL, ang_tap_dance_ta_finished, ang_tap_dance_ta_reset },
  683. .user_data = (void *)&((td_ta_state_t) { false, false })
  684. }
  685. ,[CT_LBP] = ACTION_TAP_DANCE_DOUBLE (KC_LBRC, KC_LPRN)
  686. ,[CT_RBP] = ACTION_TAP_DANCE_DOUBLE (KC_RBRC, KC_RPRN)
  687. ,[CT_TMUX]= ACTION_TAP_DANCE_FN (ang_tap_dance_tmux_finished)
  688. ,[CT_TPS] = ACTION_TAP_DANCE_FN (ang_tap_dance_tmux_pane_select)
  689. };
  690. // Runs constantly in the background, in a loop.
  691. void matrix_scan_user(void) {
  692. static uint32_t prev_layer_state;
  693. uint8_t layer = biton32(layer_state);
  694. bool is_arrow = false;
  695. static char *layer_lookup[] = {"Dvorak", "ADORE", "Arrows", "AppSel", "Hungarian", "Nav/Media", "Plover"};
  696. if (layer_state != prev_layer_state) {
  697. prev_layer_state = layer_state;
  698. if (layer_lookup[layer])
  699. uprintf("LAYER: %s\n", layer_lookup[layer]);
  700. }
  701. if (gui_timer && timer_elapsed (gui_timer) > TAPPING_TERM)
  702. unregister_code (KC_LGUI);
  703. if (layer == HUN) {
  704. ergodox_right_led_2_on();
  705. ergodox_right_led_3_on();
  706. } else if (layer == NMDIA) {
  707. ergodox_right_led_1_on();
  708. ergodox_right_led_2_on();
  709. } else if (layer == PLVR) {
  710. ergodox_right_led_1_on ();
  711. ergodox_right_led_2_on ();
  712. ergodox_right_led_3_on ();
  713. } else if (layer == ADORE) {
  714. ergodox_right_led_1_on ();
  715. ergodox_right_led_2_on ();
  716. ergodox_right_led_3_on ();
  717. ergodox_right_led_2_set (LED_BRIGHTNESS_HI);
  718. }
  719. if (layer_state & (1UL << ARRW)) {
  720. ergodox_right_led_1_on ();
  721. ergodox_right_led_3_on ();
  722. is_arrow = true;
  723. }
  724. if (keyboard_report->mods & MOD_BIT(KC_LSFT) ||
  725. ((get_oneshot_mods() & MOD_BIT(KC_LSFT)) && !has_oneshot_mods_timed_out())) {
  726. ergodox_right_led_1_set (LED_BRIGHTNESS_HI);
  727. ergodox_right_led_1_on ();
  728. } else {
  729. ergodox_right_led_1_set (LED_BRIGHTNESS_LO);
  730. if (layer != NMDIA && layer != PLVR && layer != ADORE && !is_arrow)
  731. ergodox_right_led_1_off ();
  732. }
  733. if (keyboard_report->mods & MOD_BIT(KC_LALT) ||
  734. ((get_oneshot_mods() & MOD_BIT(KC_LALT)) && !has_oneshot_mods_timed_out())) {
  735. ergodox_right_led_2_set (LED_BRIGHTNESS_HI);
  736. ergodox_right_led_2_on ();
  737. } else {
  738. ergodox_right_led_2_set (LED_BRIGHTNESS_LO);
  739. if (layer != HUN && layer != NMDIA && layer != PLVR && layer != ADORE)
  740. ergodox_right_led_2_off ();
  741. }
  742. if (keyboard_report->mods & MOD_BIT(KC_LCTRL) ||
  743. ((get_oneshot_mods() & MOD_BIT(KC_LCTRL)) && !has_oneshot_mods_timed_out())) {
  744. ergodox_right_led_3_set (LED_BRIGHTNESS_HI);
  745. ergodox_right_led_3_on ();
  746. } else {
  747. ergodox_right_led_3_set (LED_BRIGHTNESS_LO);
  748. if (layer != HUN && layer != PLVR && layer != ADORE && !is_arrow)
  749. ergodox_right_led_3_off ();
  750. }
  751. LEADER_DICTIONARY() {
  752. leading = false;
  753. leader_end ();
  754. #if KEYLOGGER_ENABLE
  755. SEQ_ONE_KEY (KC_D) {
  756. ergodox_led_all_on();
  757. wait_ms(100);
  758. ergodox_led_all_off();
  759. log_enable = !log_enable;
  760. }
  761. #endif
  762. SEQ_ONE_KEY (KC_Q) {
  763. register_code16 (LCTL(KC_1));
  764. unregister_code16 (LCTL(KC_1));
  765. }
  766. SEQ_ONE_KEY (KC_T) {
  767. time_travel = !time_travel;
  768. }
  769. SEQ_ONE_KEY (KC_U) {
  770. qk_ucis_start();
  771. }
  772. SEQ_ONE_KEY (KC_V) {
  773. SEND_STRING (QMK_KEYBOARD "/" QMK_KEYMAP " @ (" QMK_VERSION "/" KEYMAP_VERSION ")");
  774. }
  775. SEQ_ONE_KEY (KC_L) {
  776. /* λ */
  777. unicode_input_start();
  778. register_hex(0x03bb);
  779. unicode_input_finish();
  780. }
  781. SEQ_ONE_KEY (KC_Y) {
  782. ang_tap (KC_BSLS, KC_O, KC_SLSH, 0);
  783. }
  784. SEQ_ONE_KEY (KC_S) {
  785. unicode_input_start(); register_hex(0xaf); unicode_input_finish();
  786. TAP_ONCE (KC_BSLS);
  787. register_code (KC_RSFT); TAP_ONCE (KC_MINS); TAP_ONCE (KC_9); unregister_code (KC_RSFT);
  788. unicode_input_start (); register_hex(0x30c4); unicode_input_finish();
  789. register_code (KC_RSFT); TAP_ONCE (KC_0); TAP_ONCE (KC_MINS); unregister_code (KC_RSFT);
  790. TAP_ONCE (KC_SLSH);
  791. unicode_input_start (); register_hex(0xaf); unicode_input_finish();
  792. }
  793. SEQ_TWO_KEYS (KC_W, KC_M) {
  794. uprintf("CMD:wm\n");
  795. }
  796. SEQ_ONE_KEY (KC_A) {
  797. if (is_adore == 0) {
  798. default_layer_and (0);
  799. default_layer_or ((1UL << ADORE));
  800. eeconfig_update_default_layer ((1UL << ADORE));
  801. is_adore = 1;
  802. ergodox_led_all_off ();
  803. ergodox_right_led_3_on ();
  804. wait_ms (100);
  805. ergodox_right_led_2_on ();
  806. wait_ms (100);
  807. ergodox_right_led_3_off ();
  808. ergodox_right_led_1_on ();
  809. wait_ms (100);
  810. ergodox_right_led_2_off ();
  811. wait_ms (100);
  812. ergodox_right_led_1_off ();
  813. } else {
  814. is_adore = 0;
  815. default_layer_and (0);
  816. default_layer_or (1UL << BASE);
  817. eeconfig_update_default_layer ((1UL << BASE));
  818. ergodox_led_all_off ();
  819. ergodox_right_led_1_on ();
  820. wait_ms (100);
  821. ergodox_right_led_2_on ();
  822. wait_ms (100);
  823. ergodox_right_led_1_off ();
  824. ergodox_right_led_3_on ();
  825. wait_ms (100);
  826. ergodox_right_led_2_off ();
  827. wait_ms (100);
  828. ergodox_right_led_3_off ();
  829. }
  830. }
  831. }
  832. }
  833. static uint16_t last4[4];
  834. const qk_ucis_symbol_t ucis_symbol_table[] = UCIS_TABLE
  835. (
  836. UCIS_SYM("poop", 0x1f4a9),
  837. UCIS_SYM("rofl", 0x1f923),
  838. UCIS_SYM("kiss", 0x1f619),
  839. UCIS_SYM("snowman", 0x2603),
  840. UCIS_SYM("coffee", 0x2615),
  841. UCIS_SYM("heart", 0x2764),
  842. UCIS_SYM("bolt", 0x26a1)
  843. );
  844. bool process_record_user (uint16_t keycode, keyrecord_t *record) {
  845. #if KEYLOGGER_ENABLE
  846. if (log_enable) {
  847. uint8_t layer = biton32(layer_state);
  848. if ((layer == ADORE) || (layer == BASE))
  849. uprintf ("KL: col=%02d, row=%02d, pressed=%d, layer=%s\n", record->event.key.col,
  850. record->event.key.row, record->event.pressed, (is_adore) ? "ADORE" : "Dvorak");
  851. }
  852. #endif
  853. if (keycode == KC_ESC && record->event.pressed) {
  854. bool queue = true;
  855. if ((get_oneshot_mods ()) && !has_oneshot_mods_timed_out ()) {
  856. clear_oneshot_mods ();
  857. queue = false;
  858. }
  859. if (layer_state & (1UL<<HUN)) {
  860. layer_off (HUN);
  861. queue = false;
  862. }
  863. return queue;
  864. }
  865. if (time_travel && !record->event.pressed) {
  866. uint8_t p;
  867. // shift cache one to the left
  868. for (p = 0; p < 3; p++) {
  869. last4[p] = last4[p + 1];
  870. }
  871. last4[3] = keycode;
  872. if (last4[0] == KC_D && last4[1] == KC_A && last4[2] == KC_T && last4[3] == KC_E) {
  873. ang_tap (KC_E, KC_SPC, KC_MINS, KC_D, KC_SPC, KC_QUOT, 0);
  874. register_code (KC_RSFT);
  875. register_code (KC_EQL);
  876. unregister_code (KC_EQL);
  877. unregister_code (KC_RSFT);
  878. ang_tap (KC_4, KC_SPC, KC_D, KC_A, KC_Y, KC_S, KC_QUOT, 0);
  879. return false;
  880. }
  881. }
  882. return true;
  883. }
  884. void qk_ucis_symbol_fallback (void) {
  885. for (uint8_t i = 0; i < qk_ucis_state.count - 1; i++) {
  886. uint8_t code;
  887. if ((qk_ucis_state.codes[i] >= M(A_1)) && (qk_ucis_state.codes[i] <= M(A_0)))
  888. code = qk_ucis_state.codes[i] - M(A_1) + KC_1;
  889. else
  890. code = qk_ucis_state.codes[i];
  891. register_code(code);
  892. unregister_code(code);
  893. wait_ms (10);
  894. }
  895. }