Rollup merge of #128524 - chenyukang:yukang-fix-127930-invalid-outer-style-sugg, r=cjgillot
Don't suggest turning crate-level attributes into outer style Fixes #127930
This commit is contained in:
commit
dfe7d5c31e
13 changed files with 70 additions and 53 deletions
|
@ -76,6 +76,7 @@ impl<'a> Parser<'a> {
|
|||
token::CommentKind::Line => OuterAttributeType::DocComment,
|
||||
token::CommentKind::Block => OuterAttributeType::DocBlockComment,
|
||||
},
|
||||
true,
|
||||
) {
|
||||
err.note(fluent::parse_note);
|
||||
err.span_suggestion_verbose(
|
||||
|
@ -139,7 +140,11 @@ impl<'a> Parser<'a> {
|
|||
|
||||
// Emit error if inner attribute is encountered and forbidden.
|
||||
if style == ast::AttrStyle::Inner {
|
||||
this.error_on_forbidden_inner_attr(attr_sp, inner_parse_policy);
|
||||
this.error_on_forbidden_inner_attr(
|
||||
attr_sp,
|
||||
inner_parse_policy,
|
||||
item.is_valid_for_outer_style(),
|
||||
);
|
||||
}
|
||||
|
||||
Ok(attr::mk_attr_from_item(&self.psess.attr_id_generator, item, None, style, attr_sp))
|
||||
|
@ -151,6 +156,7 @@ impl<'a> Parser<'a> {
|
|||
err: &mut Diag<'_>,
|
||||
span: Span,
|
||||
attr_type: OuterAttributeType,
|
||||
suggest_to_outer: bool,
|
||||
) -> Option<Span> {
|
||||
let mut snapshot = self.create_snapshot_for_diagnostic();
|
||||
let lo = span.lo()
|
||||
|
@ -185,16 +191,18 @@ impl<'a> Parser<'a> {
|
|||
// FIXME(#100717)
|
||||
err.arg("item", item.kind.descr());
|
||||
err.span_label(item.span, fluent::parse_label_does_not_annotate_this);
|
||||
err.span_suggestion_verbose(
|
||||
replacement_span,
|
||||
fluent::parse_sugg_change_inner_to_outer,
|
||||
match attr_type {
|
||||
OuterAttributeType::Attribute => "",
|
||||
OuterAttributeType::DocBlockComment => "*",
|
||||
OuterAttributeType::DocComment => "/",
|
||||
},
|
||||
rustc_errors::Applicability::MachineApplicable,
|
||||
);
|
||||
if suggest_to_outer {
|
||||
err.span_suggestion_verbose(
|
||||
replacement_span,
|
||||
fluent::parse_sugg_change_inner_to_outer,
|
||||
match attr_type {
|
||||
OuterAttributeType::Attribute => "",
|
||||
OuterAttributeType::DocBlockComment => "*",
|
||||
OuterAttributeType::DocComment => "/",
|
||||
},
|
||||
rustc_errors::Applicability::MachineApplicable,
|
||||
);
|
||||
}
|
||||
return None;
|
||||
}
|
||||
Err(item_err) => {
|
||||
|
@ -205,7 +213,12 @@ impl<'a> Parser<'a> {
|
|||
Some(replacement_span)
|
||||
}
|
||||
|
||||
pub(super) fn error_on_forbidden_inner_attr(&self, attr_sp: Span, policy: InnerAttrPolicy) {
|
||||
pub(super) fn error_on_forbidden_inner_attr(
|
||||
&self,
|
||||
attr_sp: Span,
|
||||
policy: InnerAttrPolicy,
|
||||
suggest_to_outer: bool,
|
||||
) {
|
||||
if let InnerAttrPolicy::Forbidden(reason) = policy {
|
||||
let mut diag = match reason.as_ref().copied() {
|
||||
Some(InnerAttrForbiddenReason::AfterOuterDocComment { prev_doc_comment_span }) => {
|
||||
|
@ -239,6 +252,7 @@ impl<'a> Parser<'a> {
|
|||
&mut diag,
|
||||
attr_sp,
|
||||
OuterAttributeType::Attribute,
|
||||
suggest_to_outer,
|
||||
)
|
||||
.is_some()
|
||||
{
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue