This is a quick and dirty script to nicely get around the annoying (though reasonable) limitation of Ergodox / Moonlander keyboards in the Oryx configurator where macros can only be 4 key sequences for security reasons.
This hack is a post-processor that'll take your raw "Source" Oryx configuration and extend your macros to be any arbitrary sequence.
Sadly gittyeric no longer has a Moonlander / Ergodox, but Phoscur has kindly agree to take stewardship in his fork! When migration of this fork is complete this section will be updated with git migration commands to switch your fork's base.
To compile the firmware, setup the ZSA QMK Fork with guide referenced
qmk setup zsa/qmk_firmware -b firmware20
Install on the command line (with Node.js installed) using:
cd ~/qmk_firmware
git clone <your fork of this repo>
cd ergodox-macro-hax
npm install
Configure in Oryx just as you normally would, except make sure each macro you'd like to extend beyond 4 button presses is a unique set of alphanumeric button presses that act as a unique ID to find in post-processing. Let's say you want a keyboard to type "whale", you could just write a macro with keys "whal" or get really detailed with numeric IDs and type "1234". Remember these IDs for later. DO NOT use any key modifiers, custom delays or non-alphanumeric keys in your extendable macros, you can specify those yourself later.
When done, take a note of the layout hash ID
in the URL or download the source manually into the keymap_src
folder.
It is also recommended to git branch <your layout name>
and gitignore allowlist !layout_src/<your layout name>
.
cd ~/qmk_firmware/ergodox-macro-hax
npm run get -- <oryxLayoutHashId>
Grab my-illicit-macros.ts and change it to what you need, starting with the absolute directory path SOURCE_DIR
pointed to the unzipped directory that contains the "keymap.c" file (NOT usually in the root directory!) you noted in step 1. Now open my-illicit-macros.ts and modify to match your configuration.
Here's an example of creating an extended (more than 4 button) macro:
const macro = newMacro()
.typeAlphanumeric("function") // Supports a-z and 0-9
.sendRawCmd("SS_DELAY(100)") // Raw commands in the C file
.tapKey("X_SPACE") // Tap a raw key code
.delay(50) // Delay for 50 ms
Now just map the original 4 character macro to your newer, longer macro. See what's already in my-illicit-macros.ts for fuller examples.
Run npm run hax
to modify your config and extend your macros.
Run npm run copy
to copy the processed keymap to the parent keymaps folder (keymaps/neo).
Use the normal QMK/ZSA Wally software to compile and flash.
qmk compile -kb moonlander -km neo
If you want Github to build the firmware for you, create repository action secrets LAYOUT_ID
, set it to the hashId of your layout keymap, as well as LAYOUT_FOLDER
with the name of the folder of your keymap in the source archive.
(Extract it from your ORYX link: https://configure.zsa.io/moonlander/layouts/<hashId>/latest/0
) then you can use Github Actions to build the firmware for you.
I'm too lazy to list them for you, when I need a keycode such as "X_SPACE", I just put it in a macro and find it in the keymap.c file, then reference that name from then on out.