|
| 1 | +error[E0277]: `std::rc::Rc<()>` cannot be sent between threads safely |
| 2 | + --> $DIR/async-fn-nonsend.rs:52:5 |
| 3 | + | |
| 4 | +LL | assert_send(local_dropped_before_await()); |
| 5 | + | ^^^^^^^^^^^ `std::rc::Rc<()>` cannot be sent between threads safely |
| 6 | + | |
| 7 | + = help: within `impl std::future::Future`, the trait `std::marker::Send` is not implemented for `std::rc::Rc<()>` |
| 8 | + = note: required because it appears within the type `impl std::fmt::Debug` |
| 9 | + = note: required because it appears within the type `{impl std::fmt::Debug, impl std::future::Future, ()}` |
| 10 | + = note: required because it appears within the type `[static generator@$DIR/async-fn-nonsend.rs:23:39: 28:2 {impl std::fmt::Debug, impl std::future::Future, ()}]` |
| 11 | + = note: required because it appears within the type `std::future::GenFuture<[static generator@$DIR/async-fn-nonsend.rs:23:39: 28:2 {impl std::fmt::Debug, impl std::future::Future, ()}]>` |
| 12 | + = note: required because it appears within the type `impl std::future::Future` |
| 13 | + = note: required because it appears within the type `impl std::future::Future` |
| 14 | +note: required by `assert_send` |
| 15 | + --> $DIR/async-fn-nonsend.rs:49:1 |
| 16 | + | |
| 17 | +LL | fn assert_send(_: impl Send) {} |
| 18 | + | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^ |
| 19 | + |
| 20 | +error[E0277]: `std::rc::Rc<()>` cannot be sent between threads safely |
| 21 | + --> $DIR/async-fn-nonsend.rs:54:5 |
| 22 | + | |
| 23 | +LL | assert_send(non_send_temporary_in_match()); |
| 24 | + | ^^^^^^^^^^^ `std::rc::Rc<()>` cannot be sent between threads safely |
| 25 | + | |
| 26 | + = help: within `impl std::future::Future`, the trait `std::marker::Send` is not implemented for `std::rc::Rc<()>` |
| 27 | + = note: required because it appears within the type `impl std::fmt::Debug` |
| 28 | + = note: required because it appears within the type `{fn(impl std::fmt::Debug) -> std::option::Option<impl std::fmt::Debug> {std::option::Option::<impl std::fmt::Debug>::Some}, fn() -> impl std::fmt::Debug {non_send}, impl std::fmt::Debug, std::option::Option<impl std::fmt::Debug>, impl std::future::Future, ()}` |
| 29 | + = note: required because it appears within the type `[static generator@$DIR/async-fn-nonsend.rs:30:40: 39:2 {fn(impl std::fmt::Debug) -> std::option::Option<impl std::fmt::Debug> {std::option::Option::<impl std::fmt::Debug>::Some}, fn() -> impl std::fmt::Debug {non_send}, impl std::fmt::Debug, std::option::Option<impl std::fmt::Debug>, impl std::future::Future, ()}]` |
| 30 | + = note: required because it appears within the type `std::future::GenFuture<[static generator@$DIR/async-fn-nonsend.rs:30:40: 39:2 {fn(impl std::fmt::Debug) -> std::option::Option<impl std::fmt::Debug> {std::option::Option::<impl std::fmt::Debug>::Some}, fn() -> impl std::fmt::Debug {non_send}, impl std::fmt::Debug, std::option::Option<impl std::fmt::Debug>, impl std::future::Future, ()}]>` |
| 31 | + = note: required because it appears within the type `impl std::future::Future` |
| 32 | + = note: required because it appears within the type `impl std::future::Future` |
| 33 | +note: required by `assert_send` |
| 34 | + --> $DIR/async-fn-nonsend.rs:49:1 |
| 35 | + | |
| 36 | +LL | fn assert_send(_: impl Send) {} |
| 37 | + | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^ |
| 38 | + |
| 39 | +error[E0277]: `dyn std::fmt::Write` cannot be sent between threads safely |
| 40 | + --> $DIR/async-fn-nonsend.rs:56:5 |
| 41 | + | |
| 42 | +LL | assert_send(non_sync_with_method_call()); |
| 43 | + | ^^^^^^^^^^^ `dyn std::fmt::Write` cannot be sent between threads safely |
| 44 | + | |
| 45 | + = help: the trait `std::marker::Send` is not implemented for `dyn std::fmt::Write` |
| 46 | + = note: required because of the requirements on the impl of `std::marker::Send` for `&mut dyn std::fmt::Write` |
| 47 | + = note: required because it appears within the type `std::fmt::Formatter<'_>` |
| 48 | + = note: required because of the requirements on the impl of `std::marker::Send` for `&mut std::fmt::Formatter<'_>` |
| 49 | + = note: required because it appears within the type `for<'r, 's> {&'r mut std::fmt::Formatter<'s>, bool, impl std::future::Future, ()}` |
| 50 | + = note: required because it appears within the type `[static generator@$DIR/async-fn-nonsend.rs:41:38: 47:2 for<'r, 's> {&'r mut std::fmt::Formatter<'s>, bool, impl std::future::Future, ()}]` |
| 51 | + = note: required because it appears within the type `std::future::GenFuture<[static generator@$DIR/async-fn-nonsend.rs:41:38: 47:2 for<'r, 's> {&'r mut std::fmt::Formatter<'s>, bool, impl std::future::Future, ()}]>` |
| 52 | + = note: required because it appears within the type `impl std::future::Future` |
| 53 | + = note: required because it appears within the type `impl std::future::Future` |
| 54 | +note: required by `assert_send` |
| 55 | + --> $DIR/async-fn-nonsend.rs:49:1 |
| 56 | + | |
| 57 | +LL | fn assert_send(_: impl Send) {} |
| 58 | + | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^ |
| 59 | + |
| 60 | +error[E0277]: `*mut (dyn std::ops::Fn() + 'static)` cannot be shared between threads safely |
| 61 | + --> $DIR/async-fn-nonsend.rs:56:5 |
| 62 | + | |
| 63 | +LL | assert_send(non_sync_with_method_call()); |
| 64 | + | ^^^^^^^^^^^ `*mut (dyn std::ops::Fn() + 'static)` cannot be shared between threads safely |
| 65 | + | |
| 66 | + = help: within `std::fmt::ArgumentV1<'_>`, the trait `std::marker::Sync` is not implemented for `*mut (dyn std::ops::Fn() + 'static)` |
| 67 | + = note: required because it appears within the type `std::marker::PhantomData<*mut (dyn std::ops::Fn() + 'static)>` |
| 68 | + = note: required because it appears within the type `core::fmt::Void` |
| 69 | + = note: required because it appears within the type `&core::fmt::Void` |
| 70 | + = note: required because it appears within the type `std::fmt::ArgumentV1<'_>` |
| 71 | + = note: required because of the requirements on the impl of `std::marker::Send` for `std::slice::Iter<'_, std::fmt::ArgumentV1<'_>>` |
| 72 | + = note: required because it appears within the type `std::fmt::Formatter<'_>` |
| 73 | + = note: required because of the requirements on the impl of `std::marker::Send` for `&mut std::fmt::Formatter<'_>` |
| 74 | + = note: required because it appears within the type `for<'r, 's> {&'r mut std::fmt::Formatter<'s>, bool, impl std::future::Future, ()}` |
| 75 | + = note: required because it appears within the type `[static generator@$DIR/async-fn-nonsend.rs:41:38: 47:2 for<'r, 's> {&'r mut std::fmt::Formatter<'s>, bool, impl std::future::Future, ()}]` |
| 76 | + = note: required because it appears within the type `std::future::GenFuture<[static generator@$DIR/async-fn-nonsend.rs:41:38: 47:2 for<'r, 's> {&'r mut std::fmt::Formatter<'s>, bool, impl std::future::Future, ()}]>` |
| 77 | + = note: required because it appears within the type `impl std::future::Future` |
| 78 | + = note: required because it appears within the type `impl std::future::Future` |
| 79 | +note: required by `assert_send` |
| 80 | + --> $DIR/async-fn-nonsend.rs:49:1 |
| 81 | + | |
| 82 | +LL | fn assert_send(_: impl Send) {} |
| 83 | + | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^ |
| 84 | + |
| 85 | +error: aborting due to 4 previous errors |
| 86 | + |
| 87 | +For more information about this error, try `rustc --explain E0277`. |
0 commit comments