54bd3a7b8d
Tweak some structured suggestions to be more verbose and accurate Addressing some issues I found while working on #127282. ``` error: this URL is not a hyperlink --> $DIR/auxiliary/include-str-bare-urls.md:1:11 | LL | HEADS UP! https://example.com MUST SHOW UP IN THE STDERR FILE! | ^^^^^^^^^^^^^^^^^^^ | = note: bare URLs are not automatically turned into clickable links note: the lint level is defined here --> $DIR/include-str-bare-urls.rs:14:9 | LL | #![deny(rustdoc::bare_urls)] | ^^^^^^^^^^^^^^^^^^ help: use an automatic link instead | LL | HEADS UP! <https://example.com> MUST SHOW UP IN THE STDERR FILE! | + + ``` ``` error[E0384]: cannot assign twice to immutable variable `v` --> $DIR/assign-imm-local-twice.rs:7:5 | LL | v = 1; | ----- first assignment to `v` LL | println!("v={}", v); LL | v = 2; | ^^^^^ cannot assign twice to immutable variable | help: consider making this binding mutable | LL | let mut v: isize; | +++ ``` ``` error[E0393]: the type parameter `Rhs` must be explicitly specified --> $DIR/issue-22560.rs:9:23 | LL | trait Sub<Rhs=Self> { | ------------------- type parameter `Rhs` must be specified for this ... LL | type Test = dyn Add + Sub; | ^^^ | = note: because of the default `Self` reference, type parameters must be specified on object types help: set the type parameter to the desired type | LL | type Test = dyn Add + Sub<Rhs>; | +++++ ``` ``` error[E0596]: cannot borrow `v` as mutable, as it is not declared as mutable --> $DIR/issue-33819.rs:4:34 | LL | Some(ref v) => { let a = &mut v; }, | ^^^^^^ cannot borrow as mutable | help: try removing `&mut` here | LL - Some(ref v) => { let a = &mut v; }, LL + Some(ref v) => { let a = v; }, | ``` ``` help: remove the invocation before committing it to a version control system | LL - dbg!(); | ``` ``` error[E0308]: mismatched types --> $DIR/issue-39974.rs:1:21 | LL | const LENGTH: f64 = 2; | ^ expected `f64`, found integer | help: use a float literal | LL | const LENGTH: f64 = 2.0; | ++ ``` ``` error[E0529]: expected an array or slice, found `Vec<i32>` --> $DIR/match-ergonomics.rs:8:9 | LL | [&v] => {}, | ^^^^ pattern cannot match with input type `Vec<i32>` | help: consider slicing here | LL | match x[..] { | ++++ ``` ``` error[E0609]: no field `0` on type `[u32; 1]` --> $DIR/parenthesized-deref-suggestion.rs:10:21 | LL | (x as [u32; 1]).0; | ^ unknown field | help: instead of using tuple indexing, use array indexing | LL | (x as [u32; 1])[0]; | ~ + ``` |
||
---|---|---|
.. | ||
ascription | ||
auxiliary | ||
pattern_types | ||
type-check | ||
binding-assigned-block-without-tail-expression.rs | ||
binding-assigned-block-without-tail-expression.stderr | ||
clarify-error-for-generics-with-default-issue-120785.rs | ||
clarify-error-for-generics-with-default-issue-120785.stderr | ||
closure-with-wrong-borrows.rs | ||
closure-with-wrong-borrows.stderr | ||
issue-7607-1.rs | ||
issue-7607-1.stderr | ||
issue-7607-2.rs | ||
issue-58355.rs | ||
issue-58355.stderr | ||
issue-67690-type-alias-bound-diagnostic-crash.rs | ||
issue-67690-type-alias-bound-diagnostic-crash.stderr | ||
issue-91268.rs | ||
issue-91268.stderr | ||
issue-94187-verbose-type-name.rs | ||
issue-100584.rs | ||
issue-100584.stderr | ||
issue-101866.rs | ||
issue-101866.stderr | ||
issue-102598.rs | ||
issue-102598.stderr | ||
issue-103271.rs | ||
issue-103271.stderr | ||
missing-let-in-binding-2.fixed | ||
missing-let-in-binding-2.rs | ||
missing-let-in-binding-2.stderr | ||
missing-let-in-binding-3.rs | ||
missing-let-in-binding-3.stderr | ||
missing-let-in-binding-4.rs | ||
missing-let-in-binding-4.stderr | ||
missing-let-in-binding.fixed | ||
missing-let-in-binding.rs | ||
missing-let-in-binding.stderr | ||
option-ref-advice.rs | ||
option-ref-advice.stderr | ||
type-alias-bounds.rs | ||
type-alias-bounds.stderr | ||
type-annotation-needed.rs | ||
type-annotation-needed.stderr | ||
type-arg-out-of-scope.rs | ||
type-arg-out-of-scope.stderr | ||
type-ascription-instead-of-initializer.rs | ||
type-ascription-instead-of-initializer.stderr | ||
type-ascription-instead-of-statement-end.rs | ||
type-ascription-instead-of-statement-end.stderr | ||
type-ascription-precedence.rs | ||
type-ascription-precedence.stderr | ||
type-ascription-soundness.rs | ||
type-ascription-soundness.stderr | ||
type-ascription-with-fn-call.fixed | ||
type-ascription-with-fn-call.rs | ||
type-ascription-with-fn-call.stderr | ||
type-ascription.rs | ||
type-check-defaults.rs | ||
type-check-defaults.stderr | ||
type-dependent-def-issue-49241.rs | ||
type-dependent-def-issue-49241.stderr | ||
type-error-break-tail.rs | ||
type-error-break-tail.stderr | ||
type-mismatch-multiple.rs | ||
type-mismatch-multiple.stderr | ||
type-mismatch-same-crate-name.rs | ||
type-mismatch-same-crate-name.stderr | ||
type-mismatch.rs | ||
type-mismatch.stderr | ||
type-parameter-defaults-referencing-Self-ppaux.rs | ||
type-parameter-defaults-referencing-Self-ppaux.stderr | ||
type-parameter-defaults-referencing-Self.rs | ||
type-parameter-defaults-referencing-Self.stderr | ||
type-parameter-names.rs | ||
type-parameter-names.stderr | ||
type-params-in-different-spaces-1.rs | ||
type-params-in-different-spaces-1.stderr | ||
type-params-in-different-spaces-2.rs | ||
type-params-in-different-spaces-2.stderr | ||
type-params-in-different-spaces-3.rs | ||
type-params-in-different-spaces-3.stderr | ||
type-path-err-node-types.rs | ||
type-path-err-node-types.stderr | ||
type-recursive-box-shadowed.rs | ||
type-recursive-box-shadowed.stderr | ||
type-recursive.rs | ||
type-recursive.stderr | ||
type-shadow.rs | ||
type-shadow.stderr | ||
type-unsatisfiable.rs | ||
type-unsatisfiable.usage.stderr | ||
verbose.normal.stderr | ||
verbose.rs | ||
verbose.verbose.stderr | ||
wrong-call-return-type-due-to-generic-arg.rs | ||
wrong-call-return-type-due-to-generic-arg.stderr |