diff options
| author | bors <bors@rust-lang.org> | 2022-10-03 12:05:11 +0000 |
|---|---|---|
| committer | bors <bors@rust-lang.org> | 2022-10-03 12:05:11 +0000 |
| commit | f087ebe6e7c80da747ecd4d7e1673a27c6729d34 (patch) | |
| tree | 12e79bf09d2dcbc5e643fce774375974de556abf | |
| parent | 5c28ad193238635189f849c94ffc178f00008b12 (diff) | |
| parent | 59168035551959e089eaf4778acc84978accb9c4 (diff) | |
| download | rust-f087ebe6e7c80da747ecd4d7e1673a27c6729d34.tar.gz rust-f087ebe6e7c80da747ecd4d7e1673a27c6729d34.zip | |
Auto merge of #13338 - Veykril:flycheck, r=Veykril
Prioritize restart messages in flycheck cc https://github.com/rust-lang/rust-analyzer/issues/12936#issuecomment-1264670905
| -rw-r--r-- | crates/flycheck/src/lib.rs | 13 |
1 files changed, 11 insertions, 2 deletions
diff --git a/crates/flycheck/src/lib.rs b/crates/flycheck/src/lib.rs index fdc03f4053a..e8c63d410aa 100644 --- a/crates/flycheck/src/lib.rs +++ b/crates/flycheck/src/lib.rs @@ -169,13 +169,17 @@ impl FlycheckActor { } fn next_event(&self, inbox: &Receiver<Restart>) -> Option<Event> { let check_chan = self.cargo_handle.as_ref().map(|cargo| &cargo.receiver); + if let Ok(msg) = inbox.try_recv() { + // give restarts a preference so check outputs don't block a restart or stop + return Some(Event::Restart(msg)); + } select! { recv(inbox) -> msg => msg.ok().map(Event::Restart), recv(check_chan.unwrap_or(&never())) -> msg => Some(Event::CheckEvent(msg.ok())), } } fn run(mut self, inbox: Receiver<Restart>) { - while let Some(event) = self.next_event(&inbox) { + 'event: while let Some(event) = self.next_event(&inbox) { match event { Event::Restart(Restart::No) => { self.cancel_check_process(); @@ -183,7 +187,12 @@ impl FlycheckActor { Event::Restart(Restart::Yes) => { // Cancel the previously spawned process self.cancel_check_process(); - while let Ok(_) = inbox.recv_timeout(Duration::from_millis(50)) {} + while let Ok(restart) = inbox.recv_timeout(Duration::from_millis(50)) { + // restart chained with a stop, so just cancel + if let Restart::No = restart { + continue 'event; + } + } let command = self.check_command(); tracing::debug!(?command, "will restart flycheck"); |
