For general info on the Big Bag of Keyboard Tricks, consult the Big Bag of Tricks pages.
Select the controller platform icon to make the purple info boxes show relevant info for controllers and USB-2-USB devices.
This README is based on the now outdated Colemak Forum BigBag for TMK topic.
Chapters 1–3 correspond to BigBag chapters with links in the table below, while chapter 4 is on this page only.
WARNING - Some Assembly May Be Required (if you want a specific locale variant for instance)
[1] Character/Key Mapping Layers
[1.1] (My Colemak[eD] AltGr mappings)
[1.2] Extend layers using Caps Lock (and Tab) as switch modifier(s) for navigation/editing/browsing/etc from near the home position
[2] Ergonomic Key Remappings
[2.1] Angle/Wide ergo modifications to improve wrist angles, hand spacing and right pinky stretch/load effort
[2.2] Colemak-DH alias the Curl(DH) ergo mod (deprioritize middle columns without keys changing fingers)
[2.3] Symbol key mods for the adventurous (better apostrophe and/or hyphen positions)
[2.4] Modifier modness for the adventurous (Sticky, One-shot etc; Work-In-Progress)
[3] Layout Variants
[3.1] Tarmak transitional Colemak layouts for learning Colemak in smaller steps if so desired
[3.2] (Locale and phonetic layout variants)
[3.3] Mirrored Colemak that allows one-handed typing without extra learning
[4] Download and Setup
[4.1] Download and Install
[4.2] Keymap Configuration
[4.3] Device Flashing
[4.4] Hardware Implementations
[–] Links/Done/Todo
This page explains what a QUICKIE USB-2-USB device is, and what I've managed to implement on Hasu's USB to USB keyboard converter using his TMK Keyboard Firmware Collection toolkit. If you're eager to get started before reading the details, you may jump directly to the Download and Setup sections below.
GeekHack user yangdigi's comparison of USB-2-USB devices: Arduino Leonardo-type, Hasu's device and his own Pro Micro device. Scale: Hasu's device is about 6 cm (2") long.
Look at those beauties, heh. I've decided to call this kind of device a QUICKIE (QWERTY USB In, Colemak Key Input Emulated)! Hehe. More proper names are "USB-2-USB" or "USB to USB converter" device, as you may of course use it for non-Colemak layouts (and as my name is silly).
This non-OS-specific solution doesn't have the full power of layout installs, but it's very interesting. A USB-to-USB device that plugs between the keyboard and whatever you're connecting your keyboard to, provides an XKB/Win/Mac/what-have-you independent solution that can accommodate many of my tricks! For people having to deal with zealous IT security rules, this may be the only solution short of getting an expensive remappable keyboard. It could let you type Colemak+Extend to, say, a PlayStation or other device where you can't control the layout directly. It could let you pair code using Colemak+Extend while your mate uses QWERTY (poor thing!) on the same computer. And it could be fun to make one yourself if you're adventurous and DIY oriented!
The common solution is a microcontroller (such as Atmel's AtMega32 chips; Arduino Teensy 2+ or Pro Micro are good choices) with USB, coupled with a USB Host "shield" (separate little PCB) that lets you plug your keyboard into it. It'll mount itself as a HID keyboard, that is, a run-of-the-mill USB keyboard that almost any device accepts.
There are other options, too: You could have a PS/2-USB converter instead, or various keyboard controllers attached to or built into the keyboard itself! Most of these can use the same "Unimap" layout code, so if you're interested in one of those variants then check it out.
There are several possible ways of programming a USB-2-USB device. Essentially you have to:
- Connect the device in Bootloader mode which means it can be programmed
- Get some code and compile it for the device, or use a pre-compiled HEX file. There's even an online layout designer for a less techy option.
- Flash the .hex file to the device's static memory
- Reset the device (or just unplug and replug it) to reactivate application mode so it works
An advantage of my TMK-based implementation is that you can pick and choose most of the enhancements as modules:
- The AngleWide mods are keymap types so they work with any layout you choose, including QWERTY or Dvorak
- The Extend layers and switch keys are options that should work with nearly any existing layout
- The Curl(DH) mod for Colemak layouts and SymbolKey modifications use separate modular switches
- Mirrored Colemak and Tarmak (transitional Colemak) are separate layouts.
Freedom of choice through modularity is an ideal in the DreymaR world, as it is in Linux.
A USB-2-USB device remaps only key strokes, not character input events. So key mods like layout and ergo remappings are possible, but not mods that send glyphs. Your dead keys and AltGr mappings will work as they do without the device, and you may only move their keys around as they are.
Sorry, but AltGr/DeadKey glyph mappings such as the powerful Colemak[eD] below are for the most part up to the active layout on the machine you're typing to.
In all honesty though, it is possible to send Unicode with methods such as Windows' Alt+NumPad(####) defined for instance as TMK macros. But since it's platform dependent, memory consuming and clunky, I couldn't do this to create the full Colemak[eD]. Dead key tables and functions would've been even more byte-gobbling, so no.
However, I have made a FOURLVLU
user function that lets you define a few keys as four-level giving OS specific Unicode input using the RAlt key as AltGr for these keys only. I used this to get the Norwegian special letters åæø and their shifted counterparts (on the bracket and ISO LSGT keys) as in Colemak[eD], and it works fine for me. I even added the bullet and dagger glyphs (on the ISO | key) for good measure. You can find various lists of alt codes to use, such as this one. Remember that you need to use "KC_P#" where # is the digit. For Mac or Unix you need to change the method, see the unimap_dreymar.c file and ask me if you need help.
Fig.: Colemak-CAW[eD], showing an ISO board with the Curl(DH)Angle and Wide ergonomic mods (see below).
This is My Favorite Mod next to Colemak itself! The ability to navigate and edit from the home position and its immediate surroundings is extremely powerful. It's like having part of the power of advanced editors like Vim ready in all situations. Plus a fully functional multimedia keyboard without sacrificing compactness. And much more.
My Extend Nav/Edit mappings. Green, navigation; blue, mousing; orange, multimedia; gray, system/misc.
My Extend NumPad mappings. Green, navigation; purple, NumPad; sepia, symbols; gray, system/misc.
The USB-2-USB implementation is almost the same as the Linux/XKB and Windows/PKL ones. Some advanced media key codes such as Brightness controls are missing for now (as their key codes aren't in TMK). How some of the advanced keys like MouseWheel Left/Right are interpreted is still up to the OS.
Here's the Extend1 and Extend2 layer charts from my TMK source file:
DreymaR's Extend1 layer:
* ,----˛ ,-------------------˛ ,-------------------˛ ,-------------------˛
* |Caps| |MPly|MPrv|MNxt|MStp| |Mute|VolD|VolU|MSel| |WHom|WSch|MyCm|Calc|
* `----´ `-------------------´ `-------------------´ `-------------------´
* ,-------------------------------------------------------------------------˛
* | ?? | F1 | F2 | F3 | F4 | F5 | F6 | F7 | F8 | F9 | F10| F11| F12| Pause |
* |-------------------------------------------------------------------------|
* | |Esc |Wh_U|WBak|WFwd|Ms_U|PgUp|Home| Up |End |Del |Esc |Ins | App |
* |-------------------------------------------------------------------------|
* |*Ext1* |Alt |Wh_D|Shft|Ctrl|Ms_D|PgDn|Left|Down|Rght|BSpc|App |WFav|PScr |
* |-------------------------------------------------------------------------|
* | |Wh_L| ^Z | ^X | ^C | ^V |Btn1|Btn2|Btn3|Ms_L|Ms_R|Wh_R| Ext2 |
* |-------------------------------------------------------------------------|
* | | | | Return | | | | Ext3 |
* `-------------------------------------------------------------------------´
DreymaR's Extend2 layer:
* ,----˛ ,-------------------˛ ,-------------------˛ ,-------------------˛
* | | |MPau|MRwd|MFFd|Ejct| |WRef|BriD|BriU|Slep| |www |Mail|App3|App4|
* `----´ `-------------------´ `-------------------´ `-------------------´
* ,-------------------------------------------------------------------------˛
* | ?? | ! | @ | # | $ | % | ^ | P7 | P8 | P9 | P* | P- | = | |
* |-------------------------------------------------------------------------|
* | |Home| Up |End |Del |Esc |PgUp| P4 | P5 | P6 | P+ | ( | ) | |
* |-------------------------------------------------------------------------|
* |*Ext2* |Left|Down|Rght|BSpc|NLck|PgDn| P1 | P2 | P3 |PEnt| ' | , | |
* |-------------------------------------------------------------------------|
* | | | ^Z | ^X | ^C | ^V |Btn1| : | P0 | P0 | P. | P/ | Ext2 |
* |-------------------------------------------------------------------------|
* | | | | | | | | Ext3 |
* `-------------------------------------------------------------------------´
To use the Extend layers, define the CAPSBEHAVIOR
constant to 1. This'll make CapsLock the Extend modifier. You may change it to another key by editing the active layout or keymap; see the Keymap Configuration section below.
There's a couple of EXT#BIT
constants that determine how Extend2 is selected: If EXT2BIT
is defined as MOD_BIT(KC_RSFT)
for instance, holding Right Shift down while pressing the Extend key will activate Extend2. Once selected, holding down Extend alone maintains that layer. The EXT3BIT
and the combination of the two could select Extend3 and Extend4, but I haven't yet implemented these layers as I haven't yet decided on what to put in them. You could add your own if you want to.
For the NumPad layer, remember that the NumLock state influences what you get. There's a NumLock key easily accessible in the layer.
NOTE: Superstacking Extend modifiers doesn't always work for me. Instead of Ctrl+Shift+Left, pressing Caps+S+T+N gave me ST key strokes. Oddly enough, it works with either Phys-Shift + Extend-Ctrl as well as Phys-RCtrl + Extend-Shift (Shift+Caps+T+N or RCtrl+Caps+S+N work) but not with physical LCtrl. This leads me to believe that the limitation is my keyboards' scan matrix, but it happened on all my boards. Other users with fancier keyboards didn't have this problem.
These are ergonomic mods, moving some keys around to achieve straight wrists (the Angle mods), as well as better hand separation and right pinky load (the Wide mods). The Angle part is almost a no-brainer to me as it allows the left hand to keep a straight wrist without changing the fingering on ZXCV, and makes B easier to reach. Shai Coleman himself has given his "blessing" to this mod! The Wide mod is more optional, but it does put some load off the right-hand pinky, widen the arm distance (useful for small keyboards in particular, but nice regardless), and provide easier access to AltGr/Enter/Backspace/RShift.
The AngleWide ergo mod for ISO keyboards.
I've implemented the ZXCVB_ "Angle-ISO" shift for ISO keyboards both separately and as part of the AngleWide-ISO mod that I use myself. For ANSI boards I've made an implementation of the "Angle(Z)" shift (moving the Z key to the middle) and a Wide mod as well as the AngleWide combination of these. Also the rarely used 'A-Wing' mod to get the Angle and right pinky benefits without messing with the Z position (but at other costs).
The Angle(Z)Wide ergo mod for US/ANSI keyboards
To use one of these, define the Unimap layout constant in my keymap (.c) file:
* Edit '_########' in the UNIMAPLAYOUT definiton below to choose ergonomic Curl/Angle/Wide keyboard mods:
* _NOMODS - Standard Unimap format for all keyboard and converter types (w/o F13-24; this one is without ergo mods)
* _ISO_A_ - ISO/Int Angle (the simple lower left half-row shift)
* _ISO_AW - ISO/Int Angle-Wide(/)
* _ANS_A_ - ANSI/US Angle(Z)
* _ANS_AW - ANSI/US Angle(Z)-Wide(')
* _AWINGA - ANSI/US A-Wing Angle (rarely used)
*
* Select an ergo modded keymap, or the plain unmodded Unimap. Note that these maps affect all layouts and layers.
* For Curl(DH), you also need to set CURLMOD. For Sym mods, set SYMBOLKEYS according to keymap.
* To get, say, the Colemak-CAWS (CurlAngleWideSym) layout on ISO/ANSI, use the _###_AW keymap with
* ACTIVELAYOUT 5, CURLMOD 1 and SYMBOLKEYS 2/3 settings below. And CAPSBEHAVIOR 1 for Extend, of course!
The actual keymap types are defined in the header (.h) file as compiler macros. These are harder to edit manually.
The Colemak-DH ergo mod makes the home "row" curl like a relaxed hand does instead of forcing it to a straight line as was commonly thought best some years ago. This is achieved by moving the common D and H from their debated "middle trench" positions to the more comfortable lower-row V/M positions, while preserving the key-to-finger mappings of vanilla Colemak. Since Oct 2020, standard Colemak-DH is the original DH mod a.k.a. DHm.
The Colemak Curl(DH)AngleWide, a.k.a. Colemak-CAW, ergo modded layout.
On row-staggered boards, DH should be paired with an Angle (or AngleWide) ergo mod which is easier on an "102/105-key" ISO keyboard but as seen above there are decent options for US/ANSI boards too.
To use Colemak-DH with my TMK files, there's a preprocessor switch named CURLMOD
:
* The CURLMOD options for Colemak and Tarmak layouts are:
* 0: No Curl - "vanilla" Colemak/Tarmak
* 1: SteveP99's original Curl(DHm) ergo mod, bringing D/H down but M to the home row. DH standard since Oct 2020.
*
* N/A: The 2017 Curl(DHk) ergo mod, bringing the D and H keys down to comfortable bottom-row positions (QWERTY C/M)
* (Some row-staggered board users may like the DHk variant, but the DHm standard is good for all board types.)
* N/A: DreymaR's old Curl(DvH) mod, bringing DH center-down to the QWERTY V/N keys.
* (If you somehow wish to keep ZXCV together as in my old Curl(DvH) mod, edit the maps manually.)
*
* NOTE: On the first Tarmak step, the CURLMOD setting doesn't matter. If you want to swap H and M early, edit it in.
* For the other steps, CURLMOD still doesn't move H-M so Curl(DH) users by default will do H-M in the last step.
* An extra baby step after Tarmak1 could be transitioning to an Angle(Wide) keymap/model before Tarmak2.
# define CURLMOD 1 /* CURL_DH */
This switch only affects Colemak layouts, including the four Tarmak layouts and Mirrored Colemak. As mentioned, use an 'A' keymap with it (optional for Tarmak1).
The Symbol key mods are selected with the SYMBOLKEYS
setting. The Sym mod depends on your keymap, so select the right one depending on your Wide mod and board type.
* The SYMBOLKEYS options for layouts are:
* 0: No Symbol key changes - "vanilla" Colemak or whatever
* 1: Sym mod for non-Wide ergo mods
* 2: Sym mod for Wide mod combos on ISO keyboards
* 3: Sym mod for Wide mod combos on ANSI keyboards
*
* Adaptations for ANSI-ISO and locale key differences (more info below):
* 4 : Some keys are made four-level: AltGr+ sends Unicode glyphs (by OS specific input method)
* 5 : DreymaR's ISO-Nor hack, moving some keys to make the Norwegian layout more like ANSI/US
# define SYMBOLKEYS 0 /* SYM_NONE */
Note that SYMBOLKEYS
affects Extend layers and other layouts too!
\ 7 8 9 0 =
[ j l u y ' -
] m n e i o ;
/ k h , . _____
The "Sym" symbol rotation mod together with the Curl-DH and AngleWide(ISO) mods is Colemak-CAWS.
I've implemented Sticky Shift but not much else for TMK. Moving modifiers around manually shouldn't be hard to do if you're interested.
* The STICKYMODS constant chooses LShift, RShift and RCtrl key behavior (I chose to leave LCtrl alone):
* 0: Normal Shift/Ctrl (default)
* 1: Sticky Shift only
* 2: Sticky Ctrl only
* 3: Sticky Shift & Ctrl
* NOTE: In the unimap_dreymar.h file, some relevant constants normally set in config.h are (re)set:
* - TAPPING_TERM is the max time a key may be held down for it to register as tapped
* - ONESHOT_TIMEOUT is the max delay before a oneshot modifier is ignored
#define STICKYMODS 1 /* STICKY_SHFT */
Note that I've given most symbol keys special 'F' names (like FLSh
for LSFT
) in the layout maps. These are defined by ACTION_
definitions.
There's a Tarmak BigBag page that you may want to read. Basically, I've added four Tarmak layouts that provide stepping stones from the standard (US) English QWERTY layout to the Colemak[eD] layout by moving only 3-4 keys per step. Each step brings at least one important key to the home row (notably, E-T-R-O-I) and only the uncommon J is misplaced in the process.
The 5-step Tarmak(ETROI) transitional Colemak layouts, spectrally color-coded from red (Tarmak1) to violet (Colemak).
The Tarmak progressions work modularly with the AngleWide ergo mods.
If you want to learn the brilliant Colemak-DH variant using a Tarmak progression, that's possible too! You just have to learn a CurlAngle mod before or with the 2nd Tarmak step which also gets tweaked a little so it moves B instead of G. The right-hand swaps (Hmk) should ideally be learnt in conjunction with Tarmak1-Curl because that moves K, but for SteveP's old variant I've deferred the HM swap to the last step. It could go wherever you like as it's separate, so feel free to edit the layout file if you desire.
* Tarmak2 - Transitional Colemak (ET)
* ,-----------------------------------------------------------˛
* | | q| w| F| r| G| y| u| i| o| p| | | |
* |-----------------------------------------------------------|
* | | a| s| d| T| *J| h| N| E| l| ;| | |
* |-----------------------------------------------------------|
* | | z| x| c| v| b| K| m| | | | |
* `-----------------------------------------------------------´
* Tarmak2-Curl(DH) - Transitional Colemak-Curl-DH (ET)
* ,-----------------------------------------------------------˛
* | | q| w| F| r| B| y| u| i| o| p| | | |
* |-----------------------------------------------------------|
* | | a| s| d| T| g| h| N| E| l| ;| | |
* |-----------------------------------------------------------|
* | | z| x| c| *J| v| _| K| m| | | | |
* `-----------------------------------------------------------´
The QUICKIE device only partially supports locales per se, as it only sends key strokes that are then re-coded by your computer's layout settings. My four-level Unicode function remedies this somewhat by allowing some keys to have their AltGr/RAlt states remapped to an OS dependent Unicode input method. So I can set a standard US QWERTY layout on my computer and still have, e.g., the locale ÆæØøÅå letters where I'm used to.
Before I made that function however, I used the locale layout installed on Windows. But I found that the default symbol key mappings are non-intuitive since they are quite different from the US ones which I'm used to now. So I've made an ISOHACK
layout specifically for the Nor locale that moves several symbol keys to where I feel they are better placed for me. If you want something like that, you'll probably have to determine your own remaps based on your locale.
For instance, instead of a [=+] key as on US keyboards, the Norwegian locale has [+?], [0=] etc. I can't sort that out to get the symbol placements I'm used to as a Colemak[eD] typist unless I choose a US locale layout on the computer I'm on – but I still need the Norwegian ÆØÅ letters so that won't work! I had to settle for, e.g., moving the +? key to the US /? key position so at least the question mark is in the right place. Not perfect, but the best I could do.
Phonetic layouts for non-latin scripts require a layout with that script installed on the computer or whatever you're typing to. If you select a QWERTY phonetic layout for a script and have a USB-2-USB Colemak keymap active, your resulting layout will be Colemak phonetic. If, however, you want to swap some key positions (for Rulemak/Bulmak for instance), a suitable new keymap must be made and compiled.
Advanced typing with only one hand is possible given a modicum of familiarity with the mirroring method. In fact, this paragraph was written entirely using the left hand with the exception of the mirroring key itself, with hardly any training! The brain is inherently good at mirroring things.
Mirrored layouts are easily implementable for the USB-2-USB device. I've provided a mirrored Colemak that obeys the Curl mod setting. This will usually be your second layout (layer 1) on top of Colemak, so in my map file it's set by using ACTIVELAYOUT 5
(Colemak) and SECONDLAYOUT 6
(mirrored Colemak).
If you want a non-Colemak mirrored layout, you're on your own writing one. If you do, please share it so others can benefit!
* Mirrored Colemak (used as switch layout for one-handed typing)
* ,---˛ ,---------------˛ ,---------------˛ ,---------------˛
* | \| |F12|F11|F10|F9 | |F8 |F7 |F6 |F5 | |F4 |F3 |F2 |F1 |
* `---´ `---------------´ `---------------´ `---------------´
* ,-----------------------------------------------------------˛
* |BSp| -| 0| 9| 8| 7| 6| 5| 4| 3| 2| 1| =| ` |
* |-----------------------------------------------------------|
* | Ent | ;| Y| U| L| J| G| P| F| W| Q|Esc|Cps| \ |
* |-----------------------------------------------------------|
* | ' | O| I| E| N| H| D| T| S| R| A| '| Enter |
* |-----------------------------------------------------------|
* | Shift | /| .| ,| M| K| B| V| C| X| Z| Shift |
* `-----------------------------------------------------------´
* NOTE: Set an accessible key in your active layout (e.g., LALT or RGUI) as a layer1 switch (see SLCKBEHAVIOR).
You'll want an easily accessible key (such as a thumb key) to switch between normal and mirrored typing. One suggestion is using LAlt for left-handed typing, and RAlt or RWin for right-handed typing. But you may instead use a foot switch set to any other key, or a "ghetto foot switch" made by stripping most keys off a keyboard and placing it on the floor, for instance. A more fancy but still cheap foot switch could be made by soldering the wires from a foot pedal switch (if you have something useable) to the contacts of a key on a cheap keyboard. By default, the layer switch key in my files is Pause/Break which could be cannibalized this way.
Then, you may choose whether the switch key should be a normal Shift-type (switch) or a Caps-type (toggle) modifier. See how I've defined the "FSLk" Fn key in my file; it's used as my definition for the ScrollLock key but you can copy that to any other key as well. The normal way would be to set it to a Shift/switch-type with ACTION_LAYER_MOMENTARY(1)
(SLCKBEHAVIOR 2
), and then replace the desired key in your active (layer0) layout with FSLk
if you wish to move it. If you go with a toggle modifier, you need to make that key transparent (TRNS) on the mirrored layout, or provide a similar toggle somewhere else or you won't be able to get back!
Tip: Sticky Shift and Ctrl could be useful for one-handed typing! See the STICKYMODS
setting.
[4.1] The Download and Install section shows how to get and install my files, and also how to prepare the device in bootloader mode.
[4.2] The Keymap Configuration section shows how to get or tweak/make a HEX file that suits your layout needs.
[4.3] The Device Flashing section shows how to load a HEX file into your USB-2-USB device and get it ready for typing.
[4.4] The Hardware Implementations section shows some of the devices you can use my code on.
First off: These are my TMK-based files on GitHub! There's:
- A BigBagKbdTrix_TMK dir with my files; it can go into or beside the tmk_keyboard/ dir of Hasu's TMK repo
- A MakeFlash shell script (see below) that'll install and run TMK with my files under Linux
- A _myhexfiles dir with some ready-made HEX files that you can flash directly onto a Hasu device (or any other ATmega32U4 chip)
In addition to providing my additional files for use with Hasu's TMK code for his USB to USB converter, this section shows how to prepare your device and get ready to make and flash (install) a HEX file to it. If you have another device or just wish to learn more, I recommend looking at the TMK help files and NJBair's instructive firmware building/flashing guide.
The Keymap Configuration section will show you how to get or generate a keymap/layout that suits you, and the Device Flashing section shows how to program a USB2USB or other TMK device with that file.
1. For flashing on Windows: Install an application for device drivers ++
- New way: QMK Toolbox on Windows takes care of device drivers.
- Old way: Atmel's FLIP application takes care of device drivers.
- Note that it says 'Buy now' on a button but the links below don't cost anything!
- I've had trouble with FLIP not finding a Java Virtual Machine after a Java update.
- You may have to reinstall your Java Runtime Environment.
2. Insert the device and press its Bootloader mode button (fig. 1–4).
- You don't need a keyboard plugged into the device yet. In fact, to be on the safe side, I recommend not plugging in a keyboard yet!
- When in Application/Keyboard mode, the yellow App LED should be lit; when in Bootloader/Flash mode it goes out.
Fig. 1: Hasu's USB-2-USB device.
1) USB host – plug keyboard here; 2) USB client – plug into computer; 3) App LED; 4) Bootloader button
3. For flashing on Windows: Install/update the device drivers for your ATmega32U4 (or other) chip.
- The Windows Device Manager shows your device first as a HID keyboard and then, in Bootloader mode, as an Atmel or ATMega USB device
- Point the driver update to the
C:\Program Files (x86)\Atmel\Flip 3.4.7\usb
or similar directory if necessary (I didn't have to). - Now, using the Windows Device Manager you can check that the device is mounted:
Fig. 2: Windows Device Manager showing the Hasu USB-2-USB device in Application/Keyboard (left) and Bootloader (right) mode.
4. For flashing on Linux: Ensure that your device is seen by the OS, in DFU (bootloader) mode.
- The lsusb command lists attached USB devices; hopefully there's an entry with Atmel and "AVR DFU Bootloader" in it.
- If you're using a Linux virtual machine, make sure the device is captured in Bootloader mode, using your VM app's device listings.
- Every time you enter or leave bootloader mode, you may have to recapture the device for your VM.
- It should be ticked off in the Devices>USB menu on VirtualBox for instance; similarly for VMWare and others:
Fig. 4: The Devices (pop-up) menu of VirtualBox, showing a properly captured Atmel USB device.
My files are extensions of Hasu's TMK code. You'll need to compile them within a copy of his repo, and I'll describe how to do this on a Linux machine. You can use a real or virtual Linux machine; I've used an Ubuntu VM. If you have an updated 64-bit Windows 10, you can even use the Linux Subsystem BASH command line to do it without leaving Windows – see below! I guess you could also use for instance CygWin or MinGW, but I haven't tried those possibilities.
Included in my files is the shell script makeflash_dreymar_tmk.sh that does several things on a Linux machine. Run it with the -h option for more help:
Fig. 3: The help text for my MakeFlash script, showing options and default values. This image may be outdated; run the script yourself.
Here's a set of step-by-step download/install instructions:
- Download or clone my repo and...
- if installing TMK, put its directory with at least the MakeFlash script in the dir in which you want TMK.
- My files/dirs can actually go either a) in a dir beside TMK's tmk_keyboard, b) directly inside it, or c) in a dir inside it
- (On my virtual machine, I use a shared folder so both Linux and Windows can see the HEX files I've built directly.)
- Install the AVR Tools needed for compiling for and flashing to the chip with bash makeflash_tmk_dreymar.sh -a
- Install Git & Hasu's GitHub TMK repository with bash makeflash_dreymar_tmk.sh -g (if you have Git/TMK already, it'll update them)
- Make sure my repo is in place relative to the TMK one as described above, and open a terminal there
- Now you're ready to Build and flash HEX files from TMK code. To simply build the default keymap as set in keymap_dreymar.c, use:
$> ./makeflash_dreymar_tmk.sh
See the Keymap Configuration section below for more info on getting a HEX file that suits you, and the Device Flashing section for how to program your device with the HEX file.
The Windows 10 64-bit Anniversary Edition had an exciting addition: A Ubuntu GNU/Linux "Subsystem" running a BASH command line terminal! This is capable of compiling the TMK code just like a Linux machine. In the beta version it couldn't yet flash to a device as dfu-programmer wasn't working – but you could always use Windows-based flashing tools for that.
Since then, the WSL (Windows Subsystem for Linux) has become a standard app available in the Microsoft Store. I recommend using WSL2; it seems much better than the older ones.
Hasu had some instructions on how to use BASH on Windows 10 for TMK compiling. Here's a little run-through:
- Get Windows Subsystem for Linux 2 (WSL2) from Microsoft.
- Start the WSL terminal
- Start Menu → Ubuntu (or whatever you chose); you'll have to finish the install and choose a username/pwd the first time.
- Navigate to a suitable folder and follow the step-by-step procedure above to install AVR tools, make, git and TMK and get going!
- At /mnt/c/ you'll find the C:\ drive; you have access to the same file system as Windows does.
- If you have my files in a different location from the main tmk ones, you can use a symbolic link to make my script see the tmk dir.
The above should work directly for any ATmega32U4-based controllers. TMK works for several types of keyboard controllers and converters; look inside the TMK dirs for more info. The map files I use now are in the Unimap format, which should work with all TMK compatible controllers.
I've tested Hasu's PS/2-USB converter. For that device, be aware of the following:
- This converter uses the ATmega32U2 chip (for now). If flashing with FLIP, set its device selection accordingly.
- To compile for the PS/2-USB converter with my script, use the following switches:
$> ./makeflash_dreymar_tmk.sh -d converter/ps2_usb/ -m Makefile.unimap.rev2
This section shows how to get the keymap HEX file you want. How to compile TMK or other code is described here.
If you wish to delve deeply into keymap editing, make sure you've read at least Hasu's Keymap and Layers ReadMe. It and other docs are found in the tmk_keyboard/tmk_core/doc dir of his GitHub repo.
I've provided some .hex files with my download, but I can't make every combination of options as that'd take a lot of my time. If you're lucky, you'll find what you need and then you don't have to build your own HEX file. There may be other such files available from other sources, too.
My provided pre-compiled HEX files are:
- QWE-Tarmak-Cmk_All_Extend: A full progression from QWERTY via Tarmak 1–4 to Colemak, with Extend, without any ergonomic mods ("vanilla").
- QWE-Tarmak-Cmk_CurlAWideISO_Extend: A full Tarmak progression as above, with Extend and the Curl(DH)AngleWide-ISO ergo mods.
So you could use these files to:
- Learn Colemak or Colemak-CAW with as many Tarmak steps as you like (0–4),
- Type Tarmak#, Colemak or Colemak-CAW with Extend, or just
- Type QWERTY with Extend and optionally the AngleWide-ISO ergo mod (the Curl mod does not apply to QWERTY)
If you find a ready-made HEX file, make sure it's built for the right chip. The Hasu USB-2-USB device currently uses Atmel ATmega32U4.
Hasu's Online TMK Keymap Editor for the USB to USB converter will let you make .hex files you can save and use for flashing your ATmega32U4 device. If you need a simple keymap that I haven't made already, this may be the easiest way of getting it.
Fig.: Hasu's Online keymap editor, showing two different layers and key panels.
You can make up to 7 layers with this, only by clicking the keys you want into place. The NO code deactivates a key, and the TRNS code lets whatever is in active lower layers "shine through". There's a tab of layer switching functions too. Just mess around with it, it's fun.
To make modified key strokes and other fancy stuff, there's a Code Edit tab. To understand it, read Hasu's TMK Keymap guide.
You can also output C/JSON/etc code that you may compile manually for other devices, but you can't easily use that code for tweaking layouts, since it'll only give you hex codes for all the keys so unless you happen to know the right numbers you'll get a big headache trying to figure that out.
Here's an online editor example if you want a quick Big Bag starting point: My Colemak-CAW layout with two Extend layers. You can also import one of the precompiled HEX files into it if you want.
Note: There's also an older version of the online editor, but that didn't support modified keys.
If you've followed the Download and Install section above, by now you should have a copy of Hasu's TMK repo with my usb_usb files inside its converter/usb_usb directory and a terminal open to that directory.
In addition to installing, my shell script makeflash_dreymar_tmk.sh run in Linux can:
- Build a HEX file (default name is usb_usb_unimap.hex) for flashing to your device, using Hasu's Makefile
- Flash a HEX file to a device in Bootloader mode (or you may take the file to Windows and do it with Atmel FLIP instead)
- Clean up all the files from a build/compilation; note that this also removes the .hex file unless you've renamed or moved it
Run it with a keymap file's name (unimap_.c) to optionally choose a non-default keymap file (the default is 'dreymar'):
$> bash makeflash_dreymar_tmk.sh []
If you run the script with -h, you'll see the default values for which directory to use and what the file will be called etc. For an example, see the Install section above.
I've provided a unimap_dreymar.c file with several keymaps/layouts in, and a unimap_dreymar.h file that mostly holds keymap types for the Angle/Wide ergo mods. For normal purposes, the unimap_dreymar.c file will be the one you want to edit to get the layout(s) you want. Use any editor (as long as it preserves character encoding) to edit the file in your local tmk_keyboard/converter/usb_usb directory before building the HEX file as described above.
The default layer is layer0; this will always be active when the device is activated. I've used layer1 for a second layout and added a layer-toggle key (ScrollLock by default) to go back and forth between two layouts. Layer2+ are intended for Extend layers but only layers 2–3 are in use for now.
The layout options are chosen with preprocessor directives; you can edit the values of the #define lines before compiling to produce different .hex files as you like.
"Physical" keymap type settings (Angle/Wide ergo mods) in unimap_dreymar.c; see below if you want to edit these in unimap_dreymar.h:
/* Edit '_########' in the UNIMAPLAYOUT definiton below to choose ergonomic Curl/Angle/Wide keyboard mods:
* _NOMODS - Standard Unimap format for all keyboard and converter types (w/o F13-24; this one is without ergo mods)
* _ISO_A_ - ISO/Int Angle (the simple lower left half-row shift)
* _ISO_AW - ISO/Int Angle-Wide(/)
* _ANS_A_ - ANSI/US Angle(Z)
* _ANS_AW - ANSI/US Angle(Z)-Wide(')
* _AWINGA - ANSI/US A-Wing Angle (rarely used)
*
* Select an ergo modded keymap, or the plain unmodded Unimap. Note that these maps affect all layouts and layers.
* For Curl(DH), you also need to set CURLMOD. For Sym mods, set SYMBOLKEYS according to keymap.
* To get, say, the Colemak-CAWS (CurlAngleWideSym) layout on ISO/ANSI, use the _###_AW keymap with
* ACTIVELAYOUT 5, CURLMOD 1 and SYMBOLKEYS 2/3 settings below. And CAPSBEHAVIOR 1 for Extend, of course!
*/
#define UNIMAPLAYOUT(...) UNIMAP_ANS_AW( __VA_ARGS__ ) /* AngleWide-ANSI keymap */
For layouts and layout options, the directives will select which pieces of code below to actually compile so you get what you want.
/* Define the ACTIVELAYOUT (and CURLMOD) constant(s) to choose the layer0 layout:
* 0 : QWERTY
* 1-#: Tarmak1 - transitional Colemak (supports CURLMOD; see below)
* 2-#: Tarmak2 - transitional Colemak (--"--)
* 3-#: Tarmak3 - transitional Colemak (--"--)
* 4-#: Tarmak4 - transitional Colemak (--"--)
* 5-0: Colemak
* 5-1: Colemak Curl-DH (requires a CurlAngle keymap; see above)
* 6-#: Mirrored Colemak (normally used as second layout with a layer switch)
* 7 : Dvorak (only recommended if you already use it)
* 8 : Canary (Colemak-like layout; changes more keys, less implemented)
*/
#define ACTIVELAYOUT 5 /* LAY_COLEMAK */
/* Define the SECONDLAYOUT (and CURLMOD) constant(s) to choose the layer1 switch layout:
* 0 : Unmodded QWERTY is the default; otherwise:
* 1 : QWERTY with any active ergo mods (AngleWide etc)
* 2-#: Colemak (if you want something else, replace it in the code between the 'REPLACE THE SECOND LAYOUT...' lines)
* 3-#: Colemak Mirrored as second layout for one-handed typing (needs an accessible switch key!)
* NOTE: The "FSLk" key is a layer1 toggle or switch (select which below), normally used on the ScrollLock key.
* You may swap, e.g., LALT, RGUI or another key with FSLk in your active layout to use that key instead.
*/
#define SECONDLAYOUT 0 /* SEC_VANQWERTY */
/* The CURLMOD options for Colemak and Tarmak layouts are:
* 0: No Curl - "vanilla" Colemak/Tarmak
* 1: SteveP99's original Curl(DHm) ergo mod, bringing D/H down but M to the home row. DH standard since Oct 2020.
*
* N/A: The 2017 Curl(DHk) ergo mod, bringing the D and H keys down to comfortable bottom-row positions (QWERTY C/M)
* (Some row-staggered board users may like the DHk variant, but the DHm standard is good for all board types.)
* N/A: DreymaR's old Curl(DvH) mod, bringing DH center-down to the QWERTY V/N keys.
* (If you somehow wish to keep ZXCV together as in my old Curl(DvH) mod, edit the maps manually.)
*
* NOTE: On the first Tarmak step, the CURLMOD setting doesn't matter. If you want to swap H and M early, edit it in.
* For the other steps, CURLMOD still doesn't move H-M so Curl(DH) users by default will do H-M in the last step.
* An extra baby step after Tarmak1 could be transitioning to an Angle(Wide) keymap/model before Tarmak2.
*/
#define CURLMOD 1 /* CURL_DH */
/* The SYMBOLKEYS options for layouts are:
* 0: No Symbol key changes - "vanilla" Colemak or whatever
* 1: Sym mod for non-Wide ergo mods
* 2: Sym mod for Wide mod combos on ISO keyboards
* 3: Sym mod for Wide mod combos on ANSI keyboards
*
* Adaptations for ANSI-ISO and locale key differences (more info below):
* 4 : Some keys are made four-level: AltGr+ sends Unicode glyphs (by OS specific input method)
* 5 : DreymaR's ISO-Nor hack, moving some keys to make the Norwegian layout more like ANSI/US
*/
#define SYMBOLKEYS 0 /* SYM_NONE */
/* The CAPSBEHAVIOR constant chooses Caps key action, including the powerful Extend layer switch:
* 0: CapsLock (unchanged)
* 1: Extend modifier (uses a little more layout memory, but it's by far the most powerful option IMNSHO!)
* 2: BackSpace (for vanilla Colemak or otherwise; a decent choice but Extend is better!)
* 3: LCtrl
* 4: Esc
* NOTE: To move modifiers, edit the layouts or the appropriate UNIMAP_### in my .h file (e.g., swapping CAPS and #ALT).
* NOTE: Depending on your keyboard's scan matrix(?), chorded Extend modifiers such as Ext1+S+T+N for Shift+Ctrl+Left
* may not work. With Caps=Ext1, I've had trouble with Ext1+S+T+N; with LAlt=Ext1 even Ext1+S+N didn't work!
*/
#define CAPSBEHAVIOR 1 /* CAPS_EXTEND */
/* The EXT#BIT constants with the main Extend key (Caps by default) select Extend# layers in the EXTENDER user function:
* Ext1 on Caps alone : Navigation/editing/multimedia
* Ext2 on Ext2+Caps : NumPad/Navigation
* Ext3 on Ext3+Caps : TODO
* Ext4 on Ext2+Ext3+Caps : TODO
* NOTE: Alt keys as Extend# selectors failed, as AltUp activates Win menus even when the mod is turned off?!
* - It should be possible to write an Alt user function that doesn't release Alt when Ext has been pressed.
*/
#define EXT2BIT MOD_BIT(KC_RSFT) /* Ext2+Ext selects Extend2 */
#define EXT3BIT MOD_BIT(KC_RCTL) /* Ext3+Ext selects Extend3 */
/* The STICKYMODS constant chooses LShift, RShift and RCtrl key behavior (I chose to leave LCtrl alone):
* 0: Normal Shift/Ctrl (default)
* 1: Sticky Shift only
* 2: Sticky Ctrl only
* 3: Sticky Shift & Ctrl
* NOTE: In the unimap_dreymar.h file, some relevant constants normally set in config.h are (re)set:
* - ONESHOT_TIMEOUT max delay (in ms) before a oneshot/sticky modifier is ignored
* - TAPPING_TERM max time a key may be held down for it to register as tapped, not held
*/
#define STICKYMODS 1 /* STICKY_SHFT */
/* The SLCKBEHAVIOR constant chooses ScrollLock key action:
* 0: Normal ScrollLock (default)
* 1: Layer 1 toggle key (toggles the second layout)
* 2: Layer 1 switch key (layer shift; e.g., for mirrored typing if you can use it as "ghetto" foot switch)
*/
#define SLCKBEHAVIOR 1 /* SLCK_L1TOGGLE */
/* The PAUSBEHAVIOR constant chooses Pause/Break key action:
* 0: Normal Pause/Break (default)
* 1: Win/GUI key (useful for 101/104-key boards that have no GUI key)
*/
#define PAUSBEHAVIOR 0 /* PAUS_PAUS */
It is of course entirely possible to edit the layouts themselves directly. It should be fairly intuitive how to do that. See the TMK keycode.txt file for a list of all key codes (layouts use the 3–4 letter versions).
CapsLock, LAlt, RAlt and some other keys are defined as Fn## keys in the layouts. At the start of the file there's a bunch of action definitions for these.
Below are some examples from an unimap file:
# define AC_FTab ACTION_LAYER_TAP_KEY(2, KC_TAB) // FTab (Tab key) as Ext2 – tap for Tab (for now)
# define AC_FnLA ACTION_KEY(KC_LALT) // FnLA (LAlt key) as usual (for now)
# define AC_FnRA ACTION_KEY(KC_RALT) // FnRA (RAlt key) as usual (for now)
//# define AC_FnU1 ACTION_MODS_KEY(MOD_LGUI, KC_T) // FnU1 (`) as Win+T
# define AC_FnU1 ACTION_MACRO(TYPESTR1) // FnU1 as user macro: Type a string
In the above:
- FTab, mapped to the Tab key (TAB) in my layouts, activates layer 2 (Ext2) while held down, and sends the TAB key code if tapped. – The Tab key is quite handy as a dual-role modifier, but unfortunately it loses its repeat functionality this way. – ISO keyboard users might want to use the key instead; its code is NUBS ("Non-US Backslash").
- FnLA and FnRA, similarly, are my versions of the LAlt and RAlt keys. But for now, their defined actions are mostly to be their normal selves!
- AC_FnU1 is a user macro key that I put on Extend+Tilde/Grave. It's macro is defined at the end of the file; in this case it types out a boilerplate text (my email footer).
- Commented out above, is an alternative definition for FnU1: Sending a LWin+T keystroke instead (in Windows, this brings you to the menu line).
Here's an ergo remapping from the unimap_dreymar.h file; this one's (the lower part of) the UNIMAP_ISO_A
Angle-ISO mod. Note how ZXCVB have moved:
ESC_, _F1_,_F2_,_F3_,_F4_, _F5_,_F6_,_F7_,_F8_, _F9_,F10_,F11_,F12_, PSCR,SCLK,PAUS, VOLD,VOLU,MUTE, \
GRV_,N1_1,N2_2,N3_3,N4_4,N5_5,N6_6,N7_7,N8_8,N9_9,Na_0,NbMN,NcEQ,JYEN,BSPC, INS_,HOME,PGUP, NLCK,PSLS,PAST,PMNS, \
TAB_ ,U1_Q,U2_W,U3_E,U4_R,U5_T,U6_Y,U7_U,U8_I,U9_O,Ua_P,UbLB,UcRB, BSLS, DEL_,END_,PGDN, _P7_,_P8_,_P9_,PPLS, \
CAPS ,H1_A,H2_S,H3_D,H4_F,H5_G,H6_H,H7_J,H8_K,H9_L,HaSC,HbQU,HcHS, ENT_, _P4_,_P5_,_P6_,PCMM, \
LSFT ,L1_Z,L2_X,L3_C,L4_V,L5_B,L0LG,L6_N,L7_M,L8CM,L9DT,LaSL,JROM, RSFT, _UP_, _P1_,_P2_,_P3_,PENT, \
LCTL ,LGUI,LALT,JMHE, SPC_ ,JHEN,JKAN,RALT,RGUI,APP_, RCTL, LEFT,DOWN,RGHT, _P0_ ,PDOT,PEQL \
This section shows how to flash your HEX file to a USB-2-USB device and get it ready for typing. See the sections above for how to prepare the device and get the HEX file you want.
NOTE: Flashing with a keyboard plugged into the device may be safe in most cases. But I got trouble with one keyboard (IBM/Unicomp Model M) after using FLIP for flashing with it inserted; it seems like the drivers or registry entry got corrupted somehow because now it won't mount on that PC anymore even though it's quite okay on other machines. Be warned.
My script run with the -f option flashes the generated HEX file to a connected device using DFU-Programmer; if you've already made the .hex file use -b to skip rebuilding it. If you want to flash without using my script, you could use the 'make dfu' command inside the usb_usb directory, or look inside the script to see how I did it.
According to the TMK wiki build FAQ, you'll need admin/sudo rights for the 'dfu-programmer' command (there's a workaround using udev rules, but it's a bit techy). I've tried flashing without sudo and it worked for me in one case but not another. If you do need sudo, run makeflash like this:
$> sudo ./makeflash_dreymar_tmk.sh -bf
NOTE: You do not generally want to build your files as root! Then you'll be in trouble if you try to clean up as non-root afterwards. So run MakeFlash twice, once with normal privileges to build your .hex file and the other time with -b (to not build again) and -f (to flash) with sudo/root privileges.
If you're using BASH on Windows 10 (beta), dfu-programmer won't work yet, due to a problem with mounting USB devices in general (libusb). Use Windows native tools instead, such as FLIP or dfu-programmer for Windows. For updated WSL installs, this probably isn't a problem anymore.
If you have another device, you may need some other method and more tools. As mentioned at the start of this page, there are help files you may consult for this.
I used to flash with Atmel FLIP on Windows instead of under Linux: It gives you more feedback and intuitive control with the process. If you compiled your HEX file on Linux you must make it available for the Windows file system to use Windows FLIP. Using newer WSL, this is easy. Earlier, I put the whole TMK repository in a shared folder that both Windows and my virtual Linux machine can see; you could also move it on a USB drive or copy-paste from a Virtual Machine if your VM settings allow this.
Atmel FLIP has been difficult for me, as it doesn't seem to find an updated Java version on my system. You may prefer other flashing tools. Lately I've used the QMK Toolbox on Windows. It works great. Some of the other tools work in a way quite similar to FLIP, so the instructions below may prove instructive to you no matter what.
- Select the right chip (fig 5–1). For the Hasu device, it's ATmega32U4. Verify the chip type (fig 5–a).
- Connect to the device in Bootloader mode. Select USB connection (fig 5–2) then Open. Verify the connection (fig 5–c).
- Load a HEX file (fig 5–3). Use shared folders, a USB disk or some other way of accessing the file with Windows.
- Verify for ATmega32U4 which only has 32kB memory minus 4 kB bootloader, that the file size is below 28480 bytes (fig 5–b).
- Flash the device (fig 5–4). Make sure all options are on as shown, then press "Run".
- Activate the device (fig 5–5). Press "Start Application". Reset should be checked.
- Test the device. You may have to plug it out and in again first. Then, plug a keyboard to the device and type away.
Fig. 5: Atmel FLIP for Windows. 1) Select chip (a); 2) Connect (c); 3) Load HEX file (b); 4) Flash device; 5) Start device
I won't cover all possibilities here. I use Hasu's converters myself and haven't got any experience with others, but the possibilities are many.
One little note: I've experienced that my Hasu device doesn't provide enough power to drive all keyboards, such as some fancy ones with RGB LEDs. I'm guessing there isn't much to be done about it? Mostly, I use my device with ordinary keyboards and it works perfectly.
A Pro Micro (such as the one seen above by GeekHack user Yangdigi) may be cheapest, but it also seems to be the most techy option?
Colemak forum user Darkness made a device and his own code for it, see his "Arduino-based hardware keyboard remapper" topic for more info. Scroll down that page for pictures and a nice how-to sum-up post. He started off with an Arduino Leonardo like the one to the left in Yangdigi's image above; this can be a good development platform if you have one. But for a more useful implementation, he uses an Arduino Teensy 2.0 as seen below. Hasu has tried his TMK code on this device and it seems to be working fine.
Darkness's Teensy-based USB-2-USB Converter (see his topic)
I'm really hoping that Teensy 3.5/3.6 or a similar chip can be used for TMK! These devices are fast, have a lot more Flash/RAM (512/192 kB for 3.5; 1024/256 kB for 3.6) and most importantly, come with a second USB intended for Host mode so it won't need a separate USB host! That may make it a cheap and powerful option; someone will hopefully test this soon.
The safest and easiest option may be to order the brilliant USB to USB Converter from GeekHack user Hasu, who has also developed the TMK software for converting keyboards to more awesome keyboards. (Hasu's device is also available from 1UpKeyboards which has a web shop but at a higher price from what I can see.) I've got a few of these beauties, and my code, instructions and .hex definition files below are based on Hasu's device although they may be used for other devices too (may need some geeky tweaking).
Hasu's USB to USB Converter for TMK Key mapping (original photo by Nick J Bair)
Oh look, Hasu has other converters and keyboard controllers too!
Here's a PS/2-to-USB converter making my friend's vintage IBM Model M board awesome.
This topic won't show you any more about how to get your own QUICKIE USB-2-USB device. From my own experience I can heartily recommend Hasu's products, but find out what works for you. Best of luck, either way!
@GeekHack:
- Hasu's USB to USB converter topic, and
- Hasu's converter buying topic
- Hasu's TMK topic (code basis for keyboard controllers/converters in general)
- NJBair's review of Hasu's USB-2-USB converter, with
- a nice FLIP guide
- YangDigi's Pro Micro DIY converter topic (some Teensy info too)
@GitHub:
- Hasu's GitHub TMK repository, and its
- USB-2-USB section
- Hasu's Build FAQ,
- Build README, and
- keymap README
- NJBair's repository including some build/flash info
- Hasu's TMK Keyboard Wiki with much useful info
@TMK_site:
@Colemak:
@QMK:
- QMK (Quantum Mechanical Keyboard) is a TMK-fork-gone-solo that deserves honorable mention
- The GitHub QMK repository (I don't use QMK myself, but it has a lot of documentation and more)
Flashing tools:
- QMK Toolbox; "a collection of flashing tools packaged into one app. It supports auto-detection and auto-flashing of firmware to keyboards."
- On Windows: Asked whether to install drivers. Successfully installed a driver for the Hasu device. It showed up in Device Manager as "Atmel USB Devices -> ATmega32U4".
- DFU-programmer; "an implementation of the Device Firmware Upgrade class USB driver that enables (...) Atmel chips."
- This is a commonly used flashing tool on Linux.
- kp_boot_32u4; "a simple bootloader for the ATmega32u4 family (...). The code size is <1kB and doesn't need drivers on Windows."
- Command-line-based. Seems compact enough? Installed w/ a Python script. Apparently, KeyPlus below uses it?
- KeyPlus; "an easy to use keyboard firmware (...) in beta". Precompiled, w/ a GUI.
- On Windows: Didn't find my Hasu (atmega23u4) device, at least not right away...?
- 2016-07: Now witness the typing power of this fully operational USB-2-USB device! Happy hacking, brave and adventurous souls!
- 2018-01: Added a user function that allows for input of Unicode glyphs not in the layout using the AltGr(RAlt) modifier.
- 2018-02: More advanced modifiers for Extend2+. Hold down, e.g., RShift then Caps (then release RShift) for Extend2. Can't use Alt keys (yet) on Win.
- 2023-11: Added Sym mods. Removed Workman, DHk and Curl keymaps (made Extend respect CURLMOD instead). Added the Canary layout.
- Extend modifiers don't always stack? Caps+S+T+N didn't produce Ctrl+Shift+Left but ST keystrokes for me once; others have had no such problems.
- Use the ScrollLock LED to show whether the second layout is active?
- Port the BigBag4USB to the more popular QMK code platform? Does QMK support Hasu's USB-2-USB device?
My Unicomp SpaceSaver Buckling Spring (IBM Model M ISO type) keyboard with "American/Ninja" caps, splendidly sporting the Colemak-CAW layout.