Auto merge of #17903 - tmandry:graceful-exit, r=Veykril

Allow flycheck process to exit gracefully

Assuming it isn't cancelled. Closes #17902.

The only place CommandHandle::join() is used is when the flycheck command
finishes, so this commit changes the behavior of the method itself.

The only reason I can see for the existing behavior is if the command is somehow holding onto a build lock longer than it should, this would force it to be released. But it would be a pretty heavy-handed way to solve that issue. I'm not aware of this occurring in practice.
This commit is contained in:
bors 2024-08-16 07:35:16 +00:00
commit 4cd8dcf287

View file

@ -148,7 +148,6 @@ impl<T: ParseFromLine> CommandHandle<T> {
} }
pub(crate) fn join(mut self) -> io::Result<()> { pub(crate) fn join(mut self) -> io::Result<()> {
let _ = self.child.0.kill();
let exit_status = self.child.0.wait()?; let exit_status = self.child.0.wait()?;
let (read_at_least_one_message, error) = self.thread.join()?; let (read_at_least_one_message, error) = self.thread.join()?;
if read_at_least_one_message || exit_status.success() { if read_at_least_one_message || exit_status.success() {