JJerrell's QMK Userspace
This userspace showcases my personal journey with QMK keyboards and aims to simplify additional development, reduce code duplication, and maintain a consistent experience across my current keyboards. My original userspace has been archived because I wanted to take the time to grasp how what I was doing worked -- rather than copy/pasta and blind luck.
Some keyboard specific code is stored here because it's contextually relevant. It may be somewhat pedantic, but an effort has been made to wrap this code with preprocessor checks. i.e. #if (defined(KEYBOARD_planck_ez))
.
Daily Drivers
- Ergodox EZ - My first mechanical love. Now the office keyboard (if we go back). After finding inferior travel cases for exorbitant amounts of money, I built a custom travel case out of a case designed for drones and maticulous work cutting guncase foam. Around $50 with plenty of foam left over for family LARPing weapons. I'll post a picture one of these days. It also has a spot for my wireless touchpad.
- Planck EZ - The solution to not being able to sit at a desk 100% of the time and not being able to live without QMK for any amount of time. Karabiner-Elements disables the Macbook keyboard when this is plugged in and the planck sits ontop of it with a very short usb-c cable. Probably terrible for the built in keyboard but they screwed up this generation anyway.
- Moonlander - Just when I thought it was over, the lovely people with ZSA did it again. This one stays at home on my desk.
Features
- Keymap level customization
- User methods implemented here will give the keymaps a chance to override functionality by optionally implementing relevant _keymap methods
- Layer Macros
- WRAPPER defines in [wrapper.c] simplify consistent keymaps
- Leader key secrets
- [jjerrell.c] sets up the functionality for this feature and calls into the leader_scan_secrets method.
- TODO: add documentation for leader_scan_secrets implementation
Issues
Tap/hold keys and shifted keycodes
An immediate part of my love for QMK was it's ability to differentiate between holds and presses to a level where you can apply modifiers when a normal alpha code is held. This feature was the single-most health related improvement to adopting QMK, in my opinion.
Beloved as it may be it comes with some baggage; shifted keycodes will be applied as their unshifted counterparts. I've worked around this in the past but the solution this time is a close adoption of the symbol layer inspired by the Neo keyboard.
There is also a problem with relying on SFT_T() for all of your shifting needs because if you attempt to swap which fingers are holding it and don't release the first before pressing the second, shift won't register anymore. This could probably be fixed but it discourages typing in all caps because it becomes too tedious. However, most layers do have a dedicated shift key to counteract this when necessary.