diff options
author | Christian Duerr <contact@christianduerr.com> | 2019-12-10 00:35:13 +0100 |
---|---|---|
committer | GitHub <noreply@github.com> | 2019-12-10 00:35:13 +0100 |
commit | 36185c47533d6189c9116df7a41a13766ca2b40c (patch) | |
tree | 80089a2da7de8701f59b1e692041f0de06c01aee /alacritty_terminal/src/term/cell.rs | |
parent | 79b19176eeb57fbd6b137160afd6bc9f5518ad33 (diff) | |
download | alacritty-36185c47533d6189c9116df7a41a13766ca2b40c.tar.gz alacritty-36185c47533d6189c9116df7a41a13766ca2b40c.zip |
Fix colored row reset performance
This fixes a bug where a row would always get reset completely if its
background does not equal the default terminal background. This leads to
big performance bottlenecks when running commands like `echo "\e[41m" &&
yes`.
Instead of resetting the entire row whenever the template cell is not
empty, the template cell is now compared to the last cell in the row.
The last cell will always be equal to the previous template cell when
`row.occ < row.inner.len()` and if `occ` is equal to the row's length,
the entire row is always reset anyways.
Fixes #2989.
Diffstat (limited to 'alacritty_terminal/src/term/cell.rs')
-rw-r--r-- | alacritty_terminal/src/term/cell.rs | 5 |
1 files changed, 5 insertions, 0 deletions
diff --git a/alacritty_terminal/src/term/cell.rs b/alacritty_terminal/src/term/cell.rs index bb7869b2..92725336 100644 --- a/alacritty_terminal/src/term/cell.rs +++ b/alacritty_terminal/src/term/cell.rs @@ -85,6 +85,11 @@ impl GridCell for Cell { self.flags.remove(Flags::WRAPLINE); } } + + #[inline] + fn fast_eq(&self, other: Self) -> bool { + self.bg == other.bg + } } /// Get the length of occupied cells in a line |