Use StreamExt::select_next_some to avoid infinitely spinning on empty stream.

imgbot
Blaž Hrastnik 4 years ago
parent e833d65b77
commit ebfd67ac6a

@ -99,10 +99,10 @@ impl Application {
event = reader.next().fuse() => { event = reader.next().fuse() => {
self.handle_terminal_events(event) self.handle_terminal_events(event)
} }
call = self.editor.language_servers.incoming.next().fuse() => { call = futures_util::StreamExt::select_next_some(&mut self.editor.language_servers.incoming) => {
self.handle_language_server_message(call).await self.handle_language_server_message(call).await
} }
callback = self.callbacks.next().fuse() => { callback = futures_util::StreamExt::select_next_some(&mut self.callbacks) => {
self.handle_language_server_callback(callback) self.handle_language_server_callback(callback)
} }
} }
@ -110,9 +110,9 @@ impl Application {
} }
pub fn handle_language_server_callback( pub fn handle_language_server_callback(
&mut self, &mut self,
callback: Option<Result<LspCallbackWrapper, anyhow::Error>>, callback: Result<LspCallbackWrapper, anyhow::Error>,
) { ) {
if let Some(Ok(callback)) = callback { if let Ok(callback) = callback {
// TODO: handle Err() // TODO: handle Err()
callback(&mut self.editor, &mut self.compositor); callback(&mut self.editor, &mut self.compositor);
self.render(); self.render();
@ -144,12 +144,10 @@ impl Application {
} }
} }
pub async fn handle_language_server_message(&mut self, call: Option<helix_lsp::Call>) { pub async fn handle_language_server_message(&mut self, call: helix_lsp::Call) {
use helix_lsp::{Call, Notification}; use helix_lsp::{Call, Notification};
match call { match call {
Some(Call::Notification(helix_lsp::jsonrpc::Notification { Call::Notification(helix_lsp::jsonrpc::Notification { method, params, .. }) => {
method, params, ..
})) => {
let notification = Notification::parse(&method, params); let notification = Notification::parse(&method, params);
match notification { match notification {
Notification::PublishDiagnostics(params) => { Notification::PublishDiagnostics(params) => {
@ -203,7 +201,7 @@ impl Application {
_ => unreachable!(), _ => unreachable!(),
} }
} }
Some(Call::MethodCall(call)) => { Call::MethodCall(call) => {
error!("Method not found {}", call.method); error!("Method not found {}", call.method);
// self.language_server.reply( // self.language_server.reply(
@ -216,7 +214,6 @@ impl Application {
// }), // }),
// ); // );
} }
None => (),
e => unreachable!("{:?}", e), e => unreachable!("{:?}", e),
} }
} }

Loading…
Cancel
Save