2020-08-27 20:00:21 +10:00
|
|
|
// check-fail
|
|
|
|
// Tests error conditions for specifying diagnostics using #[derive(SessionDiagnostic)]
|
|
|
|
|
2022-06-29 09:21:44 +01:00
|
|
|
// normalize-stderr-test "the following other types implement trait `IntoDiagnosticArg`:(?:.*\n){0,9}\s+and \d+ others" -> "normalized in stderr"
|
|
|
|
|
2021-06-07 17:08:13 +02:00
|
|
|
// The proc_macro2 crate handles spans differently when on beta/stable release rather than nightly,
|
|
|
|
// changing the output of this test. Since SessionDiagnostic is strictly internal to the compiler
|
|
|
|
// the test is just ignored on stable and beta:
|
|
|
|
// ignore-beta
|
|
|
|
// ignore-stable
|
|
|
|
|
2020-08-27 20:00:21 +10:00
|
|
|
#![feature(rustc_private)]
|
|
|
|
#![crate_type = "lib"]
|
|
|
|
|
|
|
|
extern crate rustc_span;
|
|
|
|
use rustc_span::symbol::Ident;
|
2022-03-30 09:45:36 +01:00
|
|
|
use rustc_span::Span;
|
2020-08-27 20:00:21 +10:00
|
|
|
|
|
|
|
extern crate rustc_macros;
|
2022-06-30 08:57:45 +01:00
|
|
|
use rustc_macros::{SessionDiagnostic, LintDiagnostic, SessionSubdiagnostic};
|
2020-08-27 20:00:21 +10:00
|
|
|
|
|
|
|
extern crate rustc_middle;
|
|
|
|
use rustc_middle::ty::Ty;
|
|
|
|
|
|
|
|
extern crate rustc_errors;
|
2022-07-11 17:15:31 +01:00
|
|
|
use rustc_errors::{Applicability, MultiSpan};
|
2020-08-27 20:00:21 +10:00
|
|
|
|
|
|
|
extern crate rustc_session;
|
|
|
|
|
|
|
|
#[derive(SessionDiagnostic)]
|
2022-06-23 14:51:44 +01:00
|
|
|
#[error(typeck::ambiguous_lifetime_bound, code = "E0123")]
|
2020-08-27 20:00:21 +10:00
|
|
|
struct Hello {}
|
|
|
|
|
|
|
|
#[derive(SessionDiagnostic)]
|
2022-06-23 14:51:44 +01:00
|
|
|
#[warning(typeck::ambiguous_lifetime_bound, code = "E0123")]
|
2022-03-31 08:35:17 +01:00
|
|
|
struct HelloWarn {}
|
|
|
|
|
|
|
|
#[derive(SessionDiagnostic)]
|
2022-06-23 14:51:44 +01:00
|
|
|
#[error(typeck::ambiguous_lifetime_bound, code = "E0123")]
|
2020-08-27 20:00:21 +10:00
|
|
|
//~^ ERROR `#[derive(SessionDiagnostic)]` can only be used on structs
|
|
|
|
enum SessionDiagnosticOnEnum {
|
|
|
|
Foo,
|
|
|
|
Bar,
|
|
|
|
}
|
|
|
|
|
|
|
|
#[derive(SessionDiagnostic)]
|
2022-06-23 14:51:44 +01:00
|
|
|
#[error(typeck::ambiguous_lifetime_bound, code = "E0123")]
|
2020-08-27 20:00:21 +10:00
|
|
|
#[error = "E0123"]
|
2022-04-27 04:06:13 +01:00
|
|
|
//~^ ERROR `#[error = ...]` is not a valid attribute
|
2022-03-31 08:35:17 +01:00
|
|
|
struct WrongStructAttrStyle {}
|
2020-08-27 20:00:21 +10:00
|
|
|
|
|
|
|
#[derive(SessionDiagnostic)]
|
2022-06-23 14:51:44 +01:00
|
|
|
#[nonsense(typeck::ambiguous_lifetime_bound, code = "E0123")]
|
2022-04-27 04:06:13 +01:00
|
|
|
//~^ ERROR `#[nonsense(...)]` is not a valid attribute
|
2022-03-31 08:35:17 +01:00
|
|
|
//~^^ ERROR diagnostic kind not specified
|
|
|
|
//~^^^ ERROR cannot find attribute `nonsense` in this scope
|
|
|
|
struct InvalidStructAttr {}
|
|
|
|
|
|
|
|
#[derive(SessionDiagnostic)]
|
|
|
|
#[error("E0123")]
|
2022-04-27 04:06:13 +01:00
|
|
|
//~^ ERROR `#[error("...")]` is not a valid attribute
|
2022-06-23 14:51:44 +01:00
|
|
|
//~^^ ERROR diagnostic slug not specified
|
2022-03-31 08:35:17 +01:00
|
|
|
struct InvalidLitNestedAttr {}
|
|
|
|
|
|
|
|
#[derive(SessionDiagnostic)]
|
2022-06-23 14:51:44 +01:00
|
|
|
#[error(nonsense, code = "E0123")]
|
|
|
|
//~^ ERROR cannot find value `nonsense` in module `rustc_errors::fluent`
|
2022-03-31 08:35:17 +01:00
|
|
|
struct InvalidNestedStructAttr {}
|
|
|
|
|
|
|
|
#[derive(SessionDiagnostic)]
|
|
|
|
#[error(nonsense("foo"), code = "E0123", slug = "foo")]
|
2022-04-27 04:06:13 +01:00
|
|
|
//~^ ERROR `#[error(nonsense(...))]` is not a valid attribute
|
2022-06-23 14:51:44 +01:00
|
|
|
//~^^ ERROR diagnostic slug not specified
|
2022-03-31 08:35:17 +01:00
|
|
|
struct InvalidNestedStructAttr1 {}
|
|
|
|
|
|
|
|
#[derive(SessionDiagnostic)]
|
|
|
|
#[error(nonsense = "...", code = "E0123", slug = "foo")]
|
2022-04-27 04:06:13 +01:00
|
|
|
//~^ ERROR `#[error(nonsense = ...)]` is not a valid attribute
|
2022-06-23 14:51:44 +01:00
|
|
|
//~^^ ERROR diagnostic slug not specified
|
2022-03-31 08:35:17 +01:00
|
|
|
struct InvalidNestedStructAttr2 {}
|
|
|
|
|
|
|
|
#[derive(SessionDiagnostic)]
|
|
|
|
#[error(nonsense = 4, code = "E0123", slug = "foo")]
|
2022-04-27 04:06:13 +01:00
|
|
|
//~^ ERROR `#[error(nonsense = ...)]` is not a valid attribute
|
2022-06-23 14:51:44 +01:00
|
|
|
//~^^ ERROR diagnostic slug not specified
|
2022-03-31 08:35:17 +01:00
|
|
|
struct InvalidNestedStructAttr3 {}
|
|
|
|
|
|
|
|
#[derive(SessionDiagnostic)]
|
2022-06-23 14:51:44 +01:00
|
|
|
#[error(typeck::ambiguous_lifetime_bound, code = "E0123", slug = "foo")]
|
|
|
|
//~^ ERROR `#[error(slug = ...)]` is not a valid attribute
|
|
|
|
struct InvalidNestedStructAttr4 {}
|
|
|
|
|
|
|
|
#[derive(SessionDiagnostic)]
|
|
|
|
#[error(typeck::ambiguous_lifetime_bound, code = "E0123")]
|
2020-08-27 20:00:21 +10:00
|
|
|
struct WrongPlaceField {
|
2022-03-31 13:10:13 +01:00
|
|
|
#[suggestion = "bar"]
|
2022-04-27 04:06:13 +01:00
|
|
|
//~^ ERROR `#[suggestion = ...]` is not a valid attribute
|
2020-08-27 20:00:21 +10:00
|
|
|
sp: Span,
|
|
|
|
}
|
|
|
|
|
|
|
|
#[derive(SessionDiagnostic)]
|
2022-06-23 14:51:44 +01:00
|
|
|
#[error(typeck::ambiguous_lifetime_bound, code = "E0123")]
|
|
|
|
#[error(typeck::ambiguous_lifetime_bound, code = "E0456")]
|
2022-04-27 04:28:21 +01:00
|
|
|
//~^ ERROR specified multiple times
|
|
|
|
//~^^ ERROR specified multiple times
|
|
|
|
//~^^^ ERROR specified multiple times
|
2020-08-27 20:00:21 +10:00
|
|
|
struct ErrorSpecifiedTwice {}
|
|
|
|
|
|
|
|
#[derive(SessionDiagnostic)]
|
2022-06-23 14:51:44 +01:00
|
|
|
#[error(typeck::ambiguous_lifetime_bound, code = "E0123")]
|
|
|
|
#[warning(typeck::ambiguous_lifetime_bound, code = "E0293")]
|
2022-04-27 04:28:21 +01:00
|
|
|
//~^ ERROR specified multiple times
|
|
|
|
//~^^ ERROR specified multiple times
|
|
|
|
//~^^^ ERROR specified multiple times
|
2022-03-31 08:35:17 +01:00
|
|
|
struct WarnSpecifiedAfterError {}
|
2020-08-27 20:00:21 +10:00
|
|
|
|
|
|
|
#[derive(SessionDiagnostic)]
|
2022-06-23 14:51:44 +01:00
|
|
|
#[error(typeck::ambiguous_lifetime_bound, code = "E0456", code = "E0457")]
|
2022-04-27 04:28:21 +01:00
|
|
|
//~^ ERROR specified multiple times
|
2022-03-31 08:35:17 +01:00
|
|
|
struct CodeSpecifiedTwice {}
|
2020-08-27 20:00:21 +10:00
|
|
|
|
|
|
|
#[derive(SessionDiagnostic)]
|
2022-06-23 14:51:44 +01:00
|
|
|
#[error(typeck::ambiguous_lifetime_bound, typeck::ambiguous_lifetime_bound, code = "E0456")]
|
|
|
|
//~^ ERROR `#[error(typeck::ambiguous_lifetime_bound)]` is not a valid attribute
|
2022-03-31 08:35:17 +01:00
|
|
|
struct SlugSpecifiedTwice {}
|
2020-08-27 20:00:21 +10:00
|
|
|
|
|
|
|
#[derive(SessionDiagnostic)]
|
2022-03-31 08:35:17 +01:00
|
|
|
struct KindNotProvided {} //~ ERROR diagnostic kind not specified
|
2020-08-27 20:00:21 +10:00
|
|
|
|
|
|
|
#[derive(SessionDiagnostic)]
|
2022-06-23 14:51:44 +01:00
|
|
|
#[error(code = "E0456")]
|
|
|
|
//~^ ERROR diagnostic slug not specified
|
2022-03-31 08:35:17 +01:00
|
|
|
struct SlugNotProvided {}
|
2020-08-27 20:00:21 +10:00
|
|
|
|
|
|
|
#[derive(SessionDiagnostic)]
|
2022-06-23 14:51:44 +01:00
|
|
|
#[error(typeck::ambiguous_lifetime_bound)]
|
2022-03-31 08:35:17 +01:00
|
|
|
struct CodeNotProvided {}
|
|
|
|
|
|
|
|
#[derive(SessionDiagnostic)]
|
2022-06-23 14:51:44 +01:00
|
|
|
#[error(typeck::ambiguous_lifetime_bound, code = "E0123")]
|
2022-03-31 08:35:17 +01:00
|
|
|
struct MessageWrongType {
|
2022-03-31 08:50:45 +01:00
|
|
|
#[primary_span]
|
2022-07-11 17:15:31 +01:00
|
|
|
//~^ ERROR `#[primary_span]` attribute can only be applied to fields of type `Span` or `MultiSpan`
|
2022-03-31 08:35:17 +01:00
|
|
|
foo: String,
|
|
|
|
}
|
|
|
|
|
|
|
|
#[derive(SessionDiagnostic)]
|
2022-06-23 14:51:44 +01:00
|
|
|
#[error(typeck::ambiguous_lifetime_bound, code = "E0123")]
|
2022-03-31 08:35:17 +01:00
|
|
|
struct InvalidPathFieldAttr {
|
|
|
|
#[nonsense]
|
2022-04-27 04:06:13 +01:00
|
|
|
//~^ ERROR `#[nonsense]` is not a valid attribute
|
2022-03-31 08:35:17 +01:00
|
|
|
//~^^ ERROR cannot find attribute `nonsense` in this scope
|
|
|
|
foo: String,
|
|
|
|
}
|
|
|
|
|
|
|
|
#[derive(SessionDiagnostic)]
|
2022-06-23 14:51:44 +01:00
|
|
|
#[error(typeck::ambiguous_lifetime_bound, code = "E0123")]
|
2020-08-27 20:00:21 +10:00
|
|
|
struct ErrorWithField {
|
|
|
|
name: String,
|
2022-06-23 14:51:44 +01:00
|
|
|
#[label(typeck::label)]
|
2022-03-30 10:04:03 +01:00
|
|
|
span: Span,
|
2020-08-27 20:00:21 +10:00
|
|
|
}
|
|
|
|
|
|
|
|
#[derive(SessionDiagnostic)]
|
2022-06-23 14:51:44 +01:00
|
|
|
#[error(typeck::ambiguous_lifetime_bound, code = "E0123")]
|
2020-08-27 20:00:21 +10:00
|
|
|
struct ErrorWithMessageAppliedToField {
|
2022-06-23 14:51:44 +01:00
|
|
|
#[label(typeck::label)]
|
2022-07-11 17:15:31 +01:00
|
|
|
//~^ ERROR the `#[label(...)]` attribute can only be applied to fields of type `Span` or `MultiSpan`
|
2020-08-27 20:00:21 +10:00
|
|
|
name: String,
|
|
|
|
}
|
|
|
|
|
|
|
|
#[derive(SessionDiagnostic)]
|
2022-06-23 14:51:44 +01:00
|
|
|
#[error(typeck::ambiguous_lifetime_bound, code = "E0123")]
|
2020-08-27 20:00:21 +10:00
|
|
|
struct ErrorWithNonexistentField {
|
2022-06-23 14:51:44 +01:00
|
|
|
#[suggestion(typeck::suggestion, code = "{name}")]
|
2022-03-31 08:35:17 +01:00
|
|
|
//~^ ERROR `name` doesn't refer to a field on this type
|
2022-03-31 10:24:46 +01:00
|
|
|
suggestion: (Span, Applicability),
|
2020-08-27 20:00:21 +10:00
|
|
|
}
|
|
|
|
|
|
|
|
#[derive(SessionDiagnostic)]
|
|
|
|
//~^ ERROR invalid format string: expected `'}'`
|
2022-06-23 14:51:44 +01:00
|
|
|
#[error(typeck::ambiguous_lifetime_bound, code = "E0123")]
|
2020-08-27 20:00:21 +10:00
|
|
|
struct ErrorMissingClosingBrace {
|
2022-06-23 14:51:44 +01:00
|
|
|
#[suggestion(typeck::suggestion, code = "{name")]
|
2022-03-31 10:24:46 +01:00
|
|
|
suggestion: (Span, Applicability),
|
2020-08-27 20:00:21 +10:00
|
|
|
name: String,
|
2022-03-30 09:45:36 +01:00
|
|
|
val: usize,
|
2020-08-27 20:00:21 +10:00
|
|
|
}
|
|
|
|
|
|
|
|
#[derive(SessionDiagnostic)]
|
|
|
|
//~^ ERROR invalid format string: unmatched `}`
|
2022-06-23 14:51:44 +01:00
|
|
|
#[error(typeck::ambiguous_lifetime_bound, code = "E0123")]
|
2020-08-27 20:00:21 +10:00
|
|
|
struct ErrorMissingOpeningBrace {
|
2022-06-23 14:51:44 +01:00
|
|
|
#[suggestion(typeck::suggestion, code = "name}")]
|
2022-03-31 10:24:46 +01:00
|
|
|
suggestion: (Span, Applicability),
|
2020-08-27 20:00:21 +10:00
|
|
|
name: String,
|
2022-03-30 09:45:36 +01:00
|
|
|
val: usize,
|
2020-08-27 20:00:21 +10:00
|
|
|
}
|
|
|
|
|
|
|
|
#[derive(SessionDiagnostic)]
|
2022-06-23 14:51:44 +01:00
|
|
|
#[error(typeck::ambiguous_lifetime_bound, code = "E0123")]
|
2020-08-27 20:00:21 +10:00
|
|
|
struct LabelOnSpan {
|
2022-06-23 14:51:44 +01:00
|
|
|
#[label(typeck::label)]
|
2022-03-30 10:04:03 +01:00
|
|
|
sp: Span,
|
2020-08-27 20:00:21 +10:00
|
|
|
}
|
|
|
|
|
|
|
|
#[derive(SessionDiagnostic)]
|
2022-06-23 14:51:44 +01:00
|
|
|
#[error(typeck::ambiguous_lifetime_bound, code = "E0123")]
|
2020-08-27 20:00:21 +10:00
|
|
|
struct LabelOnNonSpan {
|
2022-06-23 14:51:44 +01:00
|
|
|
#[label(typeck::label)]
|
2022-07-11 17:15:31 +01:00
|
|
|
//~^ ERROR the `#[label(...)]` attribute can only be applied to fields of type `Span` or `MultiSpan`
|
2020-08-27 20:00:21 +10:00
|
|
|
id: u32,
|
|
|
|
}
|
|
|
|
|
|
|
|
#[derive(SessionDiagnostic)]
|
2022-06-23 14:51:44 +01:00
|
|
|
#[error(typeck::ambiguous_lifetime_bound, code = "E0123")]
|
2020-08-27 20:00:21 +10:00
|
|
|
struct Suggest {
|
2022-06-23 14:51:44 +01:00
|
|
|
#[suggestion(typeck::suggestion, code = "This is the suggested code")]
|
|
|
|
#[suggestion_short(typeck::suggestion, code = "This is the suggested code")]
|
|
|
|
#[suggestion_hidden(typeck::suggestion, code = "This is the suggested code")]
|
|
|
|
#[suggestion_verbose(typeck::suggestion, code = "This is the suggested code")]
|
2020-08-27 20:00:21 +10:00
|
|
|
suggestion: (Span, Applicability),
|
|
|
|
}
|
|
|
|
|
|
|
|
#[derive(SessionDiagnostic)]
|
2022-06-23 14:51:44 +01:00
|
|
|
#[error(typeck::ambiguous_lifetime_bound, code = "E0123")]
|
2020-08-27 20:00:21 +10:00
|
|
|
struct SuggestWithoutCode {
|
2022-06-23 14:51:44 +01:00
|
|
|
#[suggestion(typeck::suggestion)]
|
2020-08-27 20:00:21 +10:00
|
|
|
suggestion: (Span, Applicability),
|
|
|
|
}
|
|
|
|
|
|
|
|
#[derive(SessionDiagnostic)]
|
2022-06-23 14:51:44 +01:00
|
|
|
#[error(typeck::ambiguous_lifetime_bound, code = "E0123")]
|
2020-08-27 20:00:21 +10:00
|
|
|
struct SuggestWithBadKey {
|
2022-03-31 13:10:13 +01:00
|
|
|
#[suggestion(nonsense = "bar")]
|
2022-04-27 04:06:13 +01:00
|
|
|
//~^ ERROR `#[suggestion(nonsense = ...)]` is not a valid attribute
|
2020-08-27 20:00:21 +10:00
|
|
|
suggestion: (Span, Applicability),
|
|
|
|
}
|
|
|
|
|
|
|
|
#[derive(SessionDiagnostic)]
|
2022-06-23 14:51:44 +01:00
|
|
|
#[error(typeck::ambiguous_lifetime_bound, code = "E0123")]
|
2020-08-27 20:00:21 +10:00
|
|
|
struct SuggestWithShorthandMsg {
|
2022-03-31 13:10:13 +01:00
|
|
|
#[suggestion(msg = "bar")]
|
2022-04-27 04:06:13 +01:00
|
|
|
//~^ ERROR `#[suggestion(msg = ...)]` is not a valid attribute
|
2020-08-27 20:00:21 +10:00
|
|
|
suggestion: (Span, Applicability),
|
|
|
|
}
|
|
|
|
|
|
|
|
#[derive(SessionDiagnostic)]
|
2022-06-23 14:51:44 +01:00
|
|
|
#[error(typeck::ambiguous_lifetime_bound, code = "E0123")]
|
2020-08-27 20:00:21 +10:00
|
|
|
struct SuggestWithoutMsg {
|
2022-03-31 13:10:13 +01:00
|
|
|
#[suggestion(code = "bar")]
|
2020-08-27 20:00:21 +10:00
|
|
|
suggestion: (Span, Applicability),
|
|
|
|
}
|
|
|
|
|
|
|
|
#[derive(SessionDiagnostic)]
|
2022-06-23 14:51:44 +01:00
|
|
|
#[error(typeck::ambiguous_lifetime_bound, code = "E0123")]
|
2020-08-27 20:00:21 +10:00
|
|
|
struct SuggestWithTypesSwapped {
|
2022-06-23 14:51:44 +01:00
|
|
|
#[suggestion(typeck::suggestion, code = "This is suggested code")]
|
2020-08-27 20:00:21 +10:00
|
|
|
suggestion: (Applicability, Span),
|
|
|
|
}
|
|
|
|
|
|
|
|
#[derive(SessionDiagnostic)]
|
2022-06-23 14:51:44 +01:00
|
|
|
#[error(typeck::ambiguous_lifetime_bound, code = "E0123")]
|
2020-08-27 20:00:21 +10:00
|
|
|
struct SuggestWithWrongTypeApplicabilityOnly {
|
2022-06-23 14:51:44 +01:00
|
|
|
#[suggestion(typeck::suggestion, code = "This is suggested code")]
|
2020-08-27 20:00:21 +10:00
|
|
|
//~^ ERROR wrong field type for suggestion
|
|
|
|
suggestion: Applicability,
|
|
|
|
}
|
|
|
|
|
|
|
|
#[derive(SessionDiagnostic)]
|
2022-06-23 14:51:44 +01:00
|
|
|
#[error(typeck::ambiguous_lifetime_bound, code = "E0123")]
|
2022-03-30 10:04:03 +01:00
|
|
|
struct SuggestWithSpanOnly {
|
2022-06-23 14:51:44 +01:00
|
|
|
#[suggestion(typeck::suggestion, code = "This is suggested code")]
|
2020-08-27 20:00:21 +10:00
|
|
|
suggestion: Span,
|
|
|
|
}
|
|
|
|
|
|
|
|
#[derive(SessionDiagnostic)]
|
2022-06-23 14:51:44 +01:00
|
|
|
#[error(typeck::ambiguous_lifetime_bound, code = "E0123")]
|
2020-08-27 20:00:21 +10:00
|
|
|
struct SuggestWithDuplicateSpanAndApplicability {
|
2022-06-23 14:51:44 +01:00
|
|
|
#[suggestion(typeck::suggestion, code = "This is suggested code")]
|
2022-03-30 10:04:03 +01:00
|
|
|
//~^ ERROR type of field annotated with `#[suggestion(...)]` contains more than one `Span`
|
2020-08-27 20:00:21 +10:00
|
|
|
suggestion: (Span, Span, Applicability),
|
|
|
|
}
|
|
|
|
|
|
|
|
#[derive(SessionDiagnostic)]
|
2022-06-23 14:51:44 +01:00
|
|
|
#[error(typeck::ambiguous_lifetime_bound, code = "E0123")]
|
2020-08-27 20:00:21 +10:00
|
|
|
struct SuggestWithDuplicateApplicabilityAndSpan {
|
2022-06-23 14:51:44 +01:00
|
|
|
#[suggestion(typeck::suggestion, code = "This is suggested code")]
|
2020-08-27 20:00:21 +10:00
|
|
|
//~^ ERROR type of field annotated with `#[suggestion(...)]` contains more than one
|
|
|
|
suggestion: (Applicability, Applicability, Span),
|
|
|
|
}
|
|
|
|
|
|
|
|
#[derive(SessionDiagnostic)]
|
2022-06-23 14:51:44 +01:00
|
|
|
#[error(typeck::ambiguous_lifetime_bound, code = "E0123")]
|
2020-08-27 20:00:21 +10:00
|
|
|
struct WrongKindOfAnnotation {
|
2022-06-23 14:51:44 +01:00
|
|
|
#[label = "bar"]
|
|
|
|
//~^ ERROR `#[label = ...]` is not a valid attribute
|
2020-08-27 20:00:21 +10:00
|
|
|
z: Span,
|
|
|
|
}
|
|
|
|
|
|
|
|
#[derive(SessionDiagnostic)]
|
2022-06-23 14:51:44 +01:00
|
|
|
#[error(typeck::ambiguous_lifetime_bound, code = "E0123")]
|
2020-08-27 20:00:21 +10:00
|
|
|
struct OptionsInErrors {
|
2022-06-23 14:51:44 +01:00
|
|
|
#[label(typeck::label)]
|
2020-08-27 20:00:21 +10:00
|
|
|
label: Option<Span>,
|
2022-06-23 14:51:44 +01:00
|
|
|
#[suggestion(typeck::suggestion)]
|
2020-08-27 20:00:21 +10:00
|
|
|
opt_sugg: Option<(Span, Applicability)>,
|
|
|
|
}
|
|
|
|
|
|
|
|
#[derive(SessionDiagnostic)]
|
2022-06-23 14:51:44 +01:00
|
|
|
#[error(typeck::ambiguous_lifetime_bound, code = "E0456")]
|
2020-08-27 20:00:21 +10:00
|
|
|
struct MoveOutOfBorrowError<'tcx> {
|
|
|
|
name: Ident,
|
|
|
|
ty: Ty<'tcx>,
|
2022-03-31 08:50:45 +01:00
|
|
|
#[primary_span]
|
2022-06-23 14:51:44 +01:00
|
|
|
#[label(typeck::label)]
|
2020-08-27 20:00:21 +10:00
|
|
|
span: Span,
|
2022-06-23 14:51:44 +01:00
|
|
|
#[label(typeck::label)]
|
2020-08-27 20:00:21 +10:00
|
|
|
other_span: Span,
|
2022-06-23 14:51:44 +01:00
|
|
|
#[suggestion(typeck::suggestion, code = "{name}.clone()")]
|
2020-08-27 20:00:21 +10:00
|
|
|
opt_sugg: Option<(Span, Applicability)>,
|
|
|
|
}
|
|
|
|
|
|
|
|
#[derive(SessionDiagnostic)]
|
2022-06-23 14:51:44 +01:00
|
|
|
#[error(typeck::ambiguous_lifetime_bound, code = "E0123")]
|
2020-08-27 20:00:21 +10:00
|
|
|
struct ErrorWithLifetime<'a> {
|
2022-06-23 14:51:44 +01:00
|
|
|
#[label(typeck::label)]
|
2022-03-31 10:24:46 +01:00
|
|
|
span: Span,
|
|
|
|
name: &'a str,
|
|
|
|
}
|
|
|
|
|
|
|
|
#[derive(SessionDiagnostic)]
|
2022-06-23 14:51:44 +01:00
|
|
|
#[error(typeck::ambiguous_lifetime_bound, code = "E0123")]
|
2022-03-31 10:24:46 +01:00
|
|
|
struct ErrorWithDefaultLabelAttr<'a> {
|
|
|
|
#[label]
|
2020-08-27 20:00:21 +10:00
|
|
|
span: Span,
|
|
|
|
name: &'a str,
|
|
|
|
}
|
2022-03-31 09:02:31 +01:00
|
|
|
|
|
|
|
#[derive(SessionDiagnostic)]
|
2022-05-07 07:26:03 +01:00
|
|
|
//~^ ERROR the trait bound `Hello: IntoDiagnosticArg` is not satisfied
|
2022-06-23 14:51:44 +01:00
|
|
|
#[error(typeck::ambiguous_lifetime_bound, code = "E0123")]
|
2022-03-31 09:02:31 +01:00
|
|
|
struct ArgFieldWithoutSkip {
|
|
|
|
#[primary_span]
|
|
|
|
span: Span,
|
|
|
|
other: Hello,
|
|
|
|
}
|
|
|
|
|
|
|
|
#[derive(SessionDiagnostic)]
|
2022-06-23 14:51:44 +01:00
|
|
|
#[error(typeck::ambiguous_lifetime_bound, code = "E0123")]
|
2022-03-31 09:02:31 +01:00
|
|
|
struct ArgFieldWithSkip {
|
|
|
|
#[primary_span]
|
|
|
|
span: Span,
|
|
|
|
// `Hello` does not implement `IntoDiagnosticArg` so this would result in an error if
|
|
|
|
// not for `#[skip_arg]`.
|
|
|
|
#[skip_arg]
|
|
|
|
other: Hello,
|
|
|
|
}
|
2022-03-31 12:10:00 +01:00
|
|
|
|
|
|
|
#[derive(SessionDiagnostic)]
|
2022-06-23 14:51:44 +01:00
|
|
|
#[error(typeck::ambiguous_lifetime_bound, code = "E0123")]
|
2022-03-31 12:10:00 +01:00
|
|
|
struct ErrorWithSpannedNote {
|
|
|
|
#[note]
|
|
|
|
span: Span,
|
|
|
|
}
|
|
|
|
|
|
|
|
#[derive(SessionDiagnostic)]
|
2022-06-23 14:51:44 +01:00
|
|
|
#[error(typeck::ambiguous_lifetime_bound, code = "E0123")]
|
2022-03-31 12:10:00 +01:00
|
|
|
struct ErrorWithSpannedNoteCustom {
|
2022-06-23 14:51:44 +01:00
|
|
|
#[note(typeck::note)]
|
2022-03-31 12:10:00 +01:00
|
|
|
span: Span,
|
|
|
|
}
|
|
|
|
|
|
|
|
#[derive(SessionDiagnostic)]
|
2022-06-23 14:51:44 +01:00
|
|
|
#[error(typeck::ambiguous_lifetime_bound, code = "E0123")]
|
2022-03-31 12:10:00 +01:00
|
|
|
#[note]
|
|
|
|
struct ErrorWithNote {
|
|
|
|
val: String,
|
|
|
|
}
|
|
|
|
|
|
|
|
#[derive(SessionDiagnostic)]
|
2022-06-23 14:51:44 +01:00
|
|
|
#[error(typeck::ambiguous_lifetime_bound, code = "E0123")]
|
|
|
|
#[note(typeck::note)]
|
2022-03-31 12:10:00 +01:00
|
|
|
struct ErrorWithNoteCustom {
|
|
|
|
val: String,
|
|
|
|
}
|
|
|
|
|
|
|
|
#[derive(SessionDiagnostic)]
|
2022-06-23 14:51:44 +01:00
|
|
|
#[error(typeck::ambiguous_lifetime_bound, code = "E0123")]
|
2022-03-31 12:10:00 +01:00
|
|
|
struct ErrorWithSpannedHelp {
|
|
|
|
#[help]
|
|
|
|
span: Span,
|
|
|
|
}
|
|
|
|
|
|
|
|
#[derive(SessionDiagnostic)]
|
2022-06-23 14:51:44 +01:00
|
|
|
#[error(typeck::ambiguous_lifetime_bound, code = "E0123")]
|
2022-03-31 12:10:00 +01:00
|
|
|
struct ErrorWithSpannedHelpCustom {
|
2022-06-23 14:51:44 +01:00
|
|
|
#[help(typeck::help)]
|
2022-03-31 12:10:00 +01:00
|
|
|
span: Span,
|
|
|
|
}
|
|
|
|
|
|
|
|
#[derive(SessionDiagnostic)]
|
2022-06-23 14:51:44 +01:00
|
|
|
#[error(typeck::ambiguous_lifetime_bound, code = "E0123")]
|
2022-03-31 12:10:00 +01:00
|
|
|
#[help]
|
|
|
|
struct ErrorWithHelp {
|
|
|
|
val: String,
|
|
|
|
}
|
|
|
|
|
|
|
|
#[derive(SessionDiagnostic)]
|
2022-06-23 14:51:44 +01:00
|
|
|
#[error(typeck::ambiguous_lifetime_bound, code = "E0123")]
|
|
|
|
#[help(typeck::help)]
|
2022-03-31 12:10:00 +01:00
|
|
|
struct ErrorWithHelpCustom {
|
|
|
|
val: String,
|
|
|
|
}
|
|
|
|
|
|
|
|
#[derive(SessionDiagnostic)]
|
|
|
|
#[help]
|
2022-06-23 14:51:44 +01:00
|
|
|
#[error(typeck::ambiguous_lifetime_bound, code = "E0123")]
|
2022-03-31 12:10:00 +01:00
|
|
|
struct ErrorWithHelpWrongOrder {
|
|
|
|
val: String,
|
|
|
|
}
|
|
|
|
|
|
|
|
#[derive(SessionDiagnostic)]
|
2022-06-23 14:51:44 +01:00
|
|
|
#[help(typeck::help)]
|
|
|
|
#[error(typeck::ambiguous_lifetime_bound, code = "E0123")]
|
2022-03-31 12:10:00 +01:00
|
|
|
struct ErrorWithHelpCustomWrongOrder {
|
|
|
|
val: String,
|
|
|
|
}
|
|
|
|
|
|
|
|
#[derive(SessionDiagnostic)]
|
|
|
|
#[note]
|
2022-06-23 14:51:44 +01:00
|
|
|
#[error(typeck::ambiguous_lifetime_bound, code = "E0123")]
|
2022-03-31 12:10:00 +01:00
|
|
|
struct ErrorWithNoteWrongOrder {
|
|
|
|
val: String,
|
|
|
|
}
|
|
|
|
|
|
|
|
#[derive(SessionDiagnostic)]
|
2022-06-23 14:51:44 +01:00
|
|
|
#[note(typeck::note)]
|
|
|
|
#[error(typeck::ambiguous_lifetime_bound, code = "E0123")]
|
2022-03-31 12:10:00 +01:00
|
|
|
struct ErrorWithNoteCustomWrongOrder {
|
|
|
|
val: String,
|
|
|
|
}
|
2022-04-27 05:43:36 +01:00
|
|
|
|
|
|
|
#[derive(SessionDiagnostic)]
|
2022-06-23 14:51:44 +01:00
|
|
|
#[error(typeck::ambiguous_lifetime_bound, code = "E0123")]
|
2022-04-27 05:43:36 +01:00
|
|
|
struct ApplicabilityInBoth {
|
2022-06-23 14:51:44 +01:00
|
|
|
#[suggestion(typeck::suggestion, code = "...", applicability = "maybe-incorrect")]
|
2022-04-27 05:43:36 +01:00
|
|
|
//~^ ERROR applicability cannot be set in both the field and attribute
|
|
|
|
suggestion: (Span, Applicability),
|
|
|
|
}
|
|
|
|
|
|
|
|
#[derive(SessionDiagnostic)]
|
2022-06-23 14:51:44 +01:00
|
|
|
#[error(typeck::ambiguous_lifetime_bound, code = "E0123")]
|
2022-04-27 05:43:36 +01:00
|
|
|
struct InvalidApplicability {
|
2022-06-23 14:51:44 +01:00
|
|
|
#[suggestion(typeck::suggestion, code = "...", applicability = "batman")]
|
2022-04-27 05:43:36 +01:00
|
|
|
//~^ ERROR invalid applicability
|
|
|
|
suggestion: Span,
|
|
|
|
}
|
|
|
|
|
|
|
|
#[derive(SessionDiagnostic)]
|
2022-06-23 14:51:44 +01:00
|
|
|
#[error(typeck::ambiguous_lifetime_bound, code = "E0123")]
|
2022-04-27 05:43:36 +01:00
|
|
|
struct ValidApplicability {
|
2022-06-23 14:51:44 +01:00
|
|
|
#[suggestion(typeck::suggestion, code = "...", applicability = "maybe-incorrect")]
|
2022-04-27 05:43:36 +01:00
|
|
|
suggestion: Span,
|
|
|
|
}
|
|
|
|
|
|
|
|
#[derive(SessionDiagnostic)]
|
2022-06-23 14:51:44 +01:00
|
|
|
#[error(typeck::ambiguous_lifetime_bound, code = "E0123")]
|
2022-04-27 05:43:36 +01:00
|
|
|
struct NoApplicability {
|
2022-06-23 14:51:44 +01:00
|
|
|
#[suggestion(typeck::suggestion, code = "...")]
|
2022-04-27 05:43:36 +01:00
|
|
|
suggestion: Span,
|
|
|
|
}
|
2022-04-27 05:59:48 +01:00
|
|
|
|
|
|
|
#[derive(SessionSubdiagnostic)]
|
2022-06-23 16:12:52 +01:00
|
|
|
#[note(parser::add_paren)]
|
2022-04-27 05:59:48 +01:00
|
|
|
struct Note;
|
|
|
|
|
|
|
|
#[derive(SessionDiagnostic)]
|
2022-06-23 14:51:44 +01:00
|
|
|
#[error(typeck::ambiguous_lifetime_bound)]
|
2022-04-27 05:59:48 +01:00
|
|
|
struct Subdiagnostic {
|
|
|
|
#[subdiagnostic]
|
|
|
|
note: Note,
|
|
|
|
}
|
2022-05-06 03:43:30 +01:00
|
|
|
|
|
|
|
#[derive(SessionDiagnostic)]
|
2022-06-23 14:51:44 +01:00
|
|
|
#[error(typeck::ambiguous_lifetime_bound, code = "E0123")]
|
2022-05-06 03:43:30 +01:00
|
|
|
struct VecField {
|
|
|
|
#[primary_span]
|
|
|
|
#[label]
|
|
|
|
spans: Vec<Span>,
|
|
|
|
}
|
2022-05-07 06:02:11 +01:00
|
|
|
|
|
|
|
#[derive(SessionDiagnostic)]
|
2022-06-23 14:51:44 +01:00
|
|
|
#[error(typeck::ambiguous_lifetime_bound, code = "E0123")]
|
2022-05-07 06:02:11 +01:00
|
|
|
struct UnitField {
|
|
|
|
#[primary_span]
|
|
|
|
spans: Span,
|
|
|
|
#[help]
|
|
|
|
foo: (),
|
2022-06-23 14:51:44 +01:00
|
|
|
#[help(typeck::help)]
|
2022-05-07 06:02:11 +01:00
|
|
|
bar: (),
|
|
|
|
}
|
|
|
|
|
|
|
|
#[derive(SessionDiagnostic)]
|
2022-06-23 14:51:44 +01:00
|
|
|
#[error(typeck::ambiguous_lifetime_bound, code = "E0123")]
|
2022-05-07 06:02:11 +01:00
|
|
|
struct OptUnitField {
|
|
|
|
#[primary_span]
|
|
|
|
spans: Span,
|
|
|
|
#[help]
|
|
|
|
foo: Option<()>,
|
2022-06-23 14:51:44 +01:00
|
|
|
#[help(typeck::help)]
|
2022-05-07 06:02:11 +01:00
|
|
|
bar: Option<()>,
|
|
|
|
}
|
2022-06-23 14:51:44 +01:00
|
|
|
|
|
|
|
#[derive(SessionDiagnostic)]
|
|
|
|
#[error(typeck::ambiguous_lifetime_bound, code = "E0123")]
|
|
|
|
struct LabelWithTrailingPath {
|
|
|
|
#[label(typeck::label, foo)]
|
|
|
|
//~^ ERROR `#[label(...)]` is not a valid attribute
|
|
|
|
span: Span,
|
|
|
|
}
|
|
|
|
|
|
|
|
#[derive(SessionDiagnostic)]
|
|
|
|
#[error(typeck::ambiguous_lifetime_bound, code = "E0123")]
|
|
|
|
struct LabelWithTrailingNameValue {
|
|
|
|
#[label(typeck::label, foo = "...")]
|
|
|
|
//~^ ERROR `#[label(...)]` is not a valid attribute
|
|
|
|
span: Span,
|
|
|
|
}
|
|
|
|
|
|
|
|
#[derive(SessionDiagnostic)]
|
|
|
|
#[error(typeck::ambiguous_lifetime_bound, code = "E0123")]
|
|
|
|
struct LabelWithTrailingList {
|
|
|
|
#[label(typeck::label, foo("..."))]
|
|
|
|
//~^ ERROR `#[label(...)]` is not a valid attribute
|
|
|
|
span: Span,
|
|
|
|
}
|
2022-06-30 08:57:45 +01:00
|
|
|
|
|
|
|
#[derive(SessionDiagnostic)]
|
|
|
|
#[lint(typeck::ambiguous_lifetime_bound)]
|
2022-07-11 18:46:24 +01:00
|
|
|
//~^ ERROR only `#[error(..)]` and `#[warning(..)]` are supported
|
2022-06-30 08:57:45 +01:00
|
|
|
struct LintsBad {
|
|
|
|
}
|
|
|
|
|
|
|
|
#[derive(LintDiagnostic)]
|
|
|
|
#[lint(typeck::ambiguous_lifetime_bound)]
|
|
|
|
struct LintsGood {
|
|
|
|
}
|
|
|
|
|
|
|
|
#[derive(LintDiagnostic)]
|
|
|
|
#[error(typeck::ambiguous_lifetime_bound)]
|
|
|
|
//~^ ERROR only `#[lint(..)]` is supported
|
|
|
|
struct ErrorsBad {
|
|
|
|
}
|
2022-07-11 17:15:31 +01:00
|
|
|
|
|
|
|
#[derive(SessionDiagnostic)]
|
|
|
|
#[error(typeck::ambiguous_lifetime_bound, code = "E0123")]
|
|
|
|
struct ErrorWithMultiSpan {
|
|
|
|
#[primary_span]
|
|
|
|
span: MultiSpan,
|
|
|
|
}
|
2022-07-11 18:46:24 +01:00
|
|
|
|
|
|
|
#[derive(SessionDiagnostic)]
|
|
|
|
#[error(typeck::ambiguous_lifetime_bound, code = "E0123")]
|
|
|
|
#[warn_]
|
|
|
|
struct ErrorWithWarn {
|
|
|
|
val: String,
|
|
|
|
}
|