diff options
| author | David Wood <david@davidtw.co> | 2019-04-24 19:11:10 +0100 |
|---|---|---|
| committer | David Wood <david@davidtw.co> | 2019-04-24 20:56:18 +0100 |
| commit | 04023dc22da3f3329ba1eadc8ceb132a70a333d9 (patch) | |
| tree | 63be1230e20fb410f0035c2f645cbb55a6bae9ec /src/test/ui | |
| parent | e305df1846a6d985315917ae0c81b74af8b4e641 (diff) | |
| download | rust-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.rs | 47 |
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() {} |
