mirror of
https://github.com/rust-lang/rust-analyzer
synced 2025-01-16 07:03:57 +00:00
Auto merge of #12584 - Veykril:attr-diag, r=Veykril
fix: attribute macros not being properly diagnosed Closes https://github.com/rust-lang/rust-analyzer/issues/12582
This commit is contained in:
commit
eb9b360752
1 changed files with 14 additions and 16 deletions
|
@ -436,6 +436,17 @@ impl DefCollector<'_> {
|
||||||
let mut unresolved_macros = mem::take(&mut self.unresolved_macros);
|
let mut unresolved_macros = mem::take(&mut self.unresolved_macros);
|
||||||
let pos = unresolved_macros.iter().position(|directive| {
|
let pos = unresolved_macros.iter().position(|directive| {
|
||||||
if let MacroDirectiveKind::Attr { ast_id, mod_item, attr, tree } = &directive.kind {
|
if let MacroDirectiveKind::Attr { ast_id, mod_item, attr, tree } = &directive.kind {
|
||||||
|
self.def_map.diagnostics.push(DefDiagnostic::unresolved_proc_macro(
|
||||||
|
directive.module_id,
|
||||||
|
MacroCallKind::Attr {
|
||||||
|
ast_id: ast_id.ast_id,
|
||||||
|
attr_args: Default::default(),
|
||||||
|
invoc_attr_index: attr.id.ast_index,
|
||||||
|
is_derive: false,
|
||||||
|
},
|
||||||
|
None,
|
||||||
|
));
|
||||||
|
|
||||||
self.skip_attrs.insert(ast_id.ast_id.with_value(*mod_item), attr.id);
|
self.skip_attrs.insert(ast_id.ast_id.with_value(*mod_item), attr.id);
|
||||||
|
|
||||||
let item_tree = tree.item_tree(self.db);
|
let item_tree = tree.item_tree(self.db);
|
||||||
|
@ -1135,19 +1146,7 @@ impl DefCollector<'_> {
|
||||||
|
|
||||||
let def = match resolver(path.clone()) {
|
let def = match resolver(path.clone()) {
|
||||||
Some(def) if def.is_attribute() => def,
|
Some(def) if def.is_attribute() => def,
|
||||||
_ => {
|
_ => return true,
|
||||||
self.def_map.diagnostics.push(DefDiagnostic::unresolved_proc_macro(
|
|
||||||
directive.module_id,
|
|
||||||
MacroCallKind::Attr {
|
|
||||||
ast_id,
|
|
||||||
attr_args: Default::default(),
|
|
||||||
invoc_attr_index: attr.id.ast_index,
|
|
||||||
is_derive: false,
|
|
||||||
},
|
|
||||||
None,
|
|
||||||
));
|
|
||||||
return true;
|
|
||||||
}
|
|
||||||
};
|
};
|
||||||
if matches!(
|
if matches!(
|
||||||
def,
|
def,
|
||||||
|
@ -1389,9 +1388,8 @@ impl DefCollector<'_> {
|
||||||
ast_id.path.clone(),
|
ast_id.path.clone(),
|
||||||
));
|
));
|
||||||
}
|
}
|
||||||
MacroDirectiveKind::Attr { .. } => {
|
// These are diagnosed by `reseed_with_unresolved_attribute`, as that function consumes them
|
||||||
// FIXME: these should get diagnosed by `reseed_with_unresolved_attribute`
|
MacroDirectiveKind::Attr { .. } => {}
|
||||||
}
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue