From 6e8ddac165777a0811336c2aef71840459c5f997 Mon Sep 17 00:00:00 2001 From: Jonas Schievink Date: Mon, 2 Nov 2020 17:06:49 +0100 Subject: Coalesce prime_caches updates --- crates/rust-analyzer/src/main_loop.rs | 44 ++++++++++++++++++++++++++++------- 1 file changed, 35 insertions(+), 9 deletions(-) (limited to 'crates') diff --git a/crates/rust-analyzer/src/main_loop.rs b/crates/rust-analyzer/src/main_loop.rs index 53f8ca194..403904479 100644 --- a/crates/rust-analyzer/src/main_loop.rs +++ b/crates/rust-analyzer/src/main_loop.rs @@ -190,15 +190,35 @@ impl GlobalState { } lsp_server::Message::Response(resp) => self.complete_request(resp), }, - Event::Task(task) => match task { - Task::Response(response) => self.respond(response), - Task::Diagnostics(diagnostics_per_file) => { - for (file_id, diagnostics) in diagnostics_per_file { - self.diagnostics.set_native_diagnostics(file_id, diagnostics) + Event::Task(mut task) => { + let _p = profile::span("GlobalState::handle_event/task"); + let mut prime_caches_started = false; + let mut prime_caches_progress = None; + loop { + match task { + Task::Response(response) => self.respond(response), + Task::Diagnostics(diagnostics_per_file) => { + for (file_id, diagnostics) in diagnostics_per_file { + self.diagnostics.set_native_diagnostics(file_id, diagnostics) + } + } + Task::Workspaces(workspaces) => self.switch_workspaces(workspaces), + Task::PrimeCaches(progress) => { + if let PrimeCachesProgress::Started = progress { + prime_caches_started = true; + } + + prime_caches_progress = Some(progress); + } } + // Coalesce multiple task events into one loop turn + task = match self.task_pool.receiver.try_recv() { + Ok(task) => task, + Err(_) => break, + }; } - Task::Workspaces(workspaces) => self.switch_workspaces(workspaces), - Task::PrimeCaches(progress) => { + + if let Some(progress) = prime_caches_progress { let (state, message, fraction); match progress { PrimeCachesProgress::Started => { @@ -218,9 +238,15 @@ impl GlobalState { } }; - self.report_progress("indexing", state, message, Some(fraction)); + if state != Progress::Begin && prime_caches_started { + // Progress indicator needs to be created first. + self.report_progress("indexing", Progress::Begin, None, Some(0.0)); + } + + self.report_progress("indexing", state, message.clone(), Some(fraction)); + eprintln!("progress reported: {:?}", message); } - }, + } Event::Vfs(mut task) => { let _p = profile::span("GlobalState::handle_event/vfs"); loop { -- cgit v1.2.3