diff options
Diffstat (limited to 'src')
-rw-r--r-- | src/config/mod.rs | 10 | ||||
-rw-r--r-- | src/event.rs | 4 | ||||
-rw-r--r-- | src/input.rs | 8 |
3 files changed, 21 insertions, 1 deletions
diff --git a/src/config/mod.rs b/src/config/mod.rs index fd40776d..836fe483 100644 --- a/src/config/mod.rs +++ b/src/config/mod.rs @@ -538,6 +538,10 @@ pub struct Config { #[serde(default, deserialize_with = "failure_default")] enable_experimental_conpty_backend: bool, + /// Send escape sequences using the alt key. + #[serde(default = "default_true_bool", deserialize_with = "deserialize_true_bool")] + alt_send_esc: bool, + // TODO: DEPRECATED custom_cursor_colors: Option<bool>, @@ -1819,6 +1823,12 @@ impl Config { self.enable_experimental_conpty_backend } + /// Send escape sequences using the alt key + #[inline] + pub fn alt_send_esc(&self) -> bool { + self.alt_send_esc + } + // Update the history size, used in ref tests pub fn set_history(&mut self, history: u32) { self.scrolling.history = history; diff --git a/src/event.rs b/src/event.rs index bada4f68..5c6b71d0 100644 --- a/src/event.rs +++ b/src/event.rs @@ -293,6 +293,7 @@ pub struct Processor<N> { pending_events: Vec<Event>, window_changes: WindowChanges, save_to_clipboard: bool, + alt_send_esc: bool, } /// Notify that the terminal was resized @@ -337,6 +338,7 @@ impl<N: Notify> Processor<N> { pending_events: Vec::with_capacity(4), window_changes: Default::default(), save_to_clipboard: config.selection().save_to_clipboard, + alt_send_esc: config.alt_send_esc(), } } @@ -518,6 +520,7 @@ impl<N: Notify> Processor<N> { key_bindings: &self.key_bindings[..], mouse_bindings: &self.mouse_bindings[..], save_to_clipboard: self.save_to_clipboard, + alt_send_esc: self.alt_send_esc, }; let mut window_is_focused = window.is_focused; @@ -573,5 +576,6 @@ impl<N: Notify> Processor<N> { self.mouse_bindings = config.mouse_bindings().to_vec(); self.mouse_config = config.mouse().to_owned(); self.save_to_clipboard = config.selection().save_to_clipboard; + self.alt_send_esc = config.alt_send_esc(); } } diff --git a/src/input.rs b/src/input.rs index c2473448..65b7b6ce 100644 --- a/src/input.rs +++ b/src/input.rs @@ -49,6 +49,7 @@ pub struct Processor<'a, A: 'a> { pub scrolling_config: &'a config::Scrolling, pub ctx: A, pub save_to_clipboard: bool, + pub alt_send_esc: bool, } pub trait ActionContext { @@ -742,7 +743,11 @@ impl<'a, A: ActionContext + 'a> Processor<'a, A> { c.encode_utf8(&mut bytes[..]); } - if *self.ctx.received_count() == 0 && self.ctx.last_modifiers().alt && utf8_len == 1 { + if self.alt_send_esc + && *self.ctx.received_count() == 0 + && self.ctx.last_modifiers().alt + && utf8_len == 1 + { bytes.insert(0, b'\x1b'); } @@ -977,6 +982,7 @@ mod tests { key_bindings: &config.key_bindings()[..], mouse_bindings: &config.mouse_bindings()[..], save_to_clipboard: config.selection().save_to_clipboard, + alt_send_esc: config.alt_send_esc(), }; if let Event::WindowEvent { event: WindowEvent::MouseInput { state, button, modifiers, .. }, .. } = $input { |