Change to lint

This commit is contained in:
Jack Huey 2022-02-07 01:23:37 -05:00
parent c20b4f5584
commit 3f504f6984
8 changed files with 75 additions and 21 deletions

View File

@ -15,7 +15,9 @@ use rustc_ast_pretty::pprust::{self, State};
use rustc_data_structures::fx::FxHashMap;
use rustc_errors::{error_code, pluralize, struct_span_err, Applicability};
use rustc_parse::validate_attr;
use rustc_session::lint::builtin::{MISSING_ABI, PATTERNS_IN_FNS_WITHOUT_BODY};
use rustc_session::lint::builtin::{
DEPRECATED_WHERE_CLAUSE_LOCATION, MISSING_ABI, PATTERNS_IN_FNS_WITHOUT_BODY,
};
use rustc_session::lint::{BuiltinLintDiagnostics, LintBuffer};
use rustc_session::Session;
use rustc_span::source_map::Spanned;
@ -123,11 +125,11 @@ impl<'a> AstValidator<'a> {
}
fn check_gat_where(
&self,
&mut self,
id: NodeId,
before_predicates: &[WherePredicate],
where_clauses: (ast::TyAliasWhereClause, ast::TyAliasWhereClause),
) {
let sess = &self.session;
if !before_predicates.is_empty() {
let mut state = State::new();
if !where_clauses.1.0 {
@ -145,14 +147,16 @@ impl<'a> AstValidator<'a> {
state.print_where_predicate(p);
}
let suggestion = state.s.eof();
sess.struct_span_err(where_clauses.0.1, "where clause not allowed here")
.span_suggestion(
self.lint_buffer.buffer_lint_with_diagnostic(
DEPRECATED_WHERE_CLAUSE_LOCATION,
id,
where_clauses.0.1,
"where clause not allowed here",
BuiltinLintDiagnostics::DeprecatedWhereclauseLocation(
where_clauses.1.1.shrink_to_hi(),
"move it here",
suggestion,
Applicability::MachineApplicable,
)
.emit();
),
);
}
}
@ -1568,6 +1572,7 @@ impl<'a> Visitor<'a> for AstValidator<'a> {
self.check_type_no_bounds(bounds, "`impl`s");
if ty.is_some() {
self.check_gat_where(
item.id,
generics.where_clause.predicates.split_at(*where_predicates_split).0,
*where_clauses,
);

View File

@ -818,6 +818,14 @@ pub trait LintContext: Sized {
}
}
},
BuiltinLintDiagnostics::DeprecatedWhereclauseLocation(new_span, suggestion) => {
db.span_suggestion(
new_span,
"move it here",
suggestion,
Applicability::MachineApplicable,
);
},
}
// Rewrap `db`, and pass control to the user.
decorate(LintDiagnosticBuilder::new(db));

View File

@ -3127,6 +3127,7 @@ declare_lint_pass! {
DUPLICATE_MACRO_ATTRIBUTES,
SUSPICIOUS_AUTO_TRAIT_IMPLS,
UNEXPECTED_CFGS,
DEPRECATED_WHERE_CLAUSE_LOCATION,
]
}
@ -3737,3 +3738,36 @@ declare_lint! {
reference: "issue #93367 <https://github.com/rust-lang/rust/issues/93367>",
};
}
declare_lint! {
/// The `deprecated_where_clause_location` lint detects when a where clause in front of the equals
/// in an associated type.
///
/// ### Example
///
/// ```rust
/// #![feature(generic_associated_types)]
///
/// trait Trait {
/// type Assoc<'a> where Self: 'a;
/// }
///
/// impl Trait for () {
/// type Assoc<'a> where Self: 'a = ();
/// }
/// ```
///
/// {{produces}}
///
/// ### Explanation
///
/// The preferred location for where clauses on associated types in impls
/// is after the type. However, for most of generic associated types development,
/// it was only accepted before the equals. To provide a transition period and
/// further evaluate this change, both are currently accepted. At some point in
/// the future, this may be disallowed at an edition boundary; but, that is
/// undecided currently.
pub DEPRECATED_WHERE_CLAUSE_LOCATION,
Warn,
"deprecated where clause location"
}

