summaryrefslogtreecommitdiff
path: root/src
diff options
context:
space:
mode:
authorJoe Wilm <joe@jwilm.com>2018-05-18 20:44:54 -0700
committerJoe Wilm <joe@jwilm.com>2018-06-02 09:56:50 -0700
commit4b1a3b1e929bbf580de7106a688043bb44523a7f (patch)
tree03b27b3d5d3a3838ba3dc956453a38b3e18a3a69 /src
parentac93f6d03198c1826dbed60fa8283aeb8d1a577d (diff)
downloadalacritty-4b1a3b1e929bbf580de7106a688043bb44523a7f.tar.gz
alacritty-4b1a3b1e929bbf580de7106a688043bb44523a7f.zip
Optimize Storage::swap_lines
Saves a few cycles in a *very* hot function.
Diffstat (limited to 'src')
-rw-r--r--src/grid/storage.rs14
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