Matthew Palmer Top Articles Vanilla Rocket Kubernetes Book Standing Invitation

Remapping Keyboard Keys on Mac OS X Mavericks

This is an updated version of my original guide on how to remap keyboard keys on OS X.

Here’s how to remap any of your keyboard keys to any combination of keys on Mac OS X. Initially, I wanted to remap the Caps Lock key to Command+R for two reasons:

Here are the steps and workarounds I used to get what I wanted. I’ve essentially remapped the Insert, Home, Page Up, Delete, End and Page Down, and Caps Lock keys into a useful macro block.

  1. Download the latest version of KeyRemap4MacBook; it’s pretty much the only decent key remapper for Mac. Despite its horrible name, it is insanely flexible and powerful.
  2. Install KeyRemap4Macbook as per the instructions on their website.
  3. Download PCKeyboardHack if you want to remap the Caps Lock key.
  4. Open PCKeyboardHack (from the Launchpad), and under the Caps Lock section select Change Caps Lock.
  5. Change the keycode in the right hand column to ‘110’.
  6. Open KeyRemap4MacBook from ~/Applications.
  7. Scroll down to ‘For PC Users’, expand it, expand ‘Change PC Application Key’.
  8. Select whatever key you want the Caps Lock key to remap to (I set it to ‘Application Key to Command_L’).

Not exactly perfect, right? There’s a very limited selection of keys you can remap to. Don’t worry, with a little .xml hacking we can get it to do what we want (in a way). For those of you who are happy to just use it like this, don’t worry about the next bit. For this section, we are going to introduce user-defined key remapping.

  1. In KeyRemap4MacBook click ‘Misc & Uninstall’ in the top tab bar.
  2. Click ‘Open private.xml’ to open it in Finder.
  3. Open the private.xml file in TextEdit.
  4. Open this private.xml file in your browser. Copy and paste the code from this remote file to replace the contents of the local private.xml file.
  5. The basic syntax for adding a new remapping is this:

    <item>
    <name>SOMENAME</name>
    <identifier>private.some_name</identifier>
    <autogen>--KeyToKey-- KeyCode::STARTKEY, KeyCode::DESTINATIONKEY</autogen>
    </item>

  6. Replace STARTKEY with some key from this list. Make sure you use the uppercase name in the left column to replace KEYTOSTART. (KeyCode:: must be left as it is.)
  7. As an example, here is what I used to remap Caps Lock (i.e. PC_APPLICATION) to Command+R:

    <item>
    <name>CAPSLOCKTOCMDR</name>
    <appendix>this is to remap caps lock to cmdR</append>
    <identifier>private.swap_capslock</identifier>
    <autogen>
    --KeyToKey--
    KeyCode::PC_APPLICATION,
    KeyCode::R, ModifierFlag::COMMAND_L
    </autogen>
    </item>

  8. Save the private.xml file.
  9. Go back to KeyRemap4MacBook and hit ‘ReloadXML’ and your newly defined remaps should appear at the top of the list.
  10. Select the one you want.
  11. Try it out.
  12. Look through this page for more comprehensive documentation of what you can achieve.
  13. Keep defining new remaps until you’ve got exactly what you want.

So, eventually, we worked out a way to remap any key we want to another key or combination of keys. It works really well, and it’s probably good for RSI or something. At the very least, we’ve satisfied our laziness.

For anyone interested, here is my full private.xml file:

<?xml version="1.0"?>
<root>
<item>
<name>Swap Space and Tab</name>
<identifier>private.swap_space_and_tab</identifier>
<autogen>--KeyToKey-- KeyCode::SPACE, KeyCode::TAB</autogen>
<autogen>--KeyToKey-- KeyCode::TAB, KeyCode::SPACE</autogen>
</item>
<item>
<name>My Excel Hacks (effective only on Excel)</name>
<appendix>Change Command+2 to Ctrl+U</appendix>
<appendix>Change Control+A to Home</appendix>
<appendix>Change Control+E to End</appendix>
<identifier>private.app_excel_command2_to_ctrlu</identifier>
<only>EXCEL</only>
<autogen>--KeyToKey-- KeyCode::KEY_2, VK_COMMAND, KeyCode::U, ModifierFlag::CONTROL_L</autogen>
<autogen>--KeyToKey-- KeyCode::A, VK_CONTROL, KeyCode::HOME</autogen>
<autogen>--KeyToKey-- KeyCode::E, VK_CONTROL, KeyCode::END</autogen>
</item>
<item>
<name>My TrackPad LeftClick Hack</name>
<appendix>Command+LeftClick to F12 (only on MacBookPro2,1 Trackpad)</appendix>
<identifier>private.pointing_leftclick2f12_trackpad</identifier>
<device_only>DeviceVendor::APPLE_COMPUTER,DeviceProduct::APPLE_INTERNAL_KEYBOARD_TRACKPAD_0x021a</device_only>
<autogen>--PointingButtonToKey-- PointingButton::LEFT, VK_COMMAND, KeyCode::F12</autogen>
</item>
<item>
<name>CAPSLOCKTOCMDR</name>
<appendix>this is to remap caps lock to cmdR</append>
<identifier>private.swap_capslock</identifier>
<autogen>
--KeyToKey--
KeyCode::PC_APPLICATION,
KeyCode::R, ModifierFlag::COMMAND_L
</autogen>
</item>
<item>
<name>PGDOWNTOCMDZ</name>
<appendix>this is to remap pgdown to cmdz</append>
<identifier>private.swap_pgdown</identifier>
<autogen>
--KeyToKey--
KeyCode::PAGEDOWN,
KeyCode::Z, ModifierFlag::COMMAND_L
</autogen>
</item>
<item>
<name>endTOCMDs</name>
<appendix>this is to remap end to cmds</append>
<identifier>private.swap_end</identifier>
<autogen>
--KeyToKey--
KeyCode::END,
KeyCode::S, ModifierFlag::COMMAND_L
</autogen>
</item>
<!-- ============================================================ -->
<!-- An example of appdef -->
<appdef>
<appname>APPSTORE</appname>
<equal>com.apple.appstore</equal>
</appdef>
<item>
<name>Space to Tab on App Store.app</name>
<identifier>private.appdef</identifier>
<only>APPSTORE</only>
<autogen>--KeyToKey-- KeyCode::SPACE, KeyCode::TAB</autogen>
</item>
<!-- ============================================================ -->
<!-- An example of devicevendordef,deviceproductdef -->
<devicevendordef>
<vendorname>HEWLETT_PACKARD</vendorname>
<vendorid>0x03f0</vendorid>
</devicevendordef>
<deviceproductdef>
<productname>MY_HP_KEYBOARD</productname>
<productid>0x0224</productid>
</deviceproductdef>
<item>
<name>Space to Tab on MY_HP_KEYBOARD</name>
<identifier>private.deviceproductdef</identifier>
<device_only>DeviceVendor::HEWLETT_PACKARD, DeviceProduct::MY_HP_KEYBOARD</device_only>
<autogen>--KeyToKey-- KeyCode::SPACE, KeyCode::TAB</autogen>
</item>
<!-- ============================================================ -->
</root>

For more information on the full power of the private.xml file, check out the reference manual (thanks to @jnlevitan for the tip).

I’d love to hear your favourite key remappings, feel free to share them with me on Twitter.

My products
💅 Vanilla – hide icons from your Mac menu bar for free
🚀 Rocket – super-fast emoji shortcuts everywhere on Mac… :clap: → 👏
Horo – the best free timer app for Mac
📂 FastFolderFinder – a lightning-fast launchbar app for folders and apps
📖 Kubernetes – my book on Kubernetes for web app developers
😄 Emoji Bullet List – easily emojify your bullet point lists (like this one!)

Jump on my email list to get sent the stuff that’s too raunchy for the blog.
(Seriously though, it’s an occasional update on apps I’ve built and posts I’ve written recently.)