View File

@ -427,6 +427,7 @@ pub enum BuiltinLintDiagnostics {
NamedAsmLabel(String),
UnicodeTextFlow(Span, String),
UnexpectedCfg((Symbol, Span), Option<(Symbol, Span)>),
DeprecatedWhereclauseLocation(Span, String),
}
/// Lints that are buffered up early on in the `Session` before the

View File

@ -1,10 +1,12 @@
error: where clause not allowed here
warning: where clause not allowed here
--> $DIR/issue-87735.rs:15:19
|
LL | type Output<'a> where Self: 'a = &'a [T];
| ^^^^^^^^^^^^^^ - help: move it here: `where Self: 'a`
|
= note: `#[warn(deprecated_where_clause_location)]` on by default
error: where clause not allowed here
warning: where clause not allowed here
--> $DIR/issue-87735.rs:36:19
|
LL | type Output<'a> where Self: 'a = FooRef<'a, U>;
@ -16,6 +18,6 @@ error[E0207]: the type parameter `U` is not constrained by the impl trait, self
LL | impl<'b, T, U> AsRef2 for Foo<T>
| ^ unconstrained type parameter
error: aborting due to 3 previous errors
error: aborting due to previous error; 2 warnings emitted
For more information about this error, try `rustc --explain E0207`.

View File

@ -1,8 +1,10 @@
error: where clause not allowed here
warning: where clause not allowed here
--> $DIR/issue-87748.rs:16:24
|
LL | type Assoc<'a, 'b> where 'b: 'a = u32;
| ^^^^^^^^^^^^ - help: move it here: `where 'b: 'a`
|
= note: `#[warn(deprecated_where_clause_location)]` on by default
error[E0478]: lifetime bound not satisfied
--> $DIR/issue-87748.rs:18:5
@ -21,6 +23,6 @@ note: but lifetime parameter must outlive the anonymous lifetime #1 defined here
LL | fn do_sth(_: u32) {}
| ^^^^^^^^^^^^^^^^^
error: aborting due to 2 previous errors
error: aborting due to previous error; 1 warning emitted
For more information about this error, try `rustc --explain E0478`.

View File

@ -20,10 +20,10 @@ trait Trait {
impl Trait for u32 {
// Not fine, suggests moving.
type Assoc where u32: Copy = ();
//~^ ERROR where clause not allowed here
//~^ WARNING where clause not allowed here
// Not fine, suggests moving `u32: Copy`
type Assoc2 where u32: Copy = () where i32: Copy;
//~^ ERROR where clause not allowed here
//~^ WARNING where clause not allowed here
}
impl Trait for i32 {
@ -31,7 +31,7 @@ impl Trait for i32 {
type Assoc = () where u32: Copy;
// Not fine, suggests moving both.
type Assoc2 where u32: Copy, i32: Copy = ();
//~^ ERROR where clause not allowed here
//~^ WARNING where clause not allowed here
}
fn main() {}

View File

@ -10,23 +10,25 @@ error: where clauses are not allowed after the type for type aliases
LL | type Baz = () where;
| ^^^^^
error: where clause not allowed here
warning: where clause not allowed here
--> $DIR/type-alias-where.rs:22:16
|
LL | type Assoc where u32: Copy = ();
| ^^^^^^^^^^^^^^^ - help: move it here: `where u32: Copy`
|
= note: `#[warn(deprecated_where_clause_location)]` on by default
error: where clause not allowed here
warning: where clause not allowed here
--> $DIR/type-alias-where.rs:25:17
|
LL | type Assoc2 where u32: Copy = () where i32: Copy;
| ^^^^^^^^^^^^^^^ - help: move it here: `, u32: Copy`
error: where clause not allowed here
warning: where clause not allowed here
--> $DIR/type-alias-where.rs:33:17
|
LL | type Assoc2 where u32: Copy, i32: Copy = ();
| ^^^^^^^^^^^^^^^^^^^^^^^^^^ - help: move it here: `where u32: Copy, i32: Copy`
error: aborting due to 5 previous errors
error: aborting due to 2 previous errors; 3 warnings emitted