2020-05-07 21:41:23 +02:00
|
|
|
// run-rustfix
|
|
|
|
#![warn(clippy::manual_async_fn)]
|
|
|
|
#![allow(unused)]
|
|
|
|
|
|
|
|
use std::future::Future;
|
|
|
|
|
|
|
|
async fn fut() -> i32 { 42 }
|
|
|
|
|
2020-11-05 13:56:57 +09:00
|
|
|
#[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() {}
|
2020-05-07 21:41:23 +02:00
|
|
|
|
|
|
|
async fn core_fut() -> i32 { 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 {
|
2020-05-07 22:40:28 +02:00
|
|
|
async fn inh_fut() -> i32 {
|
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 }
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2020-08-03 00:36:28 +02:00
|
|
|
// Tests related to lifetime capture
|
|
|
|
|
|
|
|
async fn elided(_: &i32) -> i32 { 42 }
|
|
|
|
|
|
|
|
// should be ignored
|
|
|
|
fn elided_not_bound(_: &i32) -> impl Future<Output = i32> {
|
|
|
|
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<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()
|
|
|
|
};
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2020-05-07 21:41:23 +02:00
|
|
|
fn main() {}
|