rust/tests/ui/manual_async_fn.rs

143 lines
2.6 KiB
Rust
Raw Normal View History

//@run-rustfix
2020-05-07 21:41:23 +02:00
#![warn(clippy::manual_async_fn)]
#![allow(unused)]
use std::future::Future;
fn fut() -> impl Future<Output = i32> {
async { 42 }
}
#[rustfmt::skip]
fn fut2() ->impl Future<Output = i32> {
async { 42 }
}
#[rustfmt::skip]
fn fut3()-> impl Future<Output = i32> {
async { 42 }
}
2020-05-07 21:41:23 +02:00
fn empty_fut() -> impl Future<Output = ()> {
async {}
}
#[rustfmt::skip]
fn empty_fut2() ->impl Future<Output = ()> {
async {}
}
#[rustfmt::skip]
fn empty_fut3()-> impl Future<Output = ()> {
async {}
}
2020-05-07 21:41:23 +02:00
fn core_fut() -> impl core::future::Future<Output = i32> {
async move { 42 }
}
// should be ignored
fn has_other_stmts() -> impl core::future::Future<Output = i32> {
let _ = 42;
async move { 42 }
}
// should be ignored
fn not_fut() -> i32 {
42
}
// should be ignored
async fn already_async() -> impl Future<Output = i32> {
async { 42 }
}
2022-03-27 14:41:09 +02:00
struct S;
2020-05-07 21:41:23 +02:00
impl S {
fn inh_fut() -> impl Future<Output = i32> {
2020-05-07 22:40:28 +02:00
async {
2020-07-17 01:58:41 +02:00
// NOTE: this code is here just to check that the indentation is correct in the suggested fix
2020-05-07 22:40:28 +02:00
let a = 42;
let b = 21;
if a < b {
let c = 21;
let d = 42;
if c < d {
let _ = 42;
}
}
42
}
2020-05-07 21:41:23 +02:00
}
// should be ignored
fn not_fut(&self) -> i32 {
42
}
// should be ignored
fn has_other_stmts() -> impl core::future::Future<Output = i32> {
let _ = 42;
async move { 42 }
}
// should be ignored
async fn already_async(&self) -> impl Future<Output = i32> {
async { 42 }
}
}
// Tests related to lifetime capture
fn elided(_: &i32) -> impl Future<Output = i32> + '_ {
async { 42 }
}
// should be ignored
fn elided_not_bound(_: &i32) -> impl Future<Output = i32> {
async { 42 }
}
fn explicit<'a, 'b>(_: &'a i32, _: &'b i32) -> impl Future<Output = i32> + 'a + 'b {
async { 42 }
}
// should be ignored
#[allow(clippy::needless_lifetimes)]
fn explicit_not_bound<'a, 'b>(_: &'a i32, _: &'b i32) -> impl Future<Output = i32> {
async { 42 }
}
// should be ignored
mod issue_5765 {
use std::future::Future;
struct A;
impl A {
fn f(&self) -> impl Future<Output = ()> {
async {}
}
}
fn test() {
let _future = {
let a = A;
a.f()
};
}
}
pub fn issue_10450() -> impl Future<Output = i32> {
async { 42 }
}
pub(crate) fn issue_10450_2() -> impl Future<Output = i32> {
async { 42 }
}
pub(self) fn issue_10450_3() -> impl Future<Output = i32> {
async { 42 }
}
2020-05-07 21:41:23 +02:00
fn main() {}