diff options
author | Dustin <dustin1114@gmail.com> | 2019-10-14 13:50:58 -0400 |
---|---|---|
committer | Christian Duerr <contact@christianduerr.com> | 2019-10-14 19:50:58 +0200 |
commit | 401c2aab964b60e8c3b072e5098ba8e366d04944 (patch) | |
tree | 8b8fb2f11a93ebb3e59dedb41e01a89f30791455 /alacritty_terminal/src/ansi.rs | |
parent | 3475e449870b382cda4ea6d48f980577cd8c929e (diff) | |
download | alacritty-401c2aab964b60e8c3b072e5098ba8e366d04944.tar.gz alacritty-401c2aab964b60e8c3b072e5098ba8e366d04944.zip |
Add support for title stack escape sequences
This commit adds the concept of a "title stack" to the terminal. Some programs
(e.g. vim) send control sequences `CSI 22 ; 0` (push title) and `CSI 23 ; 0`
(pop title).
The title stack is just a history of previous titles. Applications can push
the current title onto the stack, and pop it back off (setting the window title
in the process).
Fixes #2840.
Diffstat (limited to 'alacritty_terminal/src/ansi.rs')
-rw-r--r-- | alacritty_terminal/src/ansi.rs | 41 |
1 files changed, 20 insertions, 21 deletions
diff --git a/alacritty_terminal/src/ansi.rs b/alacritty_terminal/src/ansi.rs index b34c1cd9..493b02aa 100644 --- a/alacritty_terminal/src/ansi.rs +++ b/alacritty_terminal/src/ansi.rs @@ -328,6 +328,12 @@ pub trait Handler { /// Run the dectest routine fn dectest(&mut self) {} + + /// Push a title onto the stack + fn push_title(&mut self) {} + + /// Pop the last title from the stack + fn pop_title(&mut self) {} } /// Describes shape of cursor @@ -412,7 +418,13 @@ impl Mode { /// Create mode from a primitive /// /// TODO lots of unhandled values.. - pub fn from_primitive(private: bool, num: i64) -> Option<Mode> { + pub fn from_primitive(intermediate: Option<&u8>, num: i64) -> Option<Mode> { + let private = match intermediate { + Some(b'?') => true, + None => false, + _ => return None, + }; + if private { Some(match num { 1 => Mode::CursorKeys, @@ -991,22 +1003,18 @@ where handler.clear_line(mode); }, ('S', None) => handler.scroll_up(Line(arg_or_default!(idx: 0, default: 1) as usize)), + ('t', None) => match arg_or_default!(idx: 0, default: 1) as usize { + 22 => handler.push_title(), + 23 => handler.pop_title(), + _ => unhandled!(), + }, ('T', None) => handler.scroll_down(Line(arg_or_default!(idx: 0, default: 1) as usize)), ('L', None) => { handler.insert_blank_lines(Line(arg_or_default!(idx: 0, default: 1) as usize)) }, ('l', intermediate) => { - let is_private_mode = match intermediate { - Some(b'?') => true, - None => false, - _ => { - unhandled!(); - return; - }, - }; for arg in args { - let mode = Mode::from_primitive(is_private_mode, *arg); - match mode { + match Mode::from_primitive(intermediate, *arg) { Some(mode) => handler.unset_mode(mode), None => { unhandled!(); @@ -1027,17 +1035,8 @@ where handler.goto_line(Line(arg_or_default!(idx: 0, default: 1) as usize - 1)) }, ('h', intermediate) => { - let is_private_mode = match intermediate { - Some(b'?') => true, - None => false, - _ => { - unhandled!(); - return; - }, - }; for arg in args { - let mode = Mode::from_primitive(is_private_mode, *arg); - match mode { + match Mode::from_primitive(intermediate, *arg) { Some(mode) => handler.set_mode(mode), None => { unhandled!(); |