mirror of
https://github.com/alacritty/alacritty.git
synced 2024-11-18 13:55:23 -05:00
Optimize Storage::swap_lines
Saves a few cycles in a *very* hot function.
This commit is contained in:
parent
f044828755
commit
5f599b0d0a
1 changed files with 6 additions and 8 deletions
|
@ -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
|
||||
|
|
Loading…
Reference in a new issue