Error code E0733

An async function used recursion without boxing.

Erroneous code example:

#![allow(unused)] fn main() { async fn foo(n: usize) { if n > 0 { foo(n - 1).await; } } }

To perform async recursion, the async fn needs to be desugared such that the Future is explicit in the return type:

#![allow(unused)] fn main() { use std::future::Future; fn foo_desugared(n: usize) -> impl Future<Output = ()> { async move { if n > 0 { foo_desugared(n - 1).await; } } } }

Finally, the future is wrapped in a pinned box:

#![allow(unused)] fn main() { use std::future::Future; use std::pin::Pin; fn foo_recursive(n: usize) -> Pin<Box<dyn Future<Output = ()>>> { Box::pin(async move { if n > 0 { foo_recursive(n - 1).await; } }) } }

The Box<...> ensures that the result is of known size, and the pin is required to keep it in the same place in memory.