rust/tests/ui/async-await/async-fn-send-uses-nonsend.rs

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

58 lines
1.2 KiB
Rust
Raw Normal View History

// build-pass (FIXME(62277): could be check-pass?)
2019-06-24 19:48:21 -05:00
// edition:2018
// compile-flags: --crate-type lib
use std::{
cell::RefCell,
fmt::Debug,
rc::Rc,
};
fn non_sync() -> impl Debug { RefCell::new(()) }
fn non_send() -> impl Debug { Rc::new(()) }
fn take_ref<T>(_: &T) {}
async fn fut() {}
async fn fut_arg<T>(_: T) {}
async fn still_send() {
fut().await;
println!("{:?} {:?}", non_send(), non_sync());
fut().await;
drop(non_send());
drop(non_sync());
fut().await;
fut_arg(non_sync()).await;
// Note: all temporaries in `if let` and `match` scrutinee
// are dropped at the *end* of the blocks, so using `non_send()`
// in either of those positions with an await in the middle will
// cause a `!Send` future. It might be nice in the future to allow
// this for `Copy` types, since they can be "dropped" early without
// affecting the end user.
if let Some(_) = Some(non_sync()) {
fut().await;
}
match Some(non_sync()) {
Some(_) => fut().await,
None => fut().await,
}
let _ = non_send();
fut().await;
{
let _x = non_send();
}
fut().await;
}
fn assert_send(_: impl Send) {}
pub fn pass_assert() {
assert_send(still_send());
}