aerc-binds - Man Page

key bindings configuration file format for aerc(1)

Synopsis

The binds.conf file is used for configuring keybindings used in the aerc interactive client. It is expected to be in your XDG config home plus aerc, which defaults to ~/.config/aerc/binds.conf. If the file does not exist, the built-in default will be installed. An alternate file can be specified via the --binds-conf command line argument, see aerc(1).

This file is written in the ini format with key bindings defined as:

<key sequence> = <command>

Where <key sequence> is the keystrokes pressed (in order) to invoke this keybinding, and <command> specifies keystrokes that aerc will simulate when the keybinding is invoked. Generally this is used to execute commands, for example:

rq = :reply -q<Enter>

Pressing r, then q, will simulate typing in :reply -q<Enter>, and execute :reply -q accordingly. It is also possible to invoke keybindings recursively in a similar fashion.

You may configure different keybindings for different contexts by writing them into different [sections] of the ini file.

Contexts

The available contexts are:

[messages]

keybindings for the message list

[view]

keybindings for the message viewer

[view::passthrough]

keybindings for the viewer, when in key passthrough mode (toggled with :toggle-key-passthrough)

[compose]

keybindings for the message composer

[compose::editor]

keybindings for the composer, when the editor is focused

[compose::review]

keybindings for the composer, when reviewing the email before it's sent

[terminal]

keybindings for terminal tabs

You may also configure account specific key bindings for each context:

[context:account=AccountName]

keybindings for this context and account, where AccountName is a regular expression that matches the account name you provided in accounts.conf.

Folder and context-specific bindings can be configured for message lists:

[messages:folder=FolderName]
[compose:folder=FolderName]
[compose::editor:folder=FolderName]
[compose::review:folder=FolderName]

keybindings under this section will be specific to the folder that matches the regular expression FolderName. Keybindings from a folder specifier will take precedence over account specifiers

Examples:

  [messages:account=Mailbox]
  c = :cf path:mailbox/** and<space>

[compose::editor:account=Mailbox2]

[compose::editor:folder=aerc]
y = :send -t aerc

[messages:folder=Drafts]
<Enter> = :recall<Enter>

[messages:folder=Archive/d+/.*]
gi = :cf Inbox<Enter>
...

You may also configure global keybindings by placing them at the beginning of the file, before specifying any context-specific sections.

Parent keybindings can be erased in the context ones by specifying an "empty" binding:

  [compose::review]
  a = :attach<space>
  d = :deatch<space>

[compose::review:account=no-attachments]
a =
d =

Special Options

In addition of user defined key sequences, the following special options are available in each binding context:

$noinherit = true|false

If set to true, global keybindings will not be effective in this context.

Default: false

$ex = <key-stroke>

This can be set to a keystroke which will bring up the command input in this context.

Default: :

$complete = <key-stroke>

This can be set to a keystroke which will trigger command completion in this context for text inputs that support it.

Default: <tab>

Note: automatic command completion is disabled when simulating keystrokes and re-enabled at the end. When [ui].completion-min-chars is set to manual (see aerc-config(5)), it is possible to end a keybinding with the completion key to explicitly display the completion menu. E.g.:

  • o = :cf<space><tab>

Supported Keys

In addition to letters and some characters (e.g. a, RR, gu, ?, !, etc.), special keys may be specified in <angle brackets>. The following special keys are supported:

NameDescription
<space>" "
<semicolon>;
<tab>Tab
<enter>Enter
<up>Up arrow
<c-up>Ctrl+Up
<a-up>Alt+Up
<down>Down arrow
<c-down>Ctrl+Down
<a-down>Alt+Down
<right>Right arrow
<c-right>Ctrl+Right
<a-right>Alt+Right
<left>Left arrow
<c-left>Ctrl+Left
<a-left>Alt+Left
<pgup>Page Up
<c-pgup>Ctrl+PageUp
<a-pgup>Alt+PageUp
<pgdn>Page Down
<c-pgdn>Ctrl+PageDn
<a-pgdn>Alt+PageDn
<home>Home
<end>End
<insert>Insert
<delete>Delete
<c-delete>Ctrl+Delete
<a-delete>Alt+Delete
<backspace>Backspace
<exit>Exit
<cancel>Cancel
<print>Print screen
<pause>Pause
<backtab>Shift+Tab
<esc>Escape
<c-space>Ctrl+Space
<a-space>Alt+Space
<a-0>Alt+0
<a-1>Alt+1
<a-2>Alt+2
<a-3>Alt+3
<a-4>Alt+4
<a-5>Alt+5
<a-6>Alt+6
<a-7>Alt+7
<a-8>Alt+8
<a-9>Alt+9
<c-a>Ctrl+a
<a-a>Alt+a
<c-b>Ctrl+b
<a-b>Alt+b
<c-c>Ctrl+c
<a-c>Alt+c
<c-d>Ctrl+d
<a-d>Alt+d
<c-e>Ctrl+e
<a-e>Alt+e
<c-f>Ctrl+f
<a-f>Alt+f
<c-g>Ctrl+g
<a-g>Alt+g
<c-h>Ctrl+h
<a-h>Alt+h
<c-i>Ctrl+i
<a-i>Alt+i
<c-j>Ctrl+j
<a-j>Alt+j
<c-k>Ctrl+k
<a-k>Alt+k
<c-l>Ctrl+l
<a-l>Alt+l
<c-m>Ctrl+m
<a-m>Alt+m
<c-n>Ctrl+n
<a-n>Alt+n
<c-o>Ctrl+o
<a-o>Alt+o
<c-p>Ctrl+p
<a-p>Alt+p
<c-q>Ctrl+q
<a-q>Alt+q
<c-r>Ctrl+r
<a-r>Alt+r
<c-s>Ctrl+s
<a-s>Alt+s
<c-t>Ctrl+t
<a-t>Alt+t
<c-u>Ctrl+u
<a-u>Alt+u
<c-v>Ctrl+v
<a-v>Alt+v
<c-w>Ctrl+w
<a-w>Alt+w
<c-x>Ctrl+x
<a-x>Alt+x
<c-y>Ctrl+y
<a-y>Alt+y
<c-z>Ctrl+z
<a-z>Alt+z
<c-]>Ctrl+]
<a-]>Alt+]
<c-[>Ctrl+[
<a-[>Alt+[
<c-^>Ctrl+^
<a-^>Alt+^
<c-_>Ctrl+_
<a-_>Alt+_

See Also

aerc(1) aerc-config(5)

Authors

Originally created by Drew DeVault and maintained by Robin Jarry who is assisted by other open source contributors. For more information about aerc development, see https://sr.ht/~rjarry/aerc/.

Referenced By

aerc(1), aerc-config(5).

2024-02-24