2023-10-19 16:46:28 -05:00
error: coroutine cannot be sent between threads safely
2024-04-11 08:15:34 -05:00
--> $DIR/ref-upvar-not-send.rs:15:30
2022-12-17 14:15:57 -06:00
|
2024-04-11 08:15:34 -05:00
LL | assert_send(#[coroutine] move || {
| ______________________________^
2022-12-17 14:15:57 -06:00
LL | |
LL | |
LL | | yield;
LL | | let _x = x;
LL | | });
2023-10-19 16:46:28 -05:00
| |_____^ coroutine is not `Send`
2022-12-17 14:15:57 -06:00
|
2024-04-11 08:15:34 -05:00
= help: the trait `Sync` is not implemented for `*mut ()`, which is required by `{coroutine@$DIR/ref-upvar-not-send.rs:15:30: 15:37}: Send`
2022-12-17 14:15:57 -06:00
note: captured value is not `Send` because `&` references cannot be sent unless their referent is `Sync`
2023-08-28 05:16:48 -05:00
--> $DIR/ref-upvar-not-send.rs:19:18
2022-12-17 14:15:57 -06:00
|
LL | let _x = x;
| ^ has type `&*mut ()` which is not `Send`, because `*mut ()` is not `Sync`
note: required by a bound in `assert_send`
--> $DIR/ref-upvar-not-send.rs:6:19
|
LL | fn assert_send<T: Send>(_: T) {}
| ^^^^ required by this bound in `assert_send`
2023-10-19 16:46:28 -05:00
error: coroutine cannot be sent between threads safely
2024-04-11 08:15:34 -05:00
--> $DIR/ref-upvar-not-send.rs:23:30
2022-12-17 14:15:57 -06:00
|
2024-04-11 08:15:34 -05:00
LL | assert_send(#[coroutine] move || {
| ______________________________^
2022-12-17 14:15:57 -06:00
LL | |
LL | |
LL | | yield;
LL | | let _y = y;
LL | | });
2023-10-19 16:46:28 -05:00
| |_____^ coroutine is not `Send`
2022-12-17 14:15:57 -06:00
|
2024-04-11 08:15:34 -05:00
= help: within `{coroutine@$DIR/ref-upvar-not-send.rs:23:30: 23:37}`, the trait `Send` is not implemented for `*mut ()`, which is required by `{coroutine@$DIR/ref-upvar-not-send.rs:23:30: 23:37}: Send`
2022-12-17 14:15:57 -06:00
note: captured value is not `Send` because `&mut` references cannot be sent unless their referent is `Send`
2023-08-28 05:16:48 -05:00
--> $DIR/ref-upvar-not-send.rs:27:18
2022-12-17 14:15:57 -06:00
|
LL | let _y = y;
| ^ has type `&mut *mut ()` which is not `Send`, because `*mut ()` is not `Send`
note: required by a bound in `assert_send`
--> $DIR/ref-upvar-not-send.rs:6:19
|
LL | fn assert_send<T: Send>(_: T) {}
| ^^^^ required by this bound in `assert_send`
error: aborting due to 2 previous errors