diff --git a/atuin-client/config.toml b/atuin-client/config.toml index 7313f9f..b84151a 100644 --- a/atuin-client/config.toml +++ b/atuin-client/config.toml @@ -68,6 +68,10 @@ ## number of context lines to show when scrolling by pages # scroll_context_lines = 1 +## use ctrl instead of alt as the shortcut modifier key for numerical UI shortcuts +## alt-0 .. alt-9 +# ctrl_n_shortcuts = false + ## prevent commands matching any of these regexes from being written to history. ## Note that these regular expressions are unanchored, i.e. if they don't start ## with ^ or end with $, they'll match anywhere in the command. diff --git a/atuin-client/src/settings.rs b/atuin-client/src/settings.rs index 3bcb270..622abde 100644 --- a/atuin-client/src/settings.rs +++ b/atuin-client/src/settings.rs @@ -168,6 +168,7 @@ pub struct Settings { #[serde(with = "serde_regex", default = "RegexSet::empty")] pub cwd_filter: RegexSet, pub workspaces: bool, + pub ctrl_n_shortcuts: bool, // This is automatically loaded when settings is created. Do not set in // config! Keep secrets and settings apart. @@ -380,6 +381,7 @@ impl Settings { .set_default("shell_up_key_binding", false)? .set_default("session_token", "")? .set_default("workspaces", false)? + .set_default("ctrl_n_shortcuts", false)? .add_source( Environment::with_prefix("atuin") .prefix_separator("_") diff --git a/atuin/src/command/client/search/interactive.rs b/atuin/src/command/client/search/interactive.rs index 710d027..e7e7189 100644 --- a/atuin/src/command/client/search/interactive.rs +++ b/atuin/src/command/client/search/interactive.rs @@ -102,6 +102,9 @@ impl State { let ctrl = input.modifiers.contains(KeyModifiers::CONTROL); let alt = input.modifiers.contains(KeyModifiers::ALT); + // Use Ctrl-n instead of Alt-n? + let modfr = if settings.ctrl_n_shortcuts { ctrl } else { alt }; + // reset the state, will be set to true later if user really did change it self.switched_search_mode = false; match input.code { @@ -115,7 +118,7 @@ impl State { KeyCode::Enter => { return Some(self.results_state.selected()); } - KeyCode::Char(c @ '1'..='9') if alt => { + KeyCode::Char(c @ '1'..='9') if modfr => { let c = c.to_digit(10)? as usize; return Some(self.results_state.selected() + c); } diff --git a/docs/docs/config/config.md b/docs/docs/config/config.md index 1f4e166..209d34c 100644 --- a/docs/docs/config/config.md +++ b/docs/docs/config/config.md @@ -231,3 +231,12 @@ history_filter = [ "^innocuous-cmd .*--secret=.+" ] ``` + +## macOS Ctrl-n key shortcuts + +macOS does not have an Alt key, although terminal emulators can often be configured to map the Option key to be used as Alt. *However*, remapping Option this way may prevent typing some characters, such as using Option-3 to type `#` on the British English layout. For such a scenario, set the `ctrl_n_shortcuts` option to `true` in your config file to replace Alt-0 to Alt-9 shortcuts with Ctrl-0 to Ctrl-9 instead: + +``` +# Use Ctrl-0 .. Ctrl-9 instead of Alt-0 .. Alt-9 UI shortcuts +ctrl_n_shortcuts = true +``` diff --git a/docs/docs/key-binding.md b/docs/docs/key-binding.md index 2069e25..c393197 100644 --- a/docs/docs/key-binding.md +++ b/docs/docs/key-binding.md @@ -46,6 +46,15 @@ eval "$(atuin init zsh)" You can then choose to bind Atuin if needed, do this after the call to init. +## Ctrl-n key shortcuts + +macOS does not have an Alt key, although terminal emulators can often be configured to map the Option key to be used as Alt. *However*, remapping Option this way may prevent typing some characters, such as using Option-3 to type `#` on the British English layout. For such a scenario, set the `ctrl_n_shortcuts` option to `true` in your config file to replace Alt-0 to Alt-9 shortcuts with Ctrl-0 to Ctrl-9 instead: + +``` +# Use Ctrl-0 .. Ctrl-9 instead of Alt-0 .. Alt-9 UI shortcuts +ctrl_n_shortcuts = true +``` + ## zsh If you'd like to customize your bindings further, it's possible to do so with custom shell config: