diff options
author | Joe Wilm <joe@jwilm.com> | 2018-05-18 20:44:54 -0700 |
---|---|---|
committer | Joe Wilm <joe@jwilm.com> | 2018-06-02 09:56:50 -0700 |
commit | 4b1a3b1e929bbf580de7106a688043bb44523a7f (patch) | |
tree | 03b27b3d5d3a3838ba3dc956453a38b3e18a3a69 /src/grid | |
parent | ac93f6d03198c1826dbed60fa8283aeb8d1a577d (diff) | |
download | alacritty-4b1a3b1e929bbf580de7106a688043bb44523a7f.tar.gz alacritty-4b1a3b1e929bbf580de7106a688043bb44523a7f.zip |
Optimize Storage::swap_lines
Saves a few cycles in a *very* hot function.
Diffstat (limited to 'src/grid')
-rw-r--r-- | src/grid/storage.rs | 14 |
1 files changed, 6 insertions, 8 deletions
diff --git a/src/grid/storage.rs b/src/grid/storage.rs index 885cb94c..cadd4e29 100644 --- a/src/grid/storage.rs +++ b/src/grid/storage.rs @@ -176,13 +176,10 @@ impl<T> Storage<T> { (requested + self.zero) % self.inner.len() } - fn compute_line_index(&self, requested: Line) -> usize { - ((self.inner.len() + self.zero + *self.visible_lines) - *requested) % self.inner.len() - } - pub fn swap_lines(&mut self, a: Line, b: Line) { - let a = self.compute_line_index(a); - let b = self.compute_line_index(b); + let offset = self.inner.len() + self.zero + *self.visible_lines; + let a = (offset - *a) % self.inner.len(); + let b = (offset - *b) % self.inner.len(); self.inner.swap(a, b); } @@ -191,9 +188,10 @@ impl<T> Storage<T> { } pub fn rotate(&mut self, count: isize) { + debug_assert!(count.abs() as usize <= self.inner.len()); + let len = self.inner.len(); - assert!(count.abs() as usize <= len); - self.zero += (count + len as isize) as usize % len; + self.zero = (self.zero as isize + count + len as isize) as usize % len; } // Fast path |