]> git.lizzy.rs Git - rust.git/commitdiff
test `unsafe fn` and `async unsafe fn` calls in `unsafe { async || }`
authorDelan Azabani <delan@azabani.com>
Fri, 12 Jul 2019 04:54:52 +0000 (14:54 +1000)
committerDelan Azabani <delan@azabani.com>
Fri, 12 Jul 2019 05:10:52 +0000 (15:10 +1000)
src/test/ui/async-await/async-await.rs
src/test/ui/async-await/async-closure.rs
src/test/ui/async-await/await-macro.rs

index dbcba812a40caa9c0b89e0139cc73cd8e95ec741..5ec99c5d183fb957780e46558fc1f58e5947de16 100644 (file)
@@ -3,7 +3,7 @@
 // edition:2018
 // aux-build:arc_wake.rs
 
-#![feature(async_await, async_closure)]
+#![feature(async_await)]
 
 extern crate arc_wake;
 
@@ -70,7 +70,7 @@ fn async_nonmove_block(x: u8) -> impl Future<Output = u8> {
     }
 }
 
-// see async-closure.rs for async_closure
+// see async-closure.rs for async_closure + async_closure_in_unsafe_block
 
 async fn async_fn(x: u8) -> u8 {
     wake_and_yield_once().await;
index f5dc9e24d2d86d0662f8f1305191c9bbea28e2f8..925b54b398517dfacc69f3a51d22f6fa87decfd6 100644 (file)
@@ -53,6 +53,21 @@ fn async_closure(x: u8) -> impl Future<Output = u8> {
     })(x)
 }
 
+fn async_closure_in_unsafe_block(x: u8) -> impl Future<Output = u8> {
+    (unsafe {
+        async move |x: u8| unsafe_fn(unsafe_async_fn(x).await)
+    })(x)
+}
+
+async unsafe fn unsafe_async_fn(x: u8) -> u8 {
+    wake_and_yield_once().await;
+    x
+}
+
+unsafe fn unsafe_fn(x: u8) -> u8 {
+    x
+}
+
 fn test_future_yields_once_then_returns<F, Fut>(f: F)
 where
     F: FnOnce(u8) -> Fut,
@@ -77,5 +92,6 @@ macro_rules! test {
 
     test! {
         async_closure,
+        async_closure_in_unsafe_block,
     }
 }
index 9ac0ab7c6c78f34bf8c1177393314379391fda24..b9cd3903513a47492bb528adf9b61f50ee7a4ad3 100644 (file)
@@ -77,6 +77,12 @@ fn async_closure(x: u8) -> impl Future<Output = u8> {
     })(x)
 }
 
+fn async_closure_in_unsafe_block(x: u8) -> impl Future<Output = u8> {
+    (unsafe {
+        async move |x: u8| unsafe_fn(await!(unsafe_async_fn(x)))
+    })(x)
+}
+
 async fn async_fn(x: u8) -> u8 {
     await!(wake_and_yield_once());
     x
@@ -193,6 +199,7 @@ macro_rules! test_with_borrow {
         async_block,
         async_nonmove_block,
         async_closure,
+        async_closure_in_unsafe_block,
         async_fn,
         generic_async_fn,
         async_fn_with_internal_borrow,