aboutsummaryrefslogtreecommitdiff
path: root/src/grid
diff options
context:
space:
mode:
Diffstat (limited to 'src/grid')
-rw-r--r--src/grid/mod.rs31
-rw-r--r--src/grid/storage.rs41
2 files changed, 52 insertions, 20 deletions
diff --git a/src/grid/mod.rs b/src/grid/mod.rs
index b6cff604..f3c8ea79 100644
--- a/src/grid/mod.rs
+++ b/src/grid/mod.rs
@@ -52,23 +52,13 @@ impl<T> Deref for Indexed<T> {
impl<T: PartialEq> ::std::cmp::PartialEq for Grid<T> {
fn eq(&self, other: &Self) -> bool {
- // Compare raw grid content
- // TODO: This is pretty inefficient but only used in tests
- let mut raw_match = true;
- for i in 0..(self.lines.0 + self.history_size) {
- for j in 0..self.cols.0 {
- if self[i][Column(j)] != other[i][Column(j)] {
- raw_match = false;
- break;
- }
- }
- }
-
// Compare struct fields and check result of grid comparison
- self.cols.eq(&other.cols) &&
+ self.raw.eq(&other.raw) &&
+ self.cols.eq(&other.cols) &&
self.lines.eq(&other.lines) &&
- self.history_size.eq(&other.history_size) &&
- raw_match
+ self.display_offset.eq(&other.display_offset) &&
+ self.scroll_limit.eq(&other.scroll_limit) &&
+ self.selection.eq(&other.selection)
}
}
@@ -102,10 +92,6 @@ pub struct Grid<T> {
/// Selected region
#[serde(skip)]
pub selection: Option<Selection>,
-
- /// Maximum number of lines in the scrollback history
- #[serde(default)]
- history_size: usize,
}
pub struct GridIterator<'a, T: 'a> {
@@ -150,7 +136,6 @@ impl<T: Copy + Clone> Grid<T> {
display_offset: 0,
scroll_limit: 0,
selection: None,
- history_size: scrollback,
}
}
@@ -426,6 +411,12 @@ impl<T> Grid<T> {
self.scroll_limit = 0;
}
+ /// Total number of lines in the buffer, this includes scrollback + visible lines
+ #[inline]
+ pub fn len(&self) -> usize {
+ self.raw.len()
+ }
+
pub fn iter_from(&self, point: Point<usize>) -> GridIterator<T> {
GridIterator {
grid: self,
diff --git a/src/grid/storage.rs b/src/grid/storage.rs
index 66e0ccc8..323d8ec4 100644
--- a/src/grid/storage.rs
+++ b/src/grid/storage.rs
@@ -22,6 +22,47 @@ pub struct Storage<T> {
visible_lines: Line,
}
+impl<T: PartialEq> ::std::cmp::PartialEq for Storage<T> {
+ fn eq(&self, other: &Self) -> bool {
+ // Make sure length is equal
+ if self.inner.len() != other.inner.len() {
+ return false;
+ }
+
+ // Check which vec has the bigger zero
+ let (ref bigger, ref smaller) = if self.zero >= other.zero {
+ (self, other)
+ } else {
+ (other, self)
+ };
+
+ // Calculate the actual zero offset
+ let len = self.inner.len();
+ let bigger_zero = bigger.zero % len;
+ let smaller_zero = smaller.zero % len;
+
+ // Compare the slices in chunks
+ // Chunks:
+ // - Bigger zero to the end
+ // - Remaining lines in smaller zero vec
+ // - Beginning of smaller zero vec
+ //
+ // Example:
+ // Bigger Zero (6):
+ // 4 5 6 | 7 8 9 | 0 1 2 3
+ // C2 C2 C2 | C3 C3 C3 | C1 C1 C1 C1
+ // Smaller Zero (3):
+ // 7 8 9 | 0 1 2 3 | 4 5 6
+ // C3 C3 C3 | C1 C1 C1 C1 | C2 C2 C2
+ &bigger.inner[bigger_zero..]
+ == &smaller.inner[smaller_zero..smaller_zero + (len - bigger_zero)]
+ && &bigger.inner[..bigger_zero - smaller_zero]
+ == &smaller.inner[smaller_zero + (len - bigger_zero)..]
+ && &bigger.inner[bigger_zero - smaller_zero..bigger_zero]
+ == &smaller.inner[..smaller_zero]
+ }
+}
+
impl<T> Storage<T> {
#[inline]
pub fn with_capacity(cap: usize, lines: Line) -> Storage<T> {