rust/tests/ui/coroutine/ref-upvar-not-send.rs
Oli Scherer aef0f4024a Error on using yield without also using #[coroutine] on the closure
And suggest adding the `#[coroutine]` to the closure
2024-04-24 08:05:29 +00:00

31 lines
1.3 KiB
Rust

// For `Send` coroutines, suggest a `T: Sync` requirement for `&T` upvars,
// and suggest a `T: Send` requirement for `&mut T` upvars.
#![feature(coroutines, stmt_expr_attributes)]
fn assert_send<T: Send>(_: T) {}
//~^ NOTE required by a bound in `assert_send`
//~| NOTE required by this bound in `assert_send`
//~| NOTE required by a bound in `assert_send`
//~| NOTE required by this bound in `assert_send`
fn main() {
let x: &*mut () = &std::ptr::null_mut();
let y: &mut *mut () = &mut std::ptr::null_mut();
assert_send(#[coroutine] move || {
//~^ ERROR coroutine cannot be sent between threads safely
//~| NOTE coroutine is not `Send`
yield;
let _x = x;
});
//~^^ NOTE captured value is not `Send` because `&` references cannot be sent unless their referent is `Sync`
//~| NOTE has type `&*mut ()` which is not `Send`, because `*mut ()` is not `Sync`
assert_send(#[coroutine] move || {
//~^ ERROR coroutine cannot be sent between threads safely
//~| NOTE coroutine is not `Send`
yield;
let _y = y;
});
//~^^ NOTE captured value is not `Send` because `&mut` references cannot be sent unless their referent is `Send`
//~| NOTE has type `&mut *mut ()` which is not `Send`, because `*mut ()` is not `Send`
}