From 376d99a51d35c258182a088515285a99cc109073 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Bla=C5=BE=20Hrastnik?= Date: Thu, 3 Mar 2022 17:03:04 +0900 Subject: [PATCH] core: transaction: Resolve some TODOs --- helix-core/src/transaction.rs | 25 +++++++++---------------- 1 file changed, 9 insertions(+), 16 deletions(-) diff --git a/helix-core/src/transaction.rs b/helix-core/src/transaction.rs index 2e34a9864..daf4a77e8 100644 --- a/helix-core/src/transaction.rs +++ b/helix-core/src/transaction.rs @@ -21,7 +21,6 @@ pub enum Assoc { After, } -// ChangeSpec = Change | ChangeSet | Vec #[derive(Debug, Default, Clone, PartialEq, Eq)] pub struct ChangeSet { pub(crate) changes: Vec, @@ -50,7 +49,6 @@ pub fn new(doc: &Rope) -> Self { } // TODO: from iter - // #[doc(hidden)] // used by lsp to convert to LSP changes pub fn changes(&self) -> &[Operation] { @@ -415,8 +413,6 @@ pub fn changes_iter(&self) -> ChangeIterator { pub struct Transaction { changes: ChangeSet, selection: Option, - // effects, annotations - // scroll_into_view } impl Transaction { @@ -440,14 +436,12 @@ pub fn selection(&self) -> Option<&Selection> { /// Returns true if applied successfully. pub fn apply(&self, doc: &mut Rope) -> bool { - if !self.changes.is_empty() { - // apply changes to the document - if !self.changes.apply(doc) { - return false; - } + if self.changes.is_empty() { + return true; } - true + // apply changes to the document + self.changes.apply(doc) } /// Generate a transaction that reverts this one. @@ -475,7 +469,7 @@ pub fn with_selection(mut self, selection: Selection) -> Self { /// Generate a transaction from a set of changes. pub fn change(doc: &Rope, changes: I) -> Self where - I: IntoIterator + Iterator, + I: Iterator, { let len = doc.len_chars(); @@ -483,12 +477,11 @@ pub fn change(doc: &Rope, changes: I) -> Self let size = upper.unwrap_or(lower); let mut changeset = ChangeSet::with_capacity(2 * size + 1); // rough estimate - // TODO: verify ranges are ordered and not overlapping or change will panic. - - // TODO: test for (pos, pos, None) to factor out as nothing - let mut last = 0; for (from, to, tendril) in changes { + // Verify ranges are ordered and not overlapping + debug_assert!(last <= from); + // Retain from last "to" to current "from" changeset.retain(from - last); let span = to - from; @@ -694,7 +687,7 @@ fn transaction_change() { let mut doc = Rope::from("hello world!\ntest 123"); let transaction = Transaction::change( &doc, - // (1, 1, None) is a useless 0-width delete + // (1, 1, None) is a useless 0-width delete that gets factored out vec![(1, 1, None), (6, 11, Some("void".into())), (12, 17, None)].into_iter(), ); transaction.apply(&mut doc);