fix: Fix empty check diagnostics not marking files as changed

This commit is contained in:
Lukas Wirth 2024-12-22 12:37:58 +01:00
parent ca17481170
commit 8da08e7100
3 changed files with 20 additions and 20 deletions

View file

@ -22,7 +22,6 @@ use hir_def::{
use crate::{ use crate::{
db::{HirDatabase, InternedCoroutine}, db::{HirDatabase, InternedCoroutine},
display::HirDisplay,
from_assoc_type_id, from_chalk_trait_id, from_foreign_def_id, from_assoc_type_id, from_chalk_trait_id, from_foreign_def_id,
generics::generics, generics::generics,
make_binders, make_single_type_binders, make_binders, make_single_type_binders,
@ -823,13 +822,12 @@ pub(crate) fn impl_datum_query(
let _p = tracing::info_span!("impl_datum_query").entered(); let _p = tracing::info_span!("impl_datum_query").entered();
debug!("impl_datum {:?}", impl_id); debug!("impl_datum {:?}", impl_id);
let impl_: hir_def::ImplId = from_chalk(db, impl_id); let impl_: hir_def::ImplId = from_chalk(db, impl_id);
impl_def_datum(db, krate, impl_id, impl_) impl_def_datum(db, krate, impl_)
} }
fn impl_def_datum( fn impl_def_datum(
db: &dyn HirDatabase, db: &dyn HirDatabase,
krate: CrateId, krate: CrateId,
chalk_id: ImplId,
impl_id: hir_def::ImplId, impl_id: hir_def::ImplId,
) -> Arc<ImplDatum> { ) -> Arc<ImplDatum> {
let trait_ref = db let trait_ref = db
@ -850,13 +848,6 @@ fn impl_def_datum(
}; };
let where_clauses = convert_where_clauses(db, impl_id.into(), &bound_vars); let where_clauses = convert_where_clauses(db, impl_id.into(), &bound_vars);
let negative = impl_data.is_negative; let negative = impl_data.is_negative;
debug!(
"impl {:?}: {}{} where {:?}",
chalk_id,
if negative { "!" } else { "" },
trait_ref.display(db, db.crate_graph()[krate].edition),
where_clauses
);
let polarity = if negative { rust_ir::Polarity::Negative } else { rust_ir::Polarity::Positive }; let polarity = if negative { rust_ir::Polarity::Negative } else { rust_ir::Polarity::Positive };

View file

@ -55,9 +55,10 @@ pub(crate) struct Fix {
impl DiagnosticCollection { impl DiagnosticCollection {
pub(crate) fn clear_check(&mut self, flycheck_id: usize) { pub(crate) fn clear_check(&mut self, flycheck_id: usize) {
if let Some(it) = self.check.get_mut(&flycheck_id) { let Some(check) = self.check.get_mut(&flycheck_id) else {
it.clear(); return;
} };
self.changes.extend(check.drain().flat_map(|(_, v)| v.into_keys()));
if let Some(fixes) = Arc::make_mut(&mut self.check_fixes).get_mut(&flycheck_id) { if let Some(fixes) = Arc::make_mut(&mut self.check_fixes).get_mut(&flycheck_id) {
fixes.clear(); fixes.clear();
} }
@ -70,12 +71,6 @@ impl DiagnosticCollection {
) )
} }
pub(crate) fn clear_native_for(&mut self, file_id: FileId) {
self.native_syntax.remove(&file_id);
self.native_semantic.remove(&file_id);
self.changes.insert(file_id);
}
pub(crate) fn clear_check_for_package( pub(crate) fn clear_check_for_package(
&mut self, &mut self,
flycheck_id: usize, flycheck_id: usize,
@ -84,7 +79,19 @@ impl DiagnosticCollection {
let Some(check) = self.check.get_mut(&flycheck_id) else { let Some(check) = self.check.get_mut(&flycheck_id) else {
return; return;
}; };
check.remove(&Some(package_id)); let package_id = Some(package_id);
if let Some(checks) = check.remove(&package_id) {
self.changes.extend(checks.into_keys());
}
if let Some(fixes) = Arc::make_mut(&mut self.check_fixes).get_mut(&flycheck_id) {
fixes.remove(&package_id);
}
}
pub(crate) fn clear_native_for(&mut self, file_id: FileId) {
self.native_syntax.remove(&file_id);
self.native_semantic.remove(&file_id);
self.changes.insert(file_id);
} }
pub(crate) fn add_check_diagnostic( pub(crate) fn add_check_diagnostic(

View file

@ -369,6 +369,7 @@ impl FlycheckActor {
tracing::trace!( tracing::trace!(
flycheck_id = self.id, flycheck_id = self.id,
artifact = msg.target.name, artifact = msg.target.name,
package_id = msg.package_id.repr,
"artifact received" "artifact received"
); );
self.report_progress(Progress::DidCheckCrate(msg.target.name)); self.report_progress(Progress::DidCheckCrate(msg.target.name));
@ -380,6 +381,7 @@ impl FlycheckActor {
tracing::trace!( tracing::trace!(
flycheck_id = self.id, flycheck_id = self.id,
message = diagnostic.message, message = diagnostic.message,
package_id = package_id.as_ref().map(|it| &it.repr),
"diagnostic received" "diagnostic received"
); );
if let Some(package_id) = &package_id { if let Some(package_id) = &package_id {