diff options
-rw-r--r-- | CHANGELOG.md | 1 | ||||
-rw-r--r-- | alacritty_terminal/CHANGELOG.md | 4 | ||||
-rw-r--r-- | alacritty_terminal/src/term/mod.rs | 30 |
3 files changed, 33 insertions, 2 deletions
diff --git a/CHANGELOG.md b/CHANGELOG.md index 94672511..9e0aefe1 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -13,6 +13,7 @@ Notable changes to the `alacritty_terminal` crate are documented in its ### Added - Config option `window.level = "AlwaysOnTop"` to force Alacritty to always be the toplevel window +- Escape sequence to move cursor forward tabs ( CSI Ps I ) ### Changed diff --git a/alacritty_terminal/CHANGELOG.md b/alacritty_terminal/CHANGELOG.md index 28ed7540..a6ee32b2 100644 --- a/alacritty_terminal/CHANGELOG.md +++ b/alacritty_terminal/CHANGELOG.md @@ -10,6 +10,10 @@ The format is based on [Keep a Changelog](https://keepachangelog.com/en/1.0.0/). ## 0.24.2-dev +### Added + +- Escape sequence to move cursor forward tabs ( CSI Ps I ) + ## 0.24.1 ### Changed diff --git a/alacritty_terminal/src/term/mod.rs b/alacritty_terminal/src/term/mod.rs index c2d77ec7..84945f52 100644 --- a/alacritty_terminal/src/term/mod.rs +++ b/alacritty_terminal/src/term/mod.rs @@ -1566,11 +1566,15 @@ impl<T: EventListener> Handler for Term<T> { #[inline] fn move_backward_tabs(&mut self, count: u16) { trace!("Moving backward {} tabs", count); - self.damage_cursor(); let old_col = self.grid.cursor.point.column.0; for _ in 0..count { let mut col = self.grid.cursor.point.column; + + if col == 0 { + break; + } + for i in (0..(col.0)).rev() { if self.tabs[index::Column(i)] { col = index::Column(i); @@ -1586,7 +1590,29 @@ impl<T: EventListener> Handler for Term<T> { #[inline] fn move_forward_tabs(&mut self, count: u16) { - trace!("[unimplemented] Moving forward {} tabs", count); + trace!("Moving forward {} tabs", count); + + let num_cols = self.columns(); + let old_col = self.grid.cursor.point.column.0; + for _ in 0..count { + let mut col = self.grid.cursor.point.column; + + if col == num_cols - 1 { + break; + } + + for i in col.0 + 1..num_cols { + col = index::Column(i); + if self.tabs[col] { + break; + } + } + + self.grid.cursor.point.column = col; + } + + let line = self.grid.cursor.point.line.0 as usize; + self.damage.damage_line(line, old_col, self.grid.cursor.point.column.0); } #[inline] |