diff options
author | Christian Duerr <contact@christianduerr.com> | 2020-07-03 20:27:18 +0000 |
---|---|---|
committer | GitHub <noreply@github.com> | 2020-07-03 20:27:18 +0000 |
commit | 09179d06fd07c13deb0b108a6f9264f77d9d9599 (patch) | |
tree | 98410cebc1e1a8a7222fe752622d21c18e03d018 /alacritty_terminal/src/ansi.rs | |
parent | bc60782e424359d818a22ffa2ffa3c2dc88ab6fe (diff) | |
download | alacritty-09179d06fd07c13deb0b108a6f9264f77d9d9599.tar.gz alacritty-09179d06fd07c13deb0b108a6f9264f77d9d9599.zip |
Document supported escape sequences
Fixes #3440.
Diffstat (limited to 'alacritty_terminal/src/ansi.rs')
-rw-r--r-- | alacritty_terminal/src/ansi.rs | 70 |
1 files changed, 33 insertions, 37 deletions
diff --git a/alacritty_terminal/src/ansi.rs b/alacritty_terminal/src/ansi.rs index 619b1d39..8240ff00 100644 --- a/alacritty_terminal/src/ansi.rs +++ b/alacritty_terminal/src/ansi.rs @@ -812,10 +812,6 @@ where unhandled(params); }, - // Set icon name. - // This is ignored, since alacritty has no concept of tabs. - b"1" => (), - // Set color index. b"4" => { if params.len() > 1 && params.len() % 2 != 0 { @@ -970,6 +966,9 @@ where ('A', None) => { handler.move_up(Line(arg_or_default!(idx: 0, default: 1) as usize)); }, + ('B', None) | ('e', None) => { + handler.move_down(Line(arg_or_default!(idx: 0, default: 1) as usize)) + }, ('b', None) => { if let Some(c) = self.state.preceding_char { for _ in 0..arg_or_default!(idx: 0, default: 1) { @@ -979,24 +978,27 @@ where debug!("tried to repeat with no preceding char"); } }, - ('B', None) | ('e', None) => { - handler.move_down(Line(arg_or_default!(idx: 0, default: 1) as usize)) + ('C', None) | ('a', None) => { + handler.move_forward(Column(arg_or_default!(idx: 0, default: 1) as usize)) }, ('c', None) if arg_or_default!(idx: 0, default: 0) == 0 => { handler.identify_terminal(writer) }, - ('C', None) | ('a', None) => { - handler.move_forward(Column(arg_or_default!(idx: 0, default: 1) as usize)) - }, ('D', None) => { handler.move_backward(Column(arg_or_default!(idx: 0, default: 1) as usize)) }, + ('d', None) => { + handler.goto_line(Line(arg_or_default!(idx: 0, default: 1) as usize - 1)) + }, ('E', None) => { handler.move_down_and_cr(Line(arg_or_default!(idx: 0, default: 1) as usize)) }, ('F', None) => { handler.move_up_and_cr(Line(arg_or_default!(idx: 0, default: 1) as usize)) }, + ('G', None) | ('`', None) => { + handler.goto_col(Column(arg_or_default!(idx: 0, default: 1) as usize - 1)) + }, ('g', None) => { let mode = match arg_or_default!(idx: 0, default: 0) { 0 => TabulationClearMode::Current, @@ -1009,14 +1011,19 @@ where handler.clear_tabs(mode); }, - ('G', None) | ('`', None) => { - handler.goto_col(Column(arg_or_default!(idx: 0, default: 1) as usize - 1)) - }, ('H', None) | ('f', None) => { let y = arg_or_default!(idx: 0, default: 1) as usize; let x = arg_or_default!(idx: 1, default: 1) as usize; handler.goto(Line(y - 1), Column(x - 1)); }, + ('h', intermediate) => { + for arg in args { + match Mode::from_primitive(intermediate, *arg) { + Some(mode) => handler.set_mode(mode), + None => unhandled!(), + } + } + }, ('I', None) => handler.move_forward_tabs(arg_or_default!(idx: 0, default: 1)), ('J', None) => { let mode = match arg_or_default!(idx: 0, default: 0) { @@ -1045,13 +1052,6 @@ 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)) }, @@ -1064,24 +1064,6 @@ where } }, ('M', None) => handler.delete_lines(Line(arg_or_default!(idx: 0, default: 1) as usize)), - ('X', None) => { - handler.erase_chars(Column(arg_or_default!(idx: 0, default: 1) as usize)) - }, - ('P', None) => { - handler.delete_chars(Column(arg_or_default!(idx: 0, default: 1) as usize)) - }, - ('Z', None) => handler.move_backward_tabs(arg_or_default!(idx: 0, default: 1)), - ('d', None) => { - handler.goto_line(Line(arg_or_default!(idx: 0, default: 1) as usize - 1)) - }, - ('h', intermediate) => { - for arg in args { - match Mode::from_primitive(intermediate, *arg) { - Some(mode) => handler.set_mode(mode), - None => unhandled!(), - } - } - }, ('m', None) => { if args.is_empty() { handler.terminal_attribute(Attr::Reset); @@ -1097,6 +1079,9 @@ where ('n', None) => { handler.device_status(writer, arg_or_default!(idx: 0, default: 0) as usize) }, + ('P', None) => { + handler.delete_chars(Column(arg_or_default!(idx: 0, default: 1) as usize)) + }, ('q', Some(b' ')) => { // DECSCUSR (CSI Ps SP q) -- Set Cursor Style. let style = match arg_or_default!(idx: 0, default: 0) { @@ -1118,8 +1103,19 @@ where handler.set_scrolling_region(top, bottom); }, + ('S', None) => handler.scroll_up(Line(arg_or_default!(idx: 0, default: 1) as usize)), ('s', None) => handler.save_cursor_position(), + ('T', None) => handler.scroll_down(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!(), + }, ('u', None) => handler.restore_cursor_position(), + ('X', None) => { + handler.erase_chars(Column(arg_or_default!(idx: 0, default: 1) as usize)) + }, + ('Z', None) => handler.move_backward_tabs(arg_or_default!(idx: 0, default: 1)), _ => unhandled!(), } } |