From cd69307aeeaa6996e782359f503666e5d7b64a25 Mon Sep 17 00:00:00 2001 From: Aleksey Kladov Date: Sun, 2 May 2021 21:45:00 +0300 Subject: fix: don't duplicate Progerss::Finised for cache priming --- crates/ide/src/prime_caches.rs | 1 + crates/rust-analyzer/src/main_loop.rs | 30 ++++++++++-------------------- 2 files changed, 11 insertions(+), 20 deletions(-) diff --git a/crates/ide/src/prime_caches.rs b/crates/ide/src/prime_caches.rs index 03597f507..d912a01b8 100644 --- a/crates/ide/src/prime_caches.rs +++ b/crates/ide/src/prime_caches.rs @@ -27,6 +27,7 @@ pub(crate) fn prime_caches(db: &RootDatabase, cb: &(dyn Fn(PrimeCachesProgress) let topo = &graph.crates_in_topological_order(); cb(PrimeCachesProgress::Started); + // Take care to emit the finish signal even when the computation is canceled. let _d = stdx::defer(|| cb(PrimeCachesProgress::Finished)); // FIXME: This would be easy to parallelize, since it's in the ideal ordering for that. diff --git a/crates/rust-analyzer/src/main_loop.rs b/crates/rust-analyzer/src/main_loop.rs index a3e974e92..ce7ece559 100644 --- a/crates/rust-analyzer/src/main_loop.rs +++ b/crates/rust-analyzer/src/main_loop.rs @@ -8,8 +8,7 @@ use std::{ use always_assert::always; use crossbeam_channel::{select, Receiver}; -use ide::PrimeCachesProgress; -use ide::{Canceled, FileId}; +use ide::{FileId, PrimeCachesProgress}; use ide_db::base_db::VfsPath; use lsp_server::{Connection, Notification, Request, Response}; use lsp_types::notification::Notification as _; @@ -278,8 +277,6 @@ impl GlobalState { }; } - let mut finished = false; - for progress in prime_caches_progress { let (state, message, fraction); match progress { @@ -297,18 +294,13 @@ impl GlobalState { state = Progress::End; message = None; fraction = 1.0; - finished = true; + + self.prime_caches_queue.op_completed(()); } }; self.report_progress("Indexing", state, message, Some(fraction)); } - - // If the task is cancelled we may observe two `PrimeCachesProgress::Finished` so we - // have to make sure to only call `op_completed()` once. - if finished { - self.prime_caches_queue.op_completed(()); - } } Event::Vfs(mut task) => { let _p = profile::span("GlobalState::handle_event/vfs"); @@ -730,15 +722,13 @@ impl GlobalState { self.task_pool.handle.spawn_with_sender({ let snap = self.snapshot(); move |sender| { - snap.analysis - .prime_caches(|progress| { - sender.send(Task::PrimeCaches(progress)).unwrap(); - }) - .unwrap_or_else(|_: Canceled| { - // Pretend that we're done, so that the progress bar is removed. Otherwise - // the editor may complain about it already existing. - sender.send(Task::PrimeCaches(PrimeCachesProgress::Finished)).unwrap() - }); + let cb = |progress| { + sender.send(Task::PrimeCaches(progress)).unwrap(); + }; + match snap.analysis.prime_caches(cb) { + Ok(()) => (), + Err(_canceled) => (), + } } }); } -- cgit v1.2.3