// run-rustfix #![warn(clippy::manual_async_fn)] #![allow(unused)] use std::future::Future; async fn fut() -> i32 { 42 } #[rustfmt::skip] async fn fut2() -> i32 { 42 } #[rustfmt::skip] async fn fut3() -> i32 { 42 } async fn empty_fut() {} #[rustfmt::skip] async fn empty_fut2() {} #[rustfmt::skip] async fn empty_fut3() {} async fn core_fut() -> i32 { 42 } // should be ignored fn has_other_stmts() -> impl core::future::Future { let _ = 42; async move { 42 } } // should be ignored fn not_fut() -> i32 { 42 } // should be ignored async fn already_async() -> impl Future { async { 42 } } struct S; impl S { async fn inh_fut() -> i32 { // NOTE: this code is here just to check that the indentation is correct in the suggested fix let a = 42; let b = 21; if a < b { let c = 21; let d = 42; if c < d { let _ = 42; } } 42 } // should be ignored fn not_fut(&self) -> i32 { 42 } // should be ignored fn has_other_stmts() -> impl core::future::Future { let _ = 42; async move { 42 } } // should be ignored async fn already_async(&self) -> impl Future { async { 42 } } } // Tests related to lifetime capture async fn elided(_: &i32) -> i32 { 42 } // should be ignored fn elided_not_bound(_: &i32) -> impl Future { async { 42 } } async fn explicit<'a, 'b>(_: &'a i32, _: &'b i32) -> i32 { 42 } // should be ignored #[allow(clippy::needless_lifetimes)] fn explicit_not_bound<'a, 'b>(_: &'a i32, _: &'b i32) -> impl Future { async { 42 } } // should be ignored mod issue_5765 { use std::future::Future; struct A; impl A { fn f(&self) -> impl Future { async {} } } fn test() { let _future = { let a = A; a.f() }; } } fn main() {}