summaryrefslogtreecommitdiff
path: root/helix-lsp
diff options
context:
space:
mode:
authorBlaž Hrastnik2021-05-06 08:15:49 +0000
committerBlaž Hrastnik2021-05-06 08:15:49 +0000
commitba970054957238cb682ae3be022b675131beb6f8 (patch)
tree92fcbcc733fdccb79b1746ed1286f6d01c49daeb /helix-lsp
parentd00414f81a49501277642868c2cf76eefeb0db6b (diff)
Work around the rest of the blocking issues.
Diffstat (limited to 'helix-lsp')
-rw-r--r--helix-lsp/Cargo.toml1
-rw-r--r--helix-lsp/src/client.rs64
-rw-r--r--helix-lsp/src/lib.rs3
3 files changed, 21 insertions, 47 deletions
diff --git a/helix-lsp/Cargo.toml b/helix-lsp/Cargo.toml
index 09351f97..0fae9cb2 100644
--- a/helix-lsp/Cargo.toml
+++ b/helix-lsp/Cargo.toml
@@ -14,6 +14,7 @@ once_cell = "1.4"
lsp-types = { version = "0.89", features = ["proposed"] }
tokio = { version = "1", features = ["full"] }
tokio-stream = "0.1.5"
+futures-executor = { version = "0.3" }
url = "2"
pathdiff = "0.2"
shellexpand = "2.0"
diff --git a/helix-lsp/src/client.rs b/helix-lsp/src/client.rs
index c54560de..8de4b95a 100644
--- a/helix-lsp/src/client.rs
+++ b/helix-lsp/src/client.rs
@@ -152,7 +152,7 @@ impl Client {
timeout(Duration::from_secs(2), rx.recv())
.await
- .map_err(|e| Error::Timeout)? // return Timeout
+ .map_err(|_| Error::Timeout)? // return Timeout
.unwrap() // TODO: None if channel closed
}
}
@@ -500,11 +500,11 @@ impl Client {
self.call::<lsp::request::Completion>(params)
}
- pub async fn text_document_signature_help(
+ pub fn text_document_signature_help(
&self,
text_document: lsp::TextDocumentIdentifier,
position: lsp::Position,
- ) -> anyhow::Result<Option<lsp::SignatureHelp>> {
+ ) -> impl Future<Output = Result<Value>> {
let params = lsp::SignatureHelpParams {
text_document_position_params: lsp::TextDocumentPositionParams {
text_document,
@@ -517,18 +517,14 @@ impl Client {
// lsp::SignatureHelpContext
};
- let response = self
- .request::<lsp::request::SignatureHelpRequest>(params)
- .await?;
-
- Ok(response)
+ self.call::<lsp::request::SignatureHelpRequest>(params)
}
- pub async fn text_document_hover(
+ pub fn text_document_hover(
&self,
text_document: lsp::TextDocumentIdentifier,
position: lsp::Position,
- ) -> anyhow::Result<Option<lsp::Hover>> {
+ ) -> impl Future<Output = Result<Value>> {
let params = lsp::HoverParams {
text_document_position_params: lsp::TextDocumentPositionParams {
text_document,
@@ -540,9 +536,7 @@ impl Client {
// lsp::SignatureHelpContext
};
- let response = self.request::<lsp::request::HoverRequest>(params).await?;
-
- Ok(response)
+ self.call::<lsp::request::HoverRequest>(params)
}
// formatting
@@ -607,7 +601,7 @@ impl Client {
Ok(response.unwrap_or_default())
}
- async fn goto_request<
+ fn goto_request<
T: lsp::request::Request<
Params = lsp::GotoDefinitionParams,
Result = Option<lsp::GotoDefinitionResponse>,
@@ -616,7 +610,7 @@ impl Client {
&self,
text_document: lsp::TextDocumentIdentifier,
position: lsp::Position,
- ) -> anyhow::Result<Vec<lsp::Location>> {
+ ) -> impl Future<Output = Result<Value>> {
let params = lsp::GotoDefinitionParams {
text_document_position_params: lsp::TextDocumentPositionParams {
text_document,
@@ -630,56 +624,38 @@ impl Client {
},
};
- let response = self.request::<T>(params).await?;
-
- let items = match response {
- Some(lsp::GotoDefinitionResponse::Scalar(location)) => vec![location],
- Some(lsp::GotoDefinitionResponse::Array(locations)) => locations,
- Some(lsp::GotoDefinitionResponse::Link(locations)) => locations
- .into_iter()
- .map(|location_link| lsp::Location {
- uri: location_link.target_uri,
- range: location_link.target_range,
- })
- .collect(),
- None => Vec::new(),
- };
-
- Ok(items)
+ self.call::<T>(params)
}
- pub async fn goto_definition(
+ pub fn goto_definition(
&self,
text_document: lsp::TextDocumentIdentifier,
position: lsp::Position,
- ) -> anyhow::Result<Vec<lsp::Location>> {
+ ) -> impl Future<Output = Result<Value>> {
self.goto_request::<lsp::request::GotoDefinition>(text_document, position)
- .await
}
- pub async fn goto_type_definition(
+ pub fn goto_type_definition(
&self,
text_document: lsp::TextDocumentIdentifier,
position: lsp::Position,
- ) -> anyhow::Result<Vec<lsp::Location>> {
+ ) -> impl Future<Output = Result<Value>> {
self.goto_request::<lsp::request::GotoTypeDefinition>(text_document, position)
- .await
}
- pub async fn goto_implementation(
+ pub fn goto_implementation(
&self,
text_document: lsp::TextDocumentIdentifier,
position: lsp::Position,
- ) -> anyhow::Result<Vec<lsp::Location>> {
+ ) -> impl Future<Output = Result<Value>> {
self.goto_request::<lsp::request::GotoImplementation>(text_document, position)
- .await
}
- pub async fn goto_reference(
+ pub fn goto_reference(
&self,
text_document: lsp::TextDocumentIdentifier,
position: lsp::Position,
- ) -> anyhow::Result<Vec<lsp::Location>> {
+ ) -> impl Future<Output = Result<Value>> {
let params = lsp::ReferenceParams {
text_document_position: lsp::TextDocumentPositionParams {
text_document,
@@ -696,8 +672,6 @@ impl Client {
},
};
- let response = self.request::<lsp::request::References>(params).await?;
-
- Ok(response.unwrap_or_default())
+ self.call::<lsp::request::References>(params)
}
}
diff --git a/helix-lsp/src/lib.rs b/helix-lsp/src/lib.rs
index fd7e6fd3..6adaa3f8 100644
--- a/helix-lsp/src/lib.rs
+++ b/helix-lsp/src/lib.rs
@@ -203,8 +203,7 @@ impl Registry {
Client::start(&config.command, &config.args).ok()?;
// TODO: run this async without blocking
- let rt = tokio::runtime::Handle::current();
- rt.block_on(client.initialize()).unwrap();
+ futures_executor::block_on(client.initialize()).unwrap();
s_incoming.push(UnboundedReceiverStream::new(incoming));