5b54286640
Remove the "which is required by `{root_obligation}`" post-script in "the trait `X` is not implemented for `Y`" explanation in E0277. This information is already conveyed in the notes explaining requirements, making it redundant while making the text (particularly in labels) harder to read. ``` error[E0277]: the trait bound `NotCopy: Copy` is not satisfied --> $DIR/wf-static-type.rs:10:13 | LL | static FOO: IsCopy<Option<NotCopy>> = IsCopy { t: None }; | ^^^^^^^^^^^^^^^^^^^^^^^ the trait `Copy` is not implemented for `NotCopy` | = note: required for `Option<NotCopy>` to implement `Copy` note: required by a bound in `IsCopy` --> $DIR/wf-static-type.rs:7:17 | LL | struct IsCopy<T:Copy> { t: T } | ^^^^ required by this bound in `IsCopy` ``` vs the prior ``` error[E0277]: the trait bound `NotCopy: Copy` is not satisfied --> $DIR/wf-static-type.rs:10:13 | LL | static FOO: IsCopy<Option<NotCopy>> = IsCopy { t: None }; | ^^^^^^^^^^^^^^^^^^^^^^^ the trait `Copy` is not implemented for `NotCopy`, which is required by `Option<NotCopy>: Copy` | = note: required for `Option<NotCopy>` to implement `Copy` note: required by a bound in `IsCopy` --> $DIR/wf-static-type.rs:7:17 | LL | struct IsCopy<T:Copy> { t: T } | ^^^^ required by this bound in `IsCopy` ```
44 lines
1.9 KiB
Plaintext
44 lines
1.9 KiB
Plaintext
error: future cannot be sent between threads safely
|
|
--> $DIR/async-fn-nonsend.rs:68:17
|
|
|
|
|
LL | assert_send(non_send_temporary_in_match());
|
|
| ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ future returned by `non_send_temporary_in_match` is not `Send`
|
|
|
|
|
= help: within `impl Future<Output = ()>`, the trait `Send` is not implemented for `Rc<()>`
|
|
note: future is not `Send` as this value is used across an await
|
|
--> $DIR/async-fn-nonsend.rs:33:26
|
|
|
|
|
LL | match Some(non_send()) {
|
|
| ---------------- has type `Option<impl Debug>` which is not `Send`
|
|
LL | Some(_) => fut().await,
|
|
| ^^^^^ await occurs here, with `Some(non_send())` maybe used later
|
|
note: required by a bound in `assert_send`
|
|
--> $DIR/async-fn-nonsend.rs:64:24
|
|
|
|
|
LL | fn assert_send(_: impl Send) {}
|
|
| ^^^^ required by this bound in `assert_send`
|
|
|
|
error: future cannot be sent between threads safely
|
|
--> $DIR/async-fn-nonsend.rs:70:17
|
|
|
|
|
LL | assert_send(non_sync_with_method_call());
|
|
| ^^^^^^^^^^^^^^^^^^^^^^^^^^^ future returned by `non_sync_with_method_call` is not `Send`
|
|
|
|
|
= help: within `impl Future<Output = ()>`, the trait `Send` is not implemented for `dyn std::fmt::Write`
|
|
note: future is not `Send` as this value is used across an await
|
|
--> $DIR/async-fn-nonsend.rs:46:15
|
|
|
|
|
LL | let f: &mut std::fmt::Formatter = &mut get_formatter();
|
|
| --------------- has type `Formatter<'_>` which is not `Send`
|
|
...
|
|
LL | fut().await;
|
|
| ^^^^^ await occurs here, with `get_formatter()` maybe used later
|
|
note: required by a bound in `assert_send`
|
|
--> $DIR/async-fn-nonsend.rs:64:24
|
|
|
|
|
LL | fn assert_send(_: impl Send) {}
|
|
| ^^^^ required by this bound in `assert_send`
|
|
|
|
error: aborting due to 2 previous errors
|
|
|