//@ edition: 2018 // This is `no-borrow-from-env.rs`, but under edition 2018 we still want to make // sure that we don't ICE or anything, even if precise closure captures means // that we can't actually borrowck successfully. #![feature(async_closure)] fn outlives<'a>(_: impl Sized + 'a) {} async fn call_once(f: impl async FnOnce()) { f().await; } fn simple<'a>(x: &'a i32) { let c = async || { println!("{}", *x); }; //~ ERROR `x` does not live long enough outlives::<'a>(c()); outlives::<'a>(call_once(c)); let c = async move || { println!("{}", *x); }; outlives::<'a>(c()); //~ ERROR `c` does not live long enough outlives::<'a>(call_once(c)); } struct S<'a>(&'a i32); fn through_field<'a>(x: S<'a>) { let c = async || { println!("{}", *x.0); }; //~ ERROR `x` does not live long enough outlives::<'a>(c()); outlives::<'a>(call_once(c)); let c = async move || { println!("{}", *x.0); }; //~ ERROR cannot move out of `x` outlives::<'a>(c()); //~ ERROR `c` does not live long enough outlives::<'a>(call_once(c)); //~ ERROR cannot move out of `c` } fn through_field_and_ref<'a>(x: &S<'a>) { let c = async || { println!("{}", *x.0); }; //~ ERROR `x` does not live long enough outlives::<'a>(c()); outlives::<'a>(call_once(c)); //~ ERROR explicit lifetime required in the type of `x` let c = async move || { println!("{}", *x.0); }; outlives::<'a>(c()); //~ ERROR `c` does not live long enough // outlives::<'a>(call_once(c)); // FIXME(async_closures): Figure out why this fails } fn main() {}