SkillAgentSearch skills...

Map2

Linux input remapping for your keyboard, mouse and more!

Install / Use

/learn @shiro/Map2
About this skill

Quality Score

0/100

Supported Platforms

Universal

README

<div align="center"> <h1>map2</h1> <h3>Linux input remapping<br />Remap your keyboard, mouse, controller and more!</h3>

GitHub MIT License Discord Build Donate

</div>

Want to remap your input devices like keyboards, mice, controllers and more?
There's nothing you can't remap with map2!

  • 🖱️ Remap keys, mouse events, controllers, pedals, and more!
  • 🔧 Highly configurable, using Python
  • 🚀 Blazingly fast, written in Rust
  • 📦 Tiny install size (around 5Mb), almost no dependencies
  • ❤️ Open source, made with love

Visit our official documentation for the full feature list and API.


<div align="center"> <b>If you like open source, consider supporting</b> <br/> <br/> <a href='https://ko-fi.com/C0C3RTCCI' target='_blank'><img height='36' style='border:0px;height:36px;' src='https://storage.ko-fi.com/cdn/kofi3.png?v=3' border='0' alt='Buy Me a Coffee at ko-fi.com' /></a> </div>

Install

The easiest way is to use pip:

pip install map2

For more, check out the Install documentation.

After installing, please read the Getting started documentation.

Example

import map2

# readers intercept all keyboard inputs and forward them
reader = map2.Reader(patterns=["/dev/input/by-id/my-keyboard"])
# mappers change inputs, you can also chain multiple mappers!
mapper = map2.Mapper()
# writers create new virtual devices we can write into
writer = map2.Writer(clone_from = "/dev/input/by-id/my-keyboard")
# finally, link nodes to control the event flow
map2.link([reader, mapper, writer])

# map the "a" key to "B"
mapper.map("a", "B")

# map "CTRL + ALT + u" to "META + SHIFT + w"
mapper.map("^!u", "#+w")

# key sequences are also supported
mapper.map("s", "hello world!")

# use the full power of Python using functions
def custom_function(key, state):
  print("called custom function")

  # custom conditions and complex sequences
  if key == "d":
    return "{ctrl down}a{ctrl up}"
  return True

mapper.map("d", custom_function)

Build from source

To build from source, make sure python and rust are installed.

# create a python virtual environment
python -m venv .env
source .env/bin/activate

# build the library
maturin develop

While the virtual environment is activated, all scripts ran from this terminal will use the newly built version of map2.

Contributing

If you want to report bugs, add suggestions or help out with development please check the Discord channel and the issues page and open an issue if it doesn't exist yet.

License

MIT

Authors

Related Skills

View on GitHub
GitHub Stars126
CategoryDevelopment
Updated2mo ago
Forks10

Languages

Rust

Security Score

100/100

Audited on Jan 14, 2026

No findings