6efddac288
Expand the primary span of E0277 when the immediate unmet bound is not what the user wrote: ``` error[E0277]: the trait bound `i32: Bar` is not satisfied --> f100.rs:6:6 | 6 | <i32 as Foo>::foo(); | ^^^ the trait `Bar` is not implemented for `i32`, which is required by `i32: Foo` | help: this trait has no implementations, consider adding one --> f100.rs:2:1 | 2 | trait Bar {} | ^^^^^^^^^ note: required for `i32` to implement `Foo` --> f100.rs:3:14 | 3 | impl<T: Bar> Foo for T {} | --- ^^^ ^ | | | unsatisfied trait bound introduced here ``` Fix #40120.
24 lines
1.0 KiB
Plaintext
24 lines
1.0 KiB
Plaintext
error[E0277]: the trait bound `Bar: Copy` is not satisfied
|
|
--> $DIR/fn-call-in-non-const.rs:14:32
|
|
|
|
|
LL | let _: [Option<Bar>; 2] = [no_copy(); 2];
|
|
| ^^^^^^^^^ the trait `Copy` is not implemented for `Bar`, which is required by `Option<Bar>: Copy`
|
|
|
|
|
= note: required for `Option<Bar>` to implement `Copy`
|
|
= note: the `Copy` trait is required because this value will be copied for each element of the array
|
|
= help: create an inline `const` block, see RFC #2920 <https://github.com/rust-lang/rfcs/pull/2920> for more information
|
|
help: consider annotating `Bar` with `#[derive(Copy)]`
|
|
|
|
|
LL + #[derive(Copy)]
|
|
LL | struct Bar;
|
|
|
|
|
help: consider creating a new `const` item and initializing it with the result of the function call to be used in the repeat position
|
|
|
|
|
LL ~ const ARRAY_REPEAT_VALUE: Option<Bar> = no_copy();
|
|
LL ~ let _: [Option<Bar>; 2] = [ARRAY_REPEAT_VALUE; 2];
|
|
|
|
|
|
|
error: aborting due to 1 previous error
|
|
|
|
For more information about this error, try `rustc --explain E0277`.
|