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` ```
70 lines
2.7 KiB
Text
70 lines
2.7 KiB
Text
error[E0277]: `*mut ()` cannot be shared between threads safely
|
|
--> $DIR/issue-70935-complex-spans.rs:15:23
|
|
|
|
|
LL | fn foo(x: NotSync) -> impl Future + Send {
|
|
| ^^^^^^^^^^^^^^^^^^ `*mut ()` cannot be shared between threads safely
|
|
|
|
|
= help: within `NotSync`, the trait `Sync` is not implemented for `*mut ()`
|
|
note: required because it appears within the type `PhantomData<*mut ()>`
|
|
--> $SRC_DIR/core/src/marker.rs:LL:COL
|
|
note: required because it appears within the type `NotSync`
|
|
--> $DIR/issue-70935-complex-spans.rs:9:8
|
|
|
|
|
LL | struct NotSync(PhantomData<*mut ()>);
|
|
| ^^^^^^^
|
|
= note: required for `&NotSync` to implement `Send`
|
|
note: required because it's used within this closure
|
|
--> $DIR/issue-70935-complex-spans.rs:19:13
|
|
|
|
|
LL | baz(|| async {
|
|
| ^^
|
|
note: required because it's used within this `async` fn body
|
|
--> $DIR/issue-70935-complex-spans.rs:12:67
|
|
|
|
|
LL | async fn baz<T>(_c: impl FnMut() -> T) where T: Future<Output=()> {
|
|
| ___________________________________________________________________^
|
|
LL | | }
|
|
| |_^
|
|
note: required because it's used within this `async` block
|
|
--> $DIR/issue-70935-complex-spans.rs:18:5
|
|
|
|
|
LL | async move {
|
|
| ^^^^^^^^^^
|
|
|
|
error[E0277]: `*mut ()` cannot be shared between threads safely
|
|
--> $DIR/issue-70935-complex-spans.rs:15:23
|
|
|
|
|
LL | fn foo(x: NotSync) -> impl Future + Send {
|
|
| ^^^^^^^^^^^^^^^^^^ `*mut ()` cannot be shared between threads safely
|
|
|
|
|
= help: within `NotSync`, the trait `Sync` is not implemented for `*mut ()`
|
|
note: required because it appears within the type `PhantomData<*mut ()>`
|
|
--> $SRC_DIR/core/src/marker.rs:LL:COL
|
|
note: required because it appears within the type `NotSync`
|
|
--> $DIR/issue-70935-complex-spans.rs:9:8
|
|
|
|
|
LL | struct NotSync(PhantomData<*mut ()>);
|
|
| ^^^^^^^
|
|
= note: required for `&NotSync` to implement `Send`
|
|
note: required because it's used within this closure
|
|
--> $DIR/issue-70935-complex-spans.rs:19:13
|
|
|
|
|
LL | baz(|| async {
|
|
| ^^
|
|
note: required because it's used within this `async` fn body
|
|
--> $DIR/issue-70935-complex-spans.rs:12:67
|
|
|
|
|
LL | async fn baz<T>(_c: impl FnMut() -> T) where T: Future<Output=()> {
|
|
| ___________________________________________________________________^
|
|
LL | | }
|
|
| |_^
|
|
note: required because it's used within this `async` block
|
|
--> $DIR/issue-70935-complex-spans.rs:18:5
|
|
|
|
|
LL | async move {
|
|
| ^^^^^^^^^^
|
|
= note: duplicate diagnostic emitted due to `-Z deduplicate-diagnostics=no`
|
|
|
|
error: aborting due to 2 previous errors
|
|
|
|
For more information about this error, try `rustc --explain E0277`.
|