blob: 7ec8a3adb4cd5617d224b7e87c7013370f5439a7 (
plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
|
#![warn(clippy::unused_async)]
#![allow(incomplete_features)]
use std::future::Future;
use std::pin::Pin;
mod issue10800 {
#![allow(dead_code, unused_must_use, clippy::no_effect)]
use std::future::ready;
async fn async_block_await() {
//~^ ERROR: unused `async` for function with no await statements
async {
ready(()).await;
};
}
async fn normal_block_await() {
{
{
ready(()).await;
}
}
}
}
mod issue10459 {
trait HasAsyncMethod {
async fn do_something() -> u32;
}
impl HasAsyncMethod for () {
async fn do_something() -> u32 {
1
}
}
}
mod issue9695 {
use std::future::Future;
async fn f() {}
async fn f2() {}
async fn f3() {}
//~^ ERROR: unused `async` for function with no await statements
fn needs_async_fn<F: Future<Output = ()>>(_: fn() -> F) {}
fn test() {
let x = f;
needs_async_fn(x); // async needed in f
needs_async_fn(f2); // async needed in f2
f3(); // async not needed in f3
}
}
async fn foo() -> i32 {
//~^ ERROR: unused `async` for function with no await statements
4
}
async fn bar() -> i32 {
foo().await
}
struct S;
impl S {
async fn unused(&self) -> i32 {
//~^ ERROR: unused `async` for function with no await statements
1
}
async fn used(&self) -> i32 {
self.unused().await
}
}
trait AsyncTrait {
fn trait_method() -> Pin<Box<dyn Future<Output = i32>>>;
}
macro_rules! async_trait_impl {
() => {
impl AsyncTrait for S {
fn trait_method() -> Pin<Box<dyn Future<Output = i32>>> {
async fn unused() -> i32 {
5
}
Box::pin(unused())
}
}
};
}
async_trait_impl!();
fn main() {
foo();
bar();
}
|