478 lines
16 KiB
Plaintext
478 lines
16 KiB
Plaintext
error: `#[derive(Diagnostic)]` can only be used on structs
|
|
--> $DIR/diagnostic-derive.rs:39:1
|
|
|
|
|
LL | / #[diag(typeck::ambiguous_lifetime_bound, code = "E0123")]
|
|
LL | |
|
|
LL | | enum DiagnosticOnEnum {
|
|
LL | | Foo,
|
|
LL | | Bar,
|
|
LL | | }
|
|
| |_^
|
|
|
|
error: `#[diag = ...]` is not a valid attribute
|
|
--> $DIR/diagnostic-derive.rs:48:1
|
|
|
|
|
LL | #[diag = "E0123"]
|
|
| ^^^^^^^^^^^^^^^^^
|
|
|
|
error: `#[nonsense(...)]` is not a valid attribute
|
|
--> $DIR/diagnostic-derive.rs:53:1
|
|
|
|
|
LL | #[nonsense(typeck::ambiguous_lifetime_bound, code = "E0123")]
|
|
| ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
|
|
|
|
|
= help: only `diag`, `help`, `note` and `warning` are valid attributes
|
|
|
|
error: diagnostic slug not specified
|
|
--> $DIR/diagnostic-derive.rs:53:1
|
|
|
|
|
LL | / #[nonsense(typeck::ambiguous_lifetime_bound, code = "E0123")]
|
|
LL | |
|
|
LL | |
|
|
LL | |
|
|
LL | | struct InvalidStructAttr {}
|
|
| |___________________________^
|
|
|
|
|
= help: specify the slug as the first argument to the `#[diag(...)]` attribute, such as `#[diag(typeck::example_error)]`
|
|
|
|
error: `#[diag("...")]` is not a valid attribute
|
|
--> $DIR/diagnostic-derive.rs:60:8
|
|
|
|
|
LL | #[diag("E0123")]
|
|
| ^^^^^^^
|
|
|
|
|
= help: first argument of the attribute should be the diagnostic slug
|
|
|
|
error: diagnostic slug not specified
|
|
--> $DIR/diagnostic-derive.rs:60:1
|
|
|
|
|
LL | / #[diag("E0123")]
|
|
LL | |
|
|
LL | |
|
|
LL | | struct InvalidLitNestedAttr {}
|
|
| |______________________________^
|
|
|
|
|
= help: specify the slug as the first argument to the `#[diag(...)]` attribute, such as `#[diag(typeck::example_error)]`
|
|
|
|
error: `#[diag(nonsense(...))]` is not a valid attribute
|
|
--> $DIR/diagnostic-derive.rs:71:8
|
|
|
|
|
LL | #[diag(nonsense("foo"), code = "E0123", slug = "foo")]
|
|
| ^^^^^^^^^^^^^^^
|
|
|
|
|
= help: first argument of the attribute should be the diagnostic slug
|
|
|
|
error: diagnostic slug not specified
|
|
--> $DIR/diagnostic-derive.rs:71:1
|
|
|
|
|
LL | / #[diag(nonsense("foo"), code = "E0123", slug = "foo")]
|
|
LL | |
|
|
LL | |
|
|
LL | | struct InvalidNestedStructAttr1 {}
|
|
| |__________________________________^
|
|
|
|
|
= help: specify the slug as the first argument to the `#[diag(...)]` attribute, such as `#[diag(typeck::example_error)]`
|
|
|
|
error: `#[diag(nonsense = ...)]` is not a valid attribute
|
|
--> $DIR/diagnostic-derive.rs:77:8
|
|
|
|
|
LL | #[diag(nonsense = "...", code = "E0123", slug = "foo")]
|
|
| ^^^^^^^^^^^^^^^^
|
|
|
|
|
= help: first argument of the attribute should be the diagnostic slug
|
|
|
|
error: diagnostic slug not specified
|
|
--> $DIR/diagnostic-derive.rs:77:1
|
|
|
|
|
LL | / #[diag(nonsense = "...", code = "E0123", slug = "foo")]
|
|
LL | |
|
|
LL | |
|
|
LL | | struct InvalidNestedStructAttr2 {}
|
|
| |__________________________________^
|
|
|
|
|
= help: specify the slug as the first argument to the `#[diag(...)]` attribute, such as `#[diag(typeck::example_error)]`
|
|
|
|
error: `#[diag(nonsense = ...)]` is not a valid attribute
|
|
--> $DIR/diagnostic-derive.rs:83:8
|
|
|
|
|
LL | #[diag(nonsense = 4, code = "E0123", slug = "foo")]
|
|
| ^^^^^^^^^^^^
|
|
|
|
|
= help: first argument of the attribute should be the diagnostic slug
|
|
|
|
error: diagnostic slug not specified
|
|
--> $DIR/diagnostic-derive.rs:83:1
|
|
|
|
|
LL | / #[diag(nonsense = 4, code = "E0123", slug = "foo")]
|
|
LL | |
|
|
LL | |
|
|
LL | | struct InvalidNestedStructAttr3 {}
|
|
| |__________________________________^
|
|
|
|
|
= help: specify the slug as the first argument to the `#[diag(...)]` attribute, such as `#[diag(typeck::example_error)]`
|
|
|
|
error: `#[diag(slug = ...)]` is not a valid attribute
|
|
--> $DIR/diagnostic-derive.rs:89:58
|
|
|
|
|
LL | #[diag(typeck::ambiguous_lifetime_bound, code = "E0123", slug = "foo")]
|
|
| ^^^^^^^^^^^^
|
|
|
|
|
= help: only `code` is a valid nested attributes following the slug
|
|
|
|
error: `#[suggestion = ...]` is not a valid attribute
|
|
--> $DIR/diagnostic-derive.rs:96:5
|
|
|
|
|
LL | #[suggestion = "bar"]
|
|
| ^^^^^^^^^^^^^^^^^^^^^
|
|
|
|
error: specified multiple times
|
|
--> $DIR/diagnostic-derive.rs:103:1
|
|
|
|
|
LL | #[diag(typeck::ambiguous_lifetime_bound, code = "E0456")]
|
|
| ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
|
|
|
|
|
note: previously specified here
|
|
--> $DIR/diagnostic-derive.rs:102:1
|
|
|
|
|
LL | #[diag(typeck::ambiguous_lifetime_bound, code = "E0123")]
|
|
| ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
|
|
|
|
error: specified multiple times
|
|
--> $DIR/diagnostic-derive.rs:103:49
|
|
|
|
|
LL | #[diag(typeck::ambiguous_lifetime_bound, code = "E0456")]
|
|
| ^^^^^^^
|
|
|
|
|
note: previously specified here
|
|
--> $DIR/diagnostic-derive.rs:102:49
|
|
|
|
|
LL | #[diag(typeck::ambiguous_lifetime_bound, code = "E0123")]
|
|
| ^^^^^^^
|
|
|
|
error: specified multiple times
|
|
--> $DIR/diagnostic-derive.rs:109:65
|
|
|
|
|
LL | #[diag(typeck::ambiguous_lifetime_bound, code = "E0456", code = "E0457")]
|
|
| ^^^^^^^
|
|
|
|
|
note: previously specified here
|
|
--> $DIR/diagnostic-derive.rs:109:49
|
|
|
|
|
LL | #[diag(typeck::ambiguous_lifetime_bound, code = "E0456", code = "E0457")]
|
|
| ^^^^^^^
|
|
|
|
error: `#[diag(typeck::ambiguous_lifetime_bound)]` is not a valid attribute
|
|
--> $DIR/diagnostic-derive.rs:114:42
|
|
|
|
|
LL | #[diag(typeck::ambiguous_lifetime_bound, typeck::ambiguous_lifetime_bound, code = "E0456")]
|
|
| ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
|
|
|
|
error: diagnostic slug not specified
|
|
--> $DIR/diagnostic-derive.rs:119:1
|
|
|
|
|
LL | struct KindNotProvided {}
|
|
| ^^^^^^^^^^^^^^^^^^^^^^^^^
|
|
|
|
|
= help: specify the slug as the first argument to the `#[diag(...)]` attribute, such as `#[diag(typeck::example_error)]`
|
|
|
|
error: diagnostic slug not specified
|
|
--> $DIR/diagnostic-derive.rs:122:1
|
|
|
|
|
LL | / #[diag(code = "E0456")]
|
|
LL | |
|
|
LL | | struct SlugNotProvided {}
|
|
| |_________________________^
|
|
|
|
|
= help: specify the slug as the first argument to the `#[diag(...)]` attribute, such as `#[diag(typeck::example_error)]`
|
|
|
|
error: the `#[primary_span]` attribute can only be applied to fields of type `Span` or `MultiSpan`
|
|
--> $DIR/diagnostic-derive.rs:133:5
|
|
|
|
|
LL | #[primary_span]
|
|
| ^^^^^^^^^^^^^^^
|
|
|
|
error: `#[nonsense]` is not a valid attribute
|
|
--> $DIR/diagnostic-derive.rs:141:5
|
|
|
|
|
LL | #[nonsense]
|
|
| ^^^^^^^^^^^
|
|
|
|
|
= help: only `skip_arg`, `primary_span`, `label`, `note`, `help` and `subdiagnostic` are valid field attributes
|
|
|
|
error: the `#[label(...)]` attribute can only be applied to fields of type `Span` or `MultiSpan`
|
|
--> $DIR/diagnostic-derive.rs:158:5
|
|
|
|
|
LL | #[label(typeck::label)]
|
|
| ^^^^^^^^^^^^^^^^^^^^^^^
|
|
|
|
error: `name` doesn't refer to a field on this type
|
|
--> $DIR/diagnostic-derive.rs:166:45
|
|
|
|
|
LL | #[suggestion(typeck::suggestion, code = "{name}")]
|
|
| ^^^^^^^^
|
|
|
|
error: invalid format string: expected `'}'` but string was terminated
|
|
--> $DIR/diagnostic-derive.rs:171:16
|
|
|
|
|
LL | #[derive(Diagnostic)]
|
|
| - ^ expected `'}'` in format string
|
|
| |
|
|
| because of this opening brace
|
|
|
|
|
= note: if you intended to print `{`, you can escape it using `{{`
|
|
= note: this error originates in the derive macro `Diagnostic` (in Nightly builds, run with -Z macro-backtrace for more info)
|
|
|
|
error: invalid format string: unmatched `}` found
|
|
--> $DIR/diagnostic-derive.rs:181:15
|
|
|
|
|
LL | #[derive(Diagnostic)]
|
|
| ^ unmatched `}` in format string
|
|
|
|
|
= note: if you intended to print `}`, you can escape it using `}}`
|
|
= note: this error originates in the derive macro `Diagnostic` (in Nightly builds, run with -Z macro-backtrace for more info)
|
|
|
|
error: the `#[label(...)]` attribute can only be applied to fields of type `Span` or `MultiSpan`
|
|
--> $DIR/diagnostic-derive.rs:201:5
|
|
|
|
|
LL | #[label(typeck::label)]
|
|
| ^^^^^^^^^^^^^^^^^^^^^^^
|
|
|
|
error: `#[suggestion(nonsense = ...)]` is not a valid attribute
|
|
--> $DIR/diagnostic-derive.rs:226:18
|
|
|
|
|
LL | #[suggestion(nonsense = "bar")]
|
|
| ^^^^^^^^^^^^^^^^
|
|
|
|
|
= help: only `message`, `code` and `applicability` are valid field attributes
|
|
|
|
error: `#[suggestion(msg = ...)]` is not a valid attribute
|
|
--> $DIR/diagnostic-derive.rs:234:18
|
|
|
|
|
LL | #[suggestion(msg = "bar")]
|
|
| ^^^^^^^^^^^
|
|
|
|
|
= help: only `message`, `code` and `applicability` are valid field attributes
|
|
|
|
error: wrong field type for suggestion
|
|
--> $DIR/diagnostic-derive.rs:256:5
|
|
|
|
|
LL | / #[suggestion(typeck::suggestion, code = "This is suggested code")]
|
|
LL | |
|
|
LL | | suggestion: Applicability,
|
|
| |_____________________________^
|
|
|
|
|
= help: `#[suggestion(...)]` should be applied to fields of type `Span` or `(Span, Applicability)`
|
|
|
|
error: type of field annotated with `#[suggestion(...)]` contains more than one `Span`
|
|
--> $DIR/diagnostic-derive.rs:271:5
|
|
|
|
|
LL | / #[suggestion(typeck::suggestion, code = "This is suggested code")]
|
|
LL | |
|
|
LL | | suggestion: (Span, Span, Applicability),
|
|
| |___________________________________________^
|
|
|
|
error: type of field annotated with `#[suggestion(...)]` contains more than one Applicability
|
|
--> $DIR/diagnostic-derive.rs:279:5
|
|
|
|
|
LL | / #[suggestion(typeck::suggestion, code = "This is suggested code")]
|
|
LL | |
|
|
LL | | suggestion: (Applicability, Applicability, Span),
|
|
| |____________________________________________________^
|
|
|
|
error: `#[label = ...]` is not a valid attribute
|
|
--> $DIR/diagnostic-derive.rs:287:5
|
|
|
|
|
LL | #[label = "bar"]
|
|
| ^^^^^^^^^^^^^^^^
|
|
|
|
error: applicability cannot be set in both the field and attribute
|
|
--> $DIR/diagnostic-derive.rs:438:52
|
|
|
|
|
LL | #[suggestion(typeck::suggestion, code = "...", applicability = "maybe-incorrect")]
|
|
| ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
|
|
|
|
error: invalid applicability
|
|
--> $DIR/diagnostic-derive.rs:446:52
|
|
|
|
|
LL | #[suggestion(typeck::suggestion, code = "...", applicability = "batman")]
|
|
| ^^^^^^^^^^^^^^^^^^^^^^^^
|
|
|
|
error: `#[label(...)]` is not a valid attribute
|
|
--> $DIR/diagnostic-derive.rs:509:5
|
|
|
|
|
LL | #[label(typeck::label, foo)]
|
|
| ^^^^^^^^^^^^^^^^^^^^^^^^^^^^
|
|
|
|
error: `#[label(...)]` is not a valid attribute
|
|
--> $DIR/diagnostic-derive.rs:517:5
|
|
|
|
|
LL | #[label(typeck::label, foo = "...")]
|
|
| ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
|
|
|
|
error: `#[label(...)]` is not a valid attribute
|
|
--> $DIR/diagnostic-derive.rs:525:5
|
|
|
|
|
LL | #[label(typeck::label, foo("..."))]
|
|
| ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
|
|
|
|
error: `#[primary_span]` is not a valid attribute
|
|
--> $DIR/diagnostic-derive.rs:538:5
|
|
|
|
|
LL | #[primary_span]
|
|
| ^^^^^^^^^^^^^^^
|
|
|
|
|
= help: the `primary_span` field attribute is not valid for lint diagnostics
|
|
|
|
error: `#[error(...)]` is not a valid attribute
|
|
--> $DIR/diagnostic-derive.rs:558:1
|
|
|
|
|
LL | #[error(typeck::ambiguous_lifetime_bound, code = "E0123")]
|
|
| ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
|
|
|
|
|
= help: `error` and `lint` have been replaced by `diag`
|
|
|
|
error: diagnostic slug not specified
|
|
--> $DIR/diagnostic-derive.rs:558:1
|
|
|
|
|
LL | / #[error(typeck::ambiguous_lifetime_bound, code = "E0123")]
|
|
LL | |
|
|
LL | |
|
|
LL | |
|
|
LL | | struct ErrorAttribute {}
|
|
| |________________________^
|
|
|
|
|
= help: specify the slug as the first argument to the `#[diag(...)]` attribute, such as `#[diag(typeck::example_error)]`
|
|
|
|
error: `#[warn_(...)]` is not a valid attribute
|
|
--> $DIR/diagnostic-derive.rs:565:1
|
|
|
|
|
LL | #[warn_(typeck::ambiguous_lifetime_bound, code = "E0123")]
|
|
| ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
|
|
|
|
|
= help: `warn_` have been replaced by `warning`
|
|
|
|
error: diagnostic slug not specified
|
|
--> $DIR/diagnostic-derive.rs:565:1
|
|
|
|
|
LL | / #[warn_(typeck::ambiguous_lifetime_bound, code = "E0123")]
|
|
LL | |
|
|
LL | |
|
|
LL | |
|
|
LL | | struct WarnAttribute {}
|
|
| |_______________________^
|
|
|
|
|
= help: specify the slug as the first argument to the `#[diag(...)]` attribute, such as `#[diag(typeck::example_error)]`
|
|
|
|
error: `#[lint(...)]` is not a valid attribute
|
|
--> $DIR/diagnostic-derive.rs:572:1
|
|
|
|
|
LL | #[lint(typeck::ambiguous_lifetime_bound, code = "E0123")]
|
|
| ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
|
|
|
|
|
= help: `error` and `lint` have been replaced by `diag`
|
|
|
|
error: diagnostic slug not specified
|
|
--> $DIR/diagnostic-derive.rs:572:1
|
|
|
|
|
LL | / #[lint(typeck::ambiguous_lifetime_bound, code = "E0123")]
|
|
LL | |
|
|
LL | |
|
|
LL | |
|
|
LL | | struct LintAttributeOnSessionDiag {}
|
|
| |____________________________________^
|
|
|
|
|
= help: specify the slug as the first argument to the `#[diag(...)]` attribute, such as `#[diag(typeck::example_error)]`
|
|
|
|
error: `#[lint(...)]` is not a valid attribute
|
|
--> $DIR/diagnostic-derive.rs:579:1
|
|
|
|
|
LL | #[lint(typeck::ambiguous_lifetime_bound, code = "E0123")]
|
|
| ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
|
|
|
|
|
= help: `error` and `lint` have been replaced by `diag`
|
|
|
|
error: diagnostic slug not specified
|
|
--> $DIR/diagnostic-derive.rs:579:1
|
|
|
|
|
LL | / #[lint(typeck::ambiguous_lifetime_bound, code = "E0123")]
|
|
LL | |
|
|
LL | |
|
|
LL | |
|
|
LL | | struct LintAttributeOnLintDiag {}
|
|
| |_________________________________^
|
|
|
|
|
= help: specify the slug as the first argument to the attribute, such as `#[diag(typeck::example_error)]`
|
|
|
|
error: specified multiple times
|
|
--> $DIR/diagnostic-derive.rs:588:52
|
|
|
|
|
LL | #[suggestion(typeck::suggestion, code = "...", code = ",,,")]
|
|
| ^^^^^^^^^^^^
|
|
|
|
|
note: previously specified here
|
|
--> $DIR/diagnostic-derive.rs:588:38
|
|
|
|
|
LL | #[suggestion(typeck::suggestion, code = "...", code = ",,,")]
|
|
| ^^^^^^^^^^^^
|
|
|
|
error: cannot find attribute `nonsense` in this scope
|
|
--> $DIR/diagnostic-derive.rs:53:3
|
|
|
|
|
LL | #[nonsense(typeck::ambiguous_lifetime_bound, code = "E0123")]
|
|
| ^^^^^^^^
|
|
|
|
error: cannot find attribute `nonsense` in this scope
|
|
--> $DIR/diagnostic-derive.rs:141:7
|
|
|
|
|
LL | #[nonsense]
|
|
| ^^^^^^^^
|
|
|
|
error: cannot find attribute `error` in this scope
|
|
--> $DIR/diagnostic-derive.rs:558:3
|
|
|
|
|
LL | #[error(typeck::ambiguous_lifetime_bound, code = "E0123")]
|
|
| ^^^^^
|
|
|
|
error: cannot find attribute `warn_` in this scope
|
|
--> $DIR/diagnostic-derive.rs:565:3
|
|
|
|
|
LL | #[warn_(typeck::ambiguous_lifetime_bound, code = "E0123")]
|
|
| ^^^^^ help: a built-in attribute with a similar name exists: `warn`
|
|
|
|
error: cannot find attribute `lint` in this scope
|
|
--> $DIR/diagnostic-derive.rs:572:3
|
|
|
|
|
LL | #[lint(typeck::ambiguous_lifetime_bound, code = "E0123")]
|
|
| ^^^^ help: a built-in attribute with a similar name exists: `link`
|
|
|
|
error: cannot find attribute `lint` in this scope
|
|
--> $DIR/diagnostic-derive.rs:579:3
|
|
|
|
|
LL | #[lint(typeck::ambiguous_lifetime_bound, code = "E0123")]
|
|
| ^^^^ help: a built-in attribute with a similar name exists: `link`
|
|
|
|
error[E0425]: cannot find value `nonsense` in module `rustc_errors::fluent`
|
|
--> $DIR/diagnostic-derive.rs:66:8
|
|
|
|
|
LL | #[diag(nonsense, code = "E0123")]
|
|
| ^^^^^^^^ not found in `rustc_errors::fluent`
|
|
|
|
error[E0277]: the trait bound `Hello: IntoDiagnosticArg` is not satisfied
|
|
--> $DIR/diagnostic-derive.rs:331:10
|
|
|
|
|
LL | #[derive(Diagnostic)]
|
|
| ^^^^^^^^^^ the trait `IntoDiagnosticArg` is not implemented for `Hello`
|
|
|
|
|
= help: normalized in stderr
|
|
note: required by a bound in `DiagnosticBuilder::<'a, G>::set_arg`
|
|
--> $COMPILER_DIR/rustc_errors/src/diagnostic_builder.rs:LL:CC
|
|
|
|
|
LL | arg: impl IntoDiagnosticArg,
|
|
| ^^^^^^^^^^^^^^^^^ required by this bound in `DiagnosticBuilder::<'a, G>::set_arg`
|
|
= note: this error originates in the derive macro `Diagnostic` (in Nightly builds, run with -Z macro-backtrace for more info)
|
|
|
|
error: aborting due to 56 previous errors
|
|
|
|
Some errors have detailed explanations: E0277, E0425.
|
|
For more information about an error, try `rustc --explain E0277`.
|