Remove Session.used_attrs
and move logic to CheckAttrVisitor
Instead of updating global state to mark attributes as used, we now explicitly emit a warning when an attribute is used in an unsupported position. As a side effect, we are to emit more detailed warning messages (instead of just a generic "unused" message). `Session.check_name` is removed, since its only purpose was to mark the attribute as used. All of the callers are modified to use `Attribute.has_name` Additionally, `AttributeType::AssumedUsed` is removed - an 'assumed used' attribute is implemented by simply not performing any checks in `CheckAttrVisitor` for a particular attribute. We no longer emit unused attribute warnings for the `#[rustc_dummy]` attribute - it's an internal attribute used for tests, so it doesn't mark sense to treat it as 'unused'. With this commit, a large source of global untracked state is removed.
This commit is contained in:
parent
b6e334d873
commit
af46699f81
62 changed files with 535 additions and 739 deletions
|
@ -166,8 +166,6 @@ where
|
|||
continue; // not a stability level
|
||||
}
|
||||
|
||||
sess.mark_attr_used(attr);
|
||||
|
||||
let meta = attr.meta();
|
||||
|
||||
if attr.has_name(sym::rustc_promotable) {
|
||||
|
@ -636,8 +634,7 @@ where
|
|||
let diagnostic = &sess.parse_sess.span_diagnostic;
|
||||
|
||||
'outer: for attr in attrs_iter {
|
||||
if !(sess.check_name(attr, sym::deprecated) || sess.check_name(attr, sym::rustc_deprecated))
|
||||
{
|
||||
if !(attr.has_name(sym::deprecated) || attr.has_name(sym::rustc_deprecated)) {
|
||||
continue;
|
||||
}
|
||||
|
||||
|
@ -700,17 +697,17 @@ where
|
|||
continue 'outer;
|
||||
}
|
||||
}
|
||||
sym::note if sess.check_name(attr, sym::deprecated) => {
|
||||
sym::note if attr.has_name(sym::deprecated) => {
|
||||
if !get(mi, &mut note) {
|
||||
continue 'outer;
|
||||
}
|
||||
}
|
||||
sym::reason if sess.check_name(attr, sym::rustc_deprecated) => {
|
||||
sym::reason if attr.has_name(sym::rustc_deprecated) => {
|
||||
if !get(mi, &mut note) {
|
||||
continue 'outer;
|
||||
}
|
||||
}
|
||||
sym::suggestion if sess.check_name(attr, sym::rustc_deprecated) => {
|
||||
sym::suggestion if attr.has_name(sym::rustc_deprecated) => {
|
||||
if !get(mi, &mut suggestion) {
|
||||
continue 'outer;
|
||||
}
|
||||
|
@ -721,7 +718,7 @@ where
|
|||
meta.span(),
|
||||
AttrError::UnknownMetaItem(
|
||||
pprust::path_to_string(&mi.path),
|
||||
if sess.check_name(attr, sym::deprecated) {
|
||||
if attr.has_name(sym::deprecated) {
|
||||
&["since", "note"]
|
||||
} else {
|
||||
&["since", "reason", "suggestion"]
|
||||
|
@ -747,11 +744,11 @@ where
|
|||
}
|
||||
}
|
||||
|
||||
if suggestion.is_some() && sess.check_name(attr, sym::deprecated) {
|
||||
if suggestion.is_some() && attr.has_name(sym::deprecated) {
|
||||
unreachable!("only allowed on rustc_deprecated")
|
||||
}
|
||||
|
||||
if sess.check_name(attr, sym::rustc_deprecated) {
|
||||
if attr.has_name(sym::rustc_deprecated) {
|
||||
if since.is_none() {
|
||||
handle_errors(&sess.parse_sess, attr.span, AttrError::MissingSince);
|
||||
continue;
|
||||
|
@ -763,9 +760,7 @@ where
|
|||
}
|
||||
}
|
||||
|
||||
sess.mark_attr_used(&attr);
|
||||
|
||||
let is_since_rustc_version = sess.check_name(attr, sym::rustc_deprecated);
|
||||
let is_since_rustc_version = attr.has_name(sym::rustc_deprecated);
|
||||
depr = Some((Deprecation { since, note, suggestion, is_since_rustc_version }, attr.span));
|
||||
}
|
||||
|
||||
|
@ -816,7 +811,6 @@ pub fn find_repr_attrs(sess: &Session, attr: &Attribute) -> Vec<ReprAttr> {
|
|||
let diagnostic = &sess.parse_sess.span_diagnostic;
|
||||
if attr.has_name(sym::repr) {
|
||||
if let Some(items) = attr.meta_item_list() {
|
||||
sess.mark_attr_used(attr);
|
||||
for item in items {
|
||||
let mut recognised = false;
|
||||
if item.is_word() {
|
||||
|
@ -1015,14 +1009,13 @@ pub enum TransparencyError {
|
|||
}
|
||||
|
||||
pub fn find_transparency(
|
||||
sess: &Session,
|
||||
attrs: &[Attribute],
|
||||
macro_rules: bool,
|
||||
) -> (Transparency, Option<TransparencyError>) {
|
||||
let mut transparency = None;
|
||||
let mut error = None;
|
||||
for attr in attrs {
|
||||
if sess.check_name(attr, sym::rustc_macro_transparency) {
|
||||
if attr.has_name(sym::rustc_macro_transparency) {
|
||||
if let Some((_, old_span)) = transparency {
|
||||
error = Some(TransparencyError::MultipleTransparencyAttrs(old_span, attr.span));
|
||||
break;
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue