about summary refs log tree commit diff
path: root/src/test/ui
diff options
context:
space:
mode:
authorDavid Wood <david@davidtw.co>2019-04-24 19:11:10 +0100
committerDavid Wood <david@davidtw.co>2019-04-24 20:56:18 +0100
commit04023dc22da3f3329ba1eadc8ceb132a70a333d9 (patch)
tree63be1230e20fb410f0035c2f645cbb55a6bae9ec /src/test/ui
parente305df1846a6d985315917ae0c81b74af8b4e641 (diff)
downloadrust-04023dc22da3f3329ba1eadc8ceb132a70a333d9.tar.gz
rust-04023dc22da3f3329ba1eadc8ceb132a70a333d9.zip
Add regression test for #53249.
Diffstat (limited to 'src/test/ui')
-rw-r--r--src/test/ui/issue-53249.rs47
1 files changed, 47 insertions, 0 deletions
diff --git a/src/test/ui/issue-53249.rs b/src/test/ui/issue-53249.rs
new file mode 100644
index 00000000000..9e4ff43ecd1
--- /dev/null
+++ b/src/test/ui/issue-53249.rs
@@ -0,0 +1,47 @@
+// compile-pass
+// edition:2018
+
+#![feature(arbitrary_self_types, async_await, await_macro)]
+
+use std::task::{self, Poll};
+use std::future::Future;
+use std::marker::Unpin;
+use std::pin::Pin;
+
+// This is a regression test for a ICE/unbounded recursion issue relating to async-await.
+
+#[derive(Debug)]
+#[must_use = "futures do nothing unless polled"]
+pub struct Lazy<F> {
+    f: Option<F>
+}
+
+impl<F> Unpin for Lazy<F> {}
+
+pub fn lazy<F, R>(f: F) -> Lazy<F>
+    where F: FnOnce(&mut task::Context) -> R,
+{
+    Lazy { f: Some(f) }
+}
+
+impl<R, F> Future for Lazy<F>
+    where F: FnOnce(&mut task::Context) -> R,
+{
+    type Output = R;
+
+    fn poll(mut self: Pin<&mut Self>, cx: &mut task::Context) -> Poll<R> {
+        Poll::Ready((self.f.take().unwrap())(cx))
+    }
+}
+
+async fn __receive<WantFn, Fut>(want: WantFn) -> ()
+    where Fut: Future<Output = ()>, WantFn: Fn(&Box<Send + 'static>) -> Fut,
+{
+    await!(lazy(|_| ()));
+}
+
+pub fn basic_spawn_receive() {
+    async { await!(__receive(|_| async { () })) };
+}
+
+fn main() {}