SKR is a low level, low latency way to remap keys. Some of the features of SKR are:
- Remap keys
- Remap keys to run a shell command or script
- Remap keys to run a sequences of keys, commands, and scripts (A.K.A Macro) (needs documentation but it's there)
- Function Layers
- Multiple keyboard support
SKR sits very low in the keyboard stack just above the kernel. Thus, it is independent of display protocol, desktop environment, or window manager. It even works in tty.
Install skr from the aur with the package skr-git
example using yay AUR helper
yay -S skr-git
First install interception-tools and git
sudo apt install git libudev-dev libevdev-dev libyaml-cpp-dev cmake build-essential
git clone https://gitlab.com/interception/linux/tools.git
cd tools
mkdir build
cd build
cmake ..
make
sudo make install
cd
Install skr
git clone https://github.com/DavRack/skr.git
cd skr
./install.sh
First install interception-tools and git
sudo dnf install git cmake yaml-cpp-devel libevdev-devel systemd-devel gcc-c++ @development-tools
git clone https://gitlab.com/interception/linux/tools.git
cd tools
mkdir build
cd build
cmake ..
make
sudo make install
cd
Install skr
git clone https://github.com/DavRack/skr.git
cd skr
./install.sh
./install.sh -u
SKR is configured through ~/.config/skr/skr.config. You can find an example config file here
Once skr is installed, run:
skr --init
This command will prompt you to press a key. skr will find the path of the keyboard used to press the key and will create a config file
First we need to define the keyboard path for skr to intercept:
if you ran skr --init, the keyboard path will have already been defined
KeyboardPath -> /dev/input/event3
A key remap makes a key behave like it is another. It uses the following syntax:
[keyToRemap] -> [targetKey]
Example: Remap CapsLock to Esc
CapsLock -> Esc
skr takes its key names from /usr/include/linux/input-event-codes.h
Here's a key code table with all valid key names: keycode table
A key swap remaps two keys to each other. It uses the following syntax:
[Key1] <-> [Key2]
This is equivalent to the following remaps
[Key1] -> [Key2]
[Key2] -> [Key1]
Example: Swap Meta/Super ("Windows" key) with left alt:
META <-> ALT
SKR can map a key to a script or shell command. It uses the following syntax:
[KeyToRemap] -> Script=[your command or full path to a script]
Example: log memory usage to a file located in /tmp/memlog
[KeyToRemap] -> Script=free -h > /tmp/memlog
Warning! all commands launched from skr will be executed as root
A layer is a set of additional key bindings that can be reached by holding down a key. It is easier to understand with an example:
Let's say you want to use H J K L as arrow keys (vim style). You can use capsLock as your fnKey When you hold it down and press H, J, K, or L they will act as arrow keys. When the fnKey is not held, H J K L will work normally.
The syntax for layers is:
NewLayer -> [fnKey]
# all remaps after NewLayer will only activate when [fnKey] is held down
# remap 1
# remap 2
.
.
.
# you can define multiple layers
NewLayer -> [fnKey2]
# all remaps after NewLayer will activate when [fnKey2] is hold down
# remap 1
# remap 2
.
.
.
The HJKL example would be written like this:
NewLayer -> CapsLock
H -> LEFT
J -> DOWN
K -> UP
L -> RIGHT
-
When a Layer is defined, its function key stops working as a normal key
-
You can define anything inside a layer: remaps, scripts, and macros
To run skr on boot first we need to create a unit file at
/etc/systemd/system/[email protected]
with the following content:
[Unit]
Description=Low-Level key remapping
[Service]
User=root
Environment=USER=%i
Environment=SUDO_USER=%i
ExecStart=/usr/bin/skr
[Install]
WantedBy=multi-user.target
Then enable the unit by running:
replace your username where indicated
sudo systemctl enable [email protected]
This will start the service at boot. To start skr immediately, run:
sudo systemctl enable --now [email protected]
-
sudo
If you like my work you can send me crypto using these wallets:
BTC: 17u6NAodc6GrQPRGNy92xF6pmzDFaq2EuC
ETH: 0xa85c356d396A80Afc49B6B281E4a9a897fdfa152
- MD custom macros
- Don't run non sudo commands as root
- Remove dependencies