mirror of
https://github.com/helix-editor/helix.git
synced 2025-04-05 20:07:44 +03:00
state.version tracking
This commit is contained in:
parent
49254d7180
commit
ef5e5f9296
4 changed files with 36 additions and 38 deletions
|
@ -29,6 +29,7 @@ pub struct State {
|
||||||
pub changes: ChangeSet,
|
pub changes: ChangeSet,
|
||||||
pub old_state: Option<(Rope, Selection)>,
|
pub old_state: Option<(Rope, Selection)>,
|
||||||
|
|
||||||
|
pub version: i64,
|
||||||
pub diagnostics: Vec<Diagnostic>,
|
pub diagnostics: Vec<Diagnostic>,
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -61,6 +62,7 @@ impl State {
|
||||||
changes,
|
changes,
|
||||||
old_state,
|
old_state,
|
||||||
diagnostics: Vec::new(),
|
diagnostics: Vec::new(),
|
||||||
|
version: 0,
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -2,6 +2,8 @@ mod transport;
|
||||||
|
|
||||||
use transport::{Payload, Transport};
|
use transport::{Payload, Transport};
|
||||||
|
|
||||||
|
use helix_core::{State, Transaction};
|
||||||
|
|
||||||
// use std::collections::HashMap;
|
// use std::collections::HashMap;
|
||||||
|
|
||||||
use jsonrpc_core as jsonrpc;
|
use jsonrpc_core as jsonrpc;
|
||||||
|
@ -13,14 +15,24 @@ use serde::{Deserialize, Serialize};
|
||||||
pub use lsp::Position;
|
pub use lsp::Position;
|
||||||
pub use lsp::Url;
|
pub use lsp::Url;
|
||||||
|
|
||||||
use smol::prelude::*;
|
|
||||||
use smol::{
|
use smol::{
|
||||||
channel::{Receiver, Sender},
|
channel::{Receiver, Sender},
|
||||||
io::{BufReader, BufWriter},
|
io::{BufReader, BufWriter},
|
||||||
|
// prelude::*,
|
||||||
process::{Child, ChildStderr, Command, Stdio},
|
process::{Child, ChildStderr, Command, Stdio},
|
||||||
Executor,
|
Executor,
|
||||||
};
|
};
|
||||||
|
|
||||||
|
pub mod util {
|
||||||
|
use super::*;
|
||||||
|
|
||||||
|
pub fn lsp_pos_to_pos(doc: &helix_core::RopeSlice, pos: lsp::Position) -> usize {
|
||||||
|
let line = doc.line_to_char(pos.line as usize);
|
||||||
|
let line_start = doc.char_to_utf16_cu(line);
|
||||||
|
doc.utf16_cu_to_char(pos.character as usize + line_start)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
/// A type representing all possible values sent from the server to the client.
|
/// A type representing all possible values sent from the server to the client.
|
||||||
#[derive(Debug, PartialEq, Clone, Deserialize, Serialize)]
|
#[derive(Debug, PartialEq, Clone, Deserialize, Serialize)]
|
||||||
#[serde(deny_unknown_fields)]
|
#[serde(deny_unknown_fields)]
|
||||||
|
@ -58,7 +70,7 @@ impl Notification {
|
||||||
}
|
}
|
||||||
|
|
||||||
pub struct Client {
|
pub struct Client {
|
||||||
process: Child,
|
_process: Child,
|
||||||
stderr: BufReader<ChildStderr>,
|
stderr: BufReader<ChildStderr>,
|
||||||
|
|
||||||
outgoing: Sender<Payload>,
|
outgoing: Sender<Payload>,
|
||||||
|
@ -90,7 +102,7 @@ impl Client {
|
||||||
let (incoming, outgoing) = Transport::start(ex, reader, writer);
|
let (incoming, outgoing) = Transport::start(ex, reader, writer);
|
||||||
|
|
||||||
Client {
|
Client {
|
||||||
process,
|
_process: process,
|
||||||
stderr,
|
stderr,
|
||||||
|
|
||||||
outgoing,
|
outgoing,
|
||||||
|
@ -224,15 +236,12 @@ impl Client {
|
||||||
// Text document
|
// Text document
|
||||||
// -------------------------------------------------------------------------------------------
|
// -------------------------------------------------------------------------------------------
|
||||||
|
|
||||||
pub async fn text_document_did_open(
|
pub async fn text_document_did_open(&mut self, state: &State) -> anyhow::Result<()> {
|
||||||
&mut self,
|
|
||||||
state: &helix_core::State,
|
|
||||||
) -> anyhow::Result<()> {
|
|
||||||
self.notify::<lsp::notification::DidOpenTextDocument>(lsp::DidOpenTextDocumentParams {
|
self.notify::<lsp::notification::DidOpenTextDocument>(lsp::DidOpenTextDocumentParams {
|
||||||
text_document: lsp::TextDocumentItem {
|
text_document: lsp::TextDocumentItem {
|
||||||
uri: lsp::Url::from_file_path(state.path().unwrap()).unwrap(),
|
uri: lsp::Url::from_file_path(state.path().unwrap()).unwrap(),
|
||||||
language_id: "rust".to_string(), // TODO: hardcoded for now
|
language_id: "rust".to_string(), // TODO: hardcoded for now
|
||||||
version: 0,
|
version: state.version,
|
||||||
text: String::from(&state.doc),
|
text: String::from(&state.doc),
|
||||||
},
|
},
|
||||||
})
|
})
|
||||||
|
@ -242,14 +251,15 @@ impl Client {
|
||||||
// TODO: trigger any time history.commit_revision happens
|
// TODO: trigger any time history.commit_revision happens
|
||||||
pub async fn text_document_did_change(
|
pub async fn text_document_did_change(
|
||||||
&mut self,
|
&mut self,
|
||||||
state: &helix_core::State,
|
state: &State,
|
||||||
|
transaction: &Transaction,
|
||||||
) -> anyhow::Result<()> {
|
) -> anyhow::Result<()> {
|
||||||
self.notify::<lsp::notification::DidChangeTextDocument>(lsp::DidChangeTextDocumentParams {
|
self.notify::<lsp::notification::DidChangeTextDocument>(lsp::DidChangeTextDocumentParams {
|
||||||
text_document: lsp::VersionedTextDocumentIdentifier::new(
|
text_document: lsp::VersionedTextDocumentIdentifier::new(
|
||||||
lsp::Url::from_file_path(state.path().unwrap()).unwrap(),
|
lsp::Url::from_file_path(state.path().unwrap()).unwrap(),
|
||||||
0, // TODO: version
|
state.version,
|
||||||
),
|
),
|
||||||
content_changes: vec![], // TODO:
|
content_changes: vec![], // TODO: probably need old_state here too?
|
||||||
})
|
})
|
||||||
.await
|
.await
|
||||||
}
|
}
|
||||||
|
|
|
@ -568,23 +568,12 @@ impl<'a> Application<'a> {
|
||||||
use helix_lsp::Notification;
|
use helix_lsp::Notification;
|
||||||
match notification {
|
match notification {
|
||||||
Some(Notification::PublishDiagnostics(params)) => {
|
Some(Notification::PublishDiagnostics(params)) => {
|
||||||
let view = self.editor.views.iter_mut().find(|view| {
|
let path = Some(params.uri.to_file_path().unwrap());
|
||||||
let path = view
|
let view = self
|
||||||
.state
|
.editor
|
||||||
.path
|
.views
|
||||||
.as_ref()
|
.iter_mut()
|
||||||
.map(|path| helix_lsp::Url::from_file_path(path).unwrap());
|
.find(|view| view.state.path == path);
|
||||||
|
|
||||||
eprintln!("{:?} {} {}", path, params.uri, params.diagnostics.len());
|
|
||||||
// HAXX
|
|
||||||
path == Some(params.uri.clone())
|
|
||||||
});
|
|
||||||
|
|
||||||
fn lsp_pos_to_pos(doc: &helix_core::RopeSlice, pos: helix_lsp::Position) -> usize {
|
|
||||||
let line = doc.line_to_char(pos.line as usize);
|
|
||||||
let line_start = doc.char_to_utf16_cu(line);
|
|
||||||
doc.utf16_cu_to_char(pos.character as usize + line_start)
|
|
||||||
}
|
|
||||||
|
|
||||||
if let Some(view) = view {
|
if let Some(view) = view {
|
||||||
let doc = view.state.doc().slice(..);
|
let doc = view.state.doc().slice(..);
|
||||||
|
@ -592,18 +581,10 @@ impl<'a> Application<'a> {
|
||||||
.diagnostics
|
.diagnostics
|
||||||
.into_iter()
|
.into_iter()
|
||||||
.map(|diagnostic| {
|
.map(|diagnostic| {
|
||||||
|
use helix_lsp::util::lsp_pos_to_pos;
|
||||||
let start = lsp_pos_to_pos(&doc, diagnostic.range.start);
|
let start = lsp_pos_to_pos(&doc, diagnostic.range.start);
|
||||||
let end = lsp_pos_to_pos(&doc, diagnostic.range.end);
|
let end = lsp_pos_to_pos(&doc, diagnostic.range.end);
|
||||||
|
|
||||||
// eprintln!(
|
|
||||||
// "{:?}-{:?} {}-{} {}",
|
|
||||||
// diagnostic.range.start,
|
|
||||||
// diagnostic.range.end,
|
|
||||||
// start,
|
|
||||||
// end,
|
|
||||||
// diagnostic.message
|
|
||||||
// );
|
|
||||||
|
|
||||||
helix_core::Diagnostic {
|
helix_core::Diagnostic {
|
||||||
range: (start, end),
|
range: (start, end),
|
||||||
line: diagnostic.range.start.line as usize,
|
line: diagnostic.range.start.line as usize,
|
||||||
|
|
|
@ -391,6 +391,12 @@ fn append_changes_to_history(view: &mut View) {
|
||||||
// annotations either add a new layer or compose into the previous one.
|
// annotations either add a new layer or compose into the previous one.
|
||||||
let transaction = Transaction::from(changes).with_selection(view.state.selection().clone());
|
let transaction = Transaction::from(changes).with_selection(view.state.selection().clone());
|
||||||
|
|
||||||
|
// increment document version
|
||||||
|
// TODO: needs to happen on undo/redo too
|
||||||
|
view.state.version += 1;
|
||||||
|
|
||||||
|
// TODO: trigger lsp/documentDidChange with changes
|
||||||
|
|
||||||
// HAXX: we need to reconstruct the state as it was before the changes..
|
// HAXX: we need to reconstruct the state as it was before the changes..
|
||||||
let (doc, selection) = view.state.old_state.take().unwrap();
|
let (doc, selection) = view.state.old_state.take().unwrap();
|
||||||
let mut old_state = State::new(doc);
|
let mut old_state = State::new(doc);
|
||||||
|
@ -399,7 +405,6 @@ fn append_changes_to_history(view: &mut View) {
|
||||||
// TODO: take transaction by value?
|
// TODO: take transaction by value?
|
||||||
view.history.commit_revision(&transaction, &old_state);
|
view.history.commit_revision(&transaction, &old_state);
|
||||||
|
|
||||||
// TODO: need to start the state with these vals
|
|
||||||
// HAXX
|
// HAXX
|
||||||
view.state.old_state = Some((view.state.doc().clone(), view.state.selection.clone()));
|
view.state.old_state = Some((view.state.doc().clone(), view.state.selection.clone()));
|
||||||
}
|
}
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue