Skip to content

Latest commit

 

History

History
118 lines (83 loc) · 3.85 KB

README.md

File metadata and controls

118 lines (83 loc) · 3.85 KB

tmux-keybtest

tmux-keybtest is a utility for identifying which key sequences tmux can detect in your terminal. When you press a key, its tmux name, like C-M-Up, will be displayed on the status line if recognized.

Terminals can sometimes misinterpret key presses, generating the wrong sequence or nothing at all. tmux-keybtest helps you evaluate which keys are available in your current terminal and can assist in selecting a terminal with better support for key sequences.

Note: If your operating system or terminal has already bound certain keys, tmux may not detect them. It may be possible to reconfigure your system or terminal to free up these keys for tmux use.

Currently, support is provided for basic alphabetic characters (a-z) and Swedish umlauts (å, ä, ö). If your keyboard includes other language-specific characters or special symbols that aren't recognized, please let me know, and I'll be happy to add support for them.

All other keys found on a standard US keyboard, such as punctuation marks and symbols, are already handled and do not require additional definitions.

Usage

  1. Clone this repository and navigate to its directory.
  2. Run keybtest.sh to start a tmux session that will display the tmux notation for any recognized key press.

Important Notes

  • Some keys might not send the intended sequence, causing tmux to interpret them differently.
  • Avoid running this script inside an existing tmux session, as this may interfere with key detection.
  • To exit the session, press C-x C-x. The exit sequence is displayed in the status line for convenience.

tmux Key Name Prefixes

  • S- : Shift key is pressed.
  • C- : Control key is pressed.
  • M- : Alt (Meta) key is pressed.

Use the key names displayed to customize your tmux.conf according to your terminal's capabilities.

Keys Not Tested

Shift S-

  • Shifted regular keys are not tested. Instead of binding S-a or S-A, use A.

Control C-

  • Cannot be bound: ~ $ % & * { } | "
  • Case is ignored: Binding C-A after C-a will override C-a, so only lowercase is bound.
  • Keys skipped due to collision:
    • C-i is the same as Tab
    • C-m is the same as Enter
    • C-[ is the same as Escape

Control Shift C-S-

  • Regular keys not tested, same as with S-.

Meta Shift M-S-

  • Regular keys not tested, same as with S-.

Control Meta C-M-

  • Cannot be bound: ~ $ % & * { } | "
  • Case is ignored: Binding C-M-A after C-M-a will override C-M-a, so only lowercase is bound.
  • Keys skipped due to collision:
    • C-M-i is the same as C-M-tab
    • C-M-m is the same as C-M-Enter
    • C-M-[ is the same as C-M-Escape

Control Meta Shift C-M-S-

  • Cannot be bound: ~ $ % & * { } | "
  • No lowercase keys are bound due to the use of Shift.

Additional Information

  • Insert is referred to as IC and Delete as DC in tmux. If you see these, the terminal is functioning correctly.
  • If a key generates an unrecognized code, the terminal might beep. Consider muting your sound before running this in public spaces.
  • Unrecognized keys will be printed. Please submit such outputs as an issue, including the key/sequence and, if possible, your keyboard type.

Handling Terminals That Can't Send Correct Sequences

If a terminal generates a sequence that tmux recognizes but is not the intended one (e.g., Alt+Up generates S-F3), bind the desired action to the detected sequence (S-F3).

If a terminal generates an unrecognized but unique sequence, you can bind it to an action using user-keys. Tmux requires octal notation for user-keys, formatted as three digits and prefixed with \\.

Example:

set -s user-keys[101] "\\342\\201\\204"
bind -n User101 send-keys F1

Checking Terminal Key Sequences

To determine what sequence a key generates, use the following commands outside of tmux:

  • showkeys -a
  • xxd