blob: 88f6935d224aec502122cc5ebf5e06d8b70a0a7f (
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
|
#![warn(clippy::missing_const_for_fn)]
#![allow(incomplete_features, clippy::let_and_return)]
#![feature(custom_inner_attributes)]
use std::mem::transmute;
struct Game {
guess: i32,
}
impl Game {
// Could be const
pub fn new() -> Self {
Self { guess: 42 }
}
fn const_generic_params<'a, T, const N: usize>(&self, b: &'a [T; N]) -> &'a [T; N] {
b
}
}
// Could be const
fn one() -> i32 {
1
}
// Could also be const
fn two() -> i32 {
let abc = 2;
abc
}
// Could be const (since Rust 1.39)
fn string() -> String {
String::new()
}
// Could be const
unsafe fn four() -> i32 {
4
}
// Could also be const
fn generic<T>(t: T) -> T {
t
}
fn sub(x: u32) -> usize {
unsafe { transmute(&x) }
}
fn generic_arr<T: Copy>(t: [T; 1]) -> T {
t[0]
}
mod with_drop {
pub struct A;
pub struct B;
impl Drop for A {
fn drop(&mut self) {}
}
impl B {
// This can be const, because `a` is passed by reference
pub fn b(self, a: &A) -> B {
B
}
}
}
mod const_fn_stabilized_before_msrv {
#![clippy::msrv = "1.47.0"]
// This could be const because `u8::is_ascii_digit` is a stable const function in 1.47.
fn const_fn_stabilized_before_msrv(byte: u8) {
byte.is_ascii_digit();
}
}
// Should not be const
fn main() {}
|