blob: 35d9cb15540d1f753d8af69098a7bf641b92cf3c (
plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
|
// build-pass (FIXME(62277): could be check-pass?)
// 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());
}
|