diff options
Diffstat (limited to 'alacritty_terminal/src/term')
-rw-r--r-- | alacritty_terminal/src/term/cell.rs | 2 | ||||
-rw-r--r-- | alacritty_terminal/src/term/mod.rs | 44 |
2 files changed, 21 insertions, 25 deletions
diff --git a/alacritty_terminal/src/term/cell.rs b/alacritty_terminal/src/term/cell.rs index 234805f9..bb7869b2 100644 --- a/alacritty_terminal/src/term/cell.rs +++ b/alacritty_terminal/src/term/cell.rs @@ -135,7 +135,7 @@ impl Cell { #[inline] pub fn reset(&mut self, template: &Cell) { // memcpy template to self - *self = *template; + *self = Cell { c: template.c, bg: template.bg, ..Cell::default() }; } #[inline] diff --git a/alacritty_terminal/src/term/mod.rs b/alacritty_terminal/src/term/mod.rs index f0f38941..ce63c407 100644 --- a/alacritty_terminal/src/term/mod.rs +++ b/alacritty_terminal/src/term/mod.rs @@ -1049,13 +1049,15 @@ impl<T> Term<T> { // Scroll up to keep cursor in terminal if self.cursor.point.line >= num_lines { let lines = self.cursor.point.line - num_lines + 1; - self.grid.scroll_up(&(Line(0)..old_lines), lines, &self.cursor.template); + let template = Cell { bg: self.cursor.template.bg, ..Cell::default() }; + self.grid.scroll_up(&(Line(0)..old_lines), lines, &template); } // Scroll up alt grid as well if self.cursor_save_alt.point.line >= num_lines { let lines = self.cursor_save_alt.point.line - num_lines + 1; - self.alt_grid.scroll_up(&(Line(0)..old_lines), lines, &self.cursor_save_alt.template); + let template = Cell { bg: self.cursor_save_alt.template.bg, ..Cell::default() }; + self.alt_grid.scroll_up(&(Line(0)..old_lines), lines, &template); } // Move prompt down when growing if scrollback lines are available @@ -1105,12 +1107,12 @@ impl<T> Term<T> { pub fn swap_alt(&mut self) { if self.alt { - let template = &self.cursor.template; - self.grid.region_mut(..).each(|c| c.reset(template)); + let template = self.cursor.template; + self.grid.region_mut(..).each(|c| c.reset(&template)); } self.alt = !self.alt; - ::std::mem::swap(&mut self.grid, &mut self.alt_grid); + std::mem::swap(&mut self.grid, &mut self.alt_grid); } /// Scroll screen down @@ -1124,8 +1126,7 @@ impl<T> Term<T> { lines = min(lines, self.scroll_region.end - origin); // Scroll between origin and bottom - let mut template = self.cursor.template; - template.flags = Flags::empty(); + let template = Cell { bg: self.cursor.template.bg, ..Cell::default() }; self.grid.scroll_down(&(origin..self.scroll_region.end), lines, &template); } @@ -1139,8 +1140,7 @@ impl<T> Term<T> { let lines = min(lines, self.scroll_region.end - self.scroll_region.start); // Scroll from origin to bottom less number of lines - let mut template = self.cursor.template; - template.flags = Flags::empty(); + let template = Cell { bg: self.cursor.template.bg, ..Cell::default() }; self.grid.scroll_up(&(origin..self.scroll_region.end), lines, &template); } @@ -1308,11 +1308,10 @@ impl<T: EventListener> ansi::Handler for Term<T> { } #[inline] - fn dectest(&mut self) { - trace!("Dectesting"); - let mut template = self.cursor.template; - template.c = 'E'; + fn decaln(&mut self) { + trace!("Decalnning"); + let template = Cell { c: 'E', ..Cell::default() }; self.grid.region_mut(..).each(|c| c.reset(&template)); } @@ -1363,9 +1362,8 @@ impl<T: EventListener> ansi::Handler for Term<T> { // Cells were just moved out towards the end of the line; fill in // between source and dest with blanks. - let template = self.cursor.template; for c in &mut line[source..destination] { - c.reset(&template); + c.reset(&self.cursor.template); } } @@ -1581,9 +1579,9 @@ impl<T: EventListener> ansi::Handler for Term<T> { let end = min(start + count, self.grid.num_cols()); let row = &mut self.grid[self.cursor.point.line]; - let template = self.cursor.template; // Cleared cells have current background color set + // Cleared cells have current background color set for c in &mut row[start..end] { - c.reset(&template); + c.reset(&self.cursor.template); } } @@ -1609,10 +1607,9 @@ impl<T: EventListener> ansi::Handler for Term<T> { // Clear last `count` cells in line. If deleting 1 char, need to delete // 1 cell. - let template = self.cursor.template; let end = cols - count; for c in &mut line[end..] { - c.reset(&template); + c.reset(&self.cursor.template); } } @@ -1658,7 +1655,6 @@ impl<T: EventListener> ansi::Handler for Term<T> { #[inline] fn clear_line(&mut self, mode: ansi::LineClearMode) { trace!("Clearing line: {:?}", mode); - let template = Cell { bg: self.cursor.template.bg, ..Cell::default() }; let col = self.cursor.point.col; @@ -1666,19 +1662,19 @@ impl<T: EventListener> ansi::Handler for Term<T> { ansi::LineClearMode::Right => { let row = &mut self.grid[self.cursor.point.line]; for cell in &mut row[col..] { - cell.reset(&template); + cell.reset(&self.cursor.template); } }, ansi::LineClearMode::Left => { let row = &mut self.grid[self.cursor.point.line]; for cell in &mut row[..=col] { - cell.reset(&template); + cell.reset(&self.cursor.template); } }, ansi::LineClearMode::All => { let row = &mut self.grid[self.cursor.point.line]; for cell in &mut row[..] { - cell.reset(&template); + cell.reset(&self.cursor.template); } }, } @@ -1746,7 +1742,7 @@ impl<T: EventListener> ansi::Handler for Term<T> { #[inline] fn clear_screen(&mut self, mode: ansi::ClearMode) { trace!("Clearing screen: {:?}", mode); - let template = Cell { bg: self.cursor.template.bg, ..Cell::default() }; + let template = self.cursor.template; // Remove active selections self.grid.selection = None; |