diff options
author | Blaž Hrastnik | 2021-02-16 06:39:41 +0000 |
---|---|---|
committer | Blaž Hrastnik | 2021-02-16 06:45:46 +0000 |
commit | b7da7f83c356a0da54390d15a2f066f64b33d5e8 (patch) | |
tree | fe3f555403d4e3315cd22e62cb036c4966f91236 | |
parent | 9821c4dd3b41d4e1ad07208e3c65b5cb96b7ecec (diff) |
lsp: Test changeset_to_changes.
-rw-r--r-- | helix-lsp/src/client.rs | 2 | ||||
-rw-r--r-- | helix-view/src/document.rs | 82 |
2 files changed, 82 insertions, 2 deletions
diff --git a/helix-lsp/src/client.rs b/helix-lsp/src/client.rs index ebfdafe7..c035dd4f 100644 --- a/helix-lsp/src/client.rs +++ b/helix-lsp/src/client.rs @@ -247,7 +247,7 @@ impl Client { .await } - fn changeset_to_changes( + pub fn changeset_to_changes( old_text: &Rope, changeset: &ChangeSet, ) -> Vec<lsp::TextDocumentContentChangeEvent> { diff --git a/helix-view/src/document.rs b/helix-view/src/document.rs index e742de46..71577a32 100644 --- a/helix-view/src/document.rs +++ b/helix-view/src/document.rs @@ -58,7 +58,7 @@ use helix_lsp::lsp; use url::Url; impl Document { - fn new(state: State) -> Self { + pub fn new(state: State) -> Self { let changes = ChangeSet::new(&state.doc); let old_state = None; @@ -294,3 +294,83 @@ impl Document { lsp::VersionedTextDocumentIdentifier::new(self.url().unwrap(), self.version) } } + +#[cfg(test)] +mod test { + use super::*; + + #[test] + fn changeset_to_changes() { + use helix_core::{Rope, State, Transaction}; + // use helix_view::Document; + use helix_lsp::{lsp, Client}; + let text = Rope::from("hello"); + let mut state = State::new(text); + state.selection = Selection::single(5, 5); + let mut doc = Document::new(state); + + // insert + + let transaction = Transaction::insert(&doc.state, " world".into()); + let old_doc = doc.state.clone(); + let changes = Client::changeset_to_changes(&old_doc.doc, transaction.changes()); + doc.apply(&transaction); + + assert_eq!( + changes, + &[lsp::TextDocumentContentChangeEvent { + range: Some(lsp::Range::new( + lsp::Position::new(0, 5), + lsp::Position::new(0, 5) + )), + text: " world".into(), + range_length: None, + }] + ); + + // delete + + let transaction = transaction.invert(&old_doc); + let old_doc = doc.state.clone(); + let changes = Client::changeset_to_changes(&old_doc.doc, transaction.changes()); + doc.apply(&transaction); + + // line: 0-based. + // col: 0-based, gaps between chars. + // 0 1 2 3 4 5 6 7 8 9 0 1 + // |h|e|l|l|o| |w|o|r|l|d| + // ------------- + // (0, 5)-(0, 11) + assert_eq!( + changes, + &[lsp::TextDocumentContentChangeEvent { + range: Some(lsp::Range::new( + lsp::Position::new(0, 5), + lsp::Position::new(0, 11) + )), + text: "".into(), + range_length: None, + }] + ); + + // replace + + doc.state.selection = Selection::single(0, 5); + let transaction = Transaction::change_by_selection(&doc.state, |range| { + (range.from(), range.to(), Some("aeiou".into())) + }); + let changes = Client::changeset_to_changes(&doc.state.doc, transaction.changes()); + + assert_eq!( + changes, + &[lsp::TextDocumentContentChangeEvent { + range: Some(lsp::Range::new( + lsp::Position::new(0, 0), + lsp::Position::new(0, 5) + )), + text: "aeiou".into(), + range_length: None, + }] + ); + } +} |