summaryrefslogtreecommitdiffstats
path: root/tests/ui/async-await/issues/issue-65436-raw-ptr-not-send.no_drop_tracking.stderr
blob: 8745bdd973beabf5637819b3d9fdc462bb7b2a61 (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
error: future cannot be sent between threads safely
  --> $DIR/issue-65436-raw-ptr-not-send.rs:17:17
   |
LL |       assert_send(async {
   |  _________________^
LL | |
LL | |         bar(Foo(std::ptr::null())).await;
LL | |     })
   | |_____^ future created by async block is not `Send`
   |
   = help: within `[async block@$DIR/issue-65436-raw-ptr-not-send.rs:17:17: 20:6]`, the trait `Send` is not implemented for `*const u8`
note: future is not `Send` as this value is used across an await
  --> $DIR/issue-65436-raw-ptr-not-send.rs:19:35
   |
LL |         bar(Foo(std::ptr::null())).await;
   |                 ----------------  ^^^^^^- `std::ptr::null()` is later dropped here
   |                 |                 |
   |                 |                 await occurs here, with `std::ptr::null()` maybe used later
   |                 has type `*const u8` which is not `Send`
help: consider moving this into a `let` binding to create a shorter lived borrow
  --> $DIR/issue-65436-raw-ptr-not-send.rs:19:13
   |
LL |         bar(Foo(std::ptr::null())).await;
   |             ^^^^^^^^^^^^^^^^^^^^^
note: required by a bound in `assert_send`
  --> $DIR/issue-65436-raw-ptr-not-send.rs:14:19
   |
LL | fn assert_send<T: Send>(_: T) {}
   |                   ^^^^ required by this bound in `assert_send`

error: aborting due to previous error