Skip to content

Commit

Permalink
Prioritize formatting thread tasks in main_loop
Browse files Browse the repository at this point in the history
  • Loading branch information
Veykril committed Jan 27, 2025
1 parent 1711a19 commit 26c5708
Show file tree
Hide file tree
Showing 2 changed files with 14 additions and 9 deletions.
Original file line number Diff line number Diff line change
Expand Up @@ -118,7 +118,7 @@ impl RequestDispatcher<'_> {
}
return self;
}
self.on_with_thread_intent::<true, ALLOW_RETRYING, R>(
self.on_with_thread_intent::<false, ALLOW_RETRYING, R>(
ThreadIntent::Worker,
f,
Self::content_modified_error,
Expand Down Expand Up @@ -147,7 +147,7 @@ impl RequestDispatcher<'_> {
}
return self;
}
self.on_with_thread_intent::<true, false, R>(ThreadIntent::Worker, f, on_cancelled)
self.on_with_thread_intent::<false, false, R>(ThreadIntent::Worker, f, on_cancelled)
}

/// Dispatches a non-latency-sensitive request onto the thread pool. When the VFS is marked not
Expand All @@ -166,7 +166,7 @@ impl RequestDispatcher<'_> {
}
return self;
}
self.on_with_thread_intent::<true, ALLOW_RETRYING, R>(
self.on_with_thread_intent::<false, ALLOW_RETRYING, R>(
ThreadIntent::Worker,
f,
Self::content_modified_error,
Expand All @@ -193,7 +193,7 @@ impl RequestDispatcher<'_> {
}
return self;
}
self.on_with_thread_intent::<true, ALLOW_RETRYING, R>(
self.on_with_thread_intent::<false, ALLOW_RETRYING, R>(
ThreadIntent::LatencySensitive,
f,
Self::content_modified_error,
Expand All @@ -212,7 +212,7 @@ impl RequestDispatcher<'_> {
R::Params: DeserializeOwned + panic::UnwindSafe + Send + fmt::Debug,
R::Result: Serialize,
{
self.on_with_thread_intent::<false, false, R>(
self.on_with_thread_intent::<true, false, R>(
ThreadIntent::LatencySensitive,
f,
Self::content_modified_error,
Expand All @@ -231,7 +231,7 @@ impl RequestDispatcher<'_> {
}
}

fn on_with_thread_intent<const MAIN_POOL: bool, const ALLOW_RETRYING: bool, R>(
fn on_with_thread_intent<const RUSTFMT: bool, const ALLOW_RETRYING: bool, R>(
&mut self,
intent: ThreadIntent,
f: fn(GlobalStateSnapshot, R::Params) -> anyhow::Result<R::Result>,
Expand All @@ -251,10 +251,10 @@ impl RequestDispatcher<'_> {
tracing::debug!(?params);

let world = self.global_state.snapshot();
if MAIN_POOL {
&mut self.global_state.task_pool.handle
} else {
if RUSTFMT {
&mut self.global_state.fmt_pool.handle
} else {
&mut self.global_state.task_pool.handle
}
.spawn(intent, move || {
let result = panic::catch_unwind(move || {
Expand Down
5 changes: 5 additions & 0 deletions src/tools/rust-analyzer/crates/rust-analyzer/src/main_loop.rs
Original file line number Diff line number Diff line change
Expand Up @@ -253,6 +253,11 @@ impl GlobalState {
&self,
inbox: &Receiver<lsp_server::Message>,
) -> Result<Option<Event>, crossbeam_channel::RecvError> {
// Make sure we reply to formatting requests ASAP so the editor doesn't block
if let Ok(task) = self.fmt_pool.receiver.try_recv() {
return Ok(Some(Event::Task(task)));
}

select! {
recv(inbox) -> msg =>
return Ok(msg.ok().map(Event::Lsp)),
Expand Down

0 comments on commit 26c5708

Please sign in to comment.