# caps2esc _Transforming the most useless key **ever** in the most useful one._ _For vi/Vim/NeoVim addicts at least_. ADM-3A terminal ## What is it? - **Put what's useless in its place** _By moving the CAPSLOCK function to the far ESC location_ - **Make what's useful comfortably present, just below your Pinky** _By moving both ESC and CTRL functions to the CAPSLOCK location_ ## Why?! Because CAPSLOCK is just "right there" and making it CTRL when key-chording and ESC when pressed alone is quite handy, specially in vi. ## Dependencies - [Interception Tools][interception-tools] ## Building ``` $ git clone git@gitlab.com:interception/linux/plugins/caps2esc.git $ cd caps2esc $ cmake -B build -DCMAKE_BUILD_TYPE=Release $ cmake --build build ``` ## Execution ``` caps2esc - transforming the most useless key ever in the most useful one usage: caps2esc [-h] [-m mode] [-t delay] options: -h show this message and exit -t delay used for key sequences (default: 20000 microseconds) -m mode 0: default - caps as esc/ctrl - esc as caps 1: minimal - caps as esc/ctrl 2: useful on 60% layouts - caps as esc/ctrl - esc as grave accent - grave accent as caps ``` `caps2esc` is an [_Interception Tools_][interception-tools] plugin. A suggested `udevmon` job configuration is: ```yaml - JOB: intercept -g $DEVNODE | caps2esc | uinput -d $DEVNODE DEVICE: EVENTS: EV_KEY: [KEY_CAPSLOCK, KEY_ESC] ``` For more information about the [_Interception Tools_][interception-tools], check the project's website. ## Mouse button support After _Interception Tools_ 0.3, `caps2esc` can work with mouse clicks. An example configuration taken from my laptop: ```yaml SHELL: [zsh, -c] --- - JOB: mux -c caps2esc - JOB: - intercept -g $DEVNODE | mux -o caps2esc - mux -i caps2esc | caps2esc | uinput -d $DEVNODE DEVICE: LINK: /dev/input/by-path/platform-i8042-serio-0-event-kbd - JOB: - intercept $DEVNODE | mux -o caps2esc DEVICE: LINK: /dev/input/by-path/platform-i8042-serio-4-event-mouse ``` For more information on the topic, check the [_Interception Tools_ README][interception-tools] about usage of the `mux` tool and device specific setups, and [this discussion][issue-9-note] for more examples. ## Installation It's available from [community](https://archlinux.org/packages/community/x86_64/interception-caps2esc/): ``` $ pacman -S interception-caps2esc ``` I don't use Ubuntu and recommend Archlinux instead, as it provides the AUR, so I don't maintain PPAs. For more information on Ubuntu/Debian installation check this: - ## Caveats As always, there's always a caveat: - `intercept -g` will "grab" the detected devices for exclusive access. - If you tweak your key repeat settings, check whether they get reset. Please check [this report][key-repeat-fix] about the resolution. ## History I can't recall when I started using CAPSLOCK as both ESC and CTRL but it has been quite some time already. It started when I was on OS X where it was quite easy to achieve using the [Karabiner][], which already provides an option to turn CTRL into ESC/CTRL (which can be coupled with OS X system settings that turn CAPSLOCK into CTRL). Moving on, permanently making Linux my home, I searched and tweaked a similar solution based on [xmodmap][] and [xcape][]: - It's a simple solution but with many annoying drawbacks I couldn't stand in the end: - It resets any time a device change happens (bluetooth, usb, any) or the laptop lid is closed or when logging off and needs to be re-executed. - It depends on [X][]. Doesn't work on TTY (bare terminal based machine, CTRL-ALT F2, etc). Meanwhile on Windows land, I had a definitive solution based on my [Interception library][interception] that always works perfectly, no hiccups. It made me envy enough, so I ported the [Windows Interception caps2esc][caps2esc-windows] sample to Linux based upon the [_Interception Tools_][interception-tools]. ## License MIT Copyright © 2017 Francisco Lopes da Silva [caps2esc-windows]: https://github.com/oblitum/Interception/blob/master/samples/caps2esc/caps2esc.cpp [karabiner]: https://pqrs.org/osx/karabiner/ [xmodmap]: https://www.x.org/releases/X11R7.7/doc/man/man1/xmodmap.1.xhtml [xcape]: https://github.com/alols/xcape [x]: https://www.x.org [interception]: https://github.com/oblitum/Interception [interception-tools]: https://gitlab.com/interception/linux/tools [issue-9-note]: https://gitlab.com/interception/linux/plugins/caps2esc/-/issues/9#note_474942893 [key-repeat-fix]: https://github.com/oblitum/caps2esc/issues/1