rust/tests/ui/coroutine/ref-upvar-not-send.rs

Ignoring revisions in .git-blame-ignore-revs. Click here to bypass and see the normal blame view.

32 lines
1.3 KiB
Rust
Raw Permalink Normal View History

2023-10-19 16:46:28 -05:00
// 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 || {
2023-10-19 16:46:28 -05:00
//~^ 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 || {
2023-10-19 16:46:28 -05:00
//~^ 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`
}