mirror of
https://github.com/rust-lang/rust-analyzer
synced 2024-12-27 05:23:24 +00:00
fix: Fix the server not honoring diagnostic refresh support
This commit is contained in:
parent
80e9d014be
commit
1da6138b40
2 changed files with 7 additions and 4 deletions
|
@ -463,6 +463,11 @@ impl ClientCapabilities {
|
|||
.unwrap_or_default()
|
||||
}
|
||||
|
||||
pub fn diagnostics_refresh(&self) -> bool {
|
||||
(|| -> _ { self.0.workspace.as_ref()?.diagnostic.as_ref()?.refresh_support })()
|
||||
.unwrap_or_default()
|
||||
}
|
||||
|
||||
pub fn inlay_hint_resolve_support_properties(&self) -> FxHashSet<&str> {
|
||||
self.0
|
||||
.text_document
|
||||
|
|
|
@ -417,8 +417,6 @@ impl GlobalState {
|
|||
}
|
||||
}
|
||||
|
||||
let supports_diagnostic_pull_model = self.config.text_document_diagnostic();
|
||||
|
||||
let client_refresh = became_quiescent || state_changed;
|
||||
if client_refresh {
|
||||
// Refresh semantic tokens if the client supports it.
|
||||
|
@ -437,7 +435,7 @@ impl GlobalState {
|
|||
self.send_request::<lsp_types::request::InlayHintRefreshRequest>((), |_, _| ());
|
||||
}
|
||||
|
||||
if supports_diagnostic_pull_model {
|
||||
if self.config.diagnostics_refresh() {
|
||||
self.send_request::<lsp_types::request::WorkspaceDiagnosticRefresh>(
|
||||
(),
|
||||
|_, _| (),
|
||||
|
@ -448,7 +446,7 @@ impl GlobalState {
|
|||
let project_or_mem_docs_changed =
|
||||
became_quiescent || state_changed || memdocs_added_or_removed;
|
||||
if project_or_mem_docs_changed
|
||||
&& !supports_diagnostic_pull_model
|
||||
&& !self.config.text_document_diagnostic()
|
||||
&& self.config.publish_diagnostics(None)
|
||||
{
|
||||
self.update_diagnostics();
|
||||
|
|
Loading…
Reference in a new issue