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
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
|
// run-rustfix
#![warn(clippy::identity_op)]
#![allow(
clippy::eq_op,
clippy::no_effect,
clippy::unnecessary_operation,
clippy::op_ref,
clippy::double_parens,
unused
)]
use std::fmt::Write as _;
const ONE: i64 = 1;
const NEG_ONE: i64 = -1;
const ZERO: i64 = 0;
struct A(String);
impl std::ops::Shl<i32> for A {
type Output = A;
fn shl(mut self, other: i32) -> Self {
let _ = write!(self.0, "{}", other);
self
}
}
struct Length(u8);
struct Meter;
impl core::ops::Mul<Meter> for u8 {
type Output = Length;
fn mul(self, _: Meter) -> Length {
Length(self)
}
}
#[rustfmt::skip]
fn main() {
let x = 0;
x;
x;
x + 1;
x;
1 + x;
x - ZERO; //no error, as we skip lookups (for now)
x;
((ZERO)) | x; //no error, as we skip lookups (for now)
x;
x;
x / ONE; //no error, as we skip lookups (for now)
x / 2; //no false positive
x & NEG_ONE; //no error, as we skip lookups (for now)
x;
let u: u8 = 0;
u;
1 << 0; // no error, this case is allowed, see issue 3430
42;
1;
42;
&x;
x;
let mut a = A("".into());
let b = a << 0; // no error: non-integer
1 * Meter; // no error: non-integer
2;
-2;
2 + x;
-2 + x;
x + 1;
(x + 1) % 3; // no error
4 % 3; // no error
4 % -3; // no error
// See #8724
let a = 0;
let b = true;
(if b { 1 } else { 2 });
(if b { 1 } else { 2 }) + if b { 3 } else { 4 };
(match a { 0 => 10, _ => 20 });
(match a { 0 => 10, _ => 20 }) + match a { 0 => 30, _ => 40 };
(if b { 1 } else { 2 }) + match a { 0 => 30, _ => 40 };
(match a { 0 => 10, _ => 20 }) + if b { 3 } else { 4 };
(if b { 1 } else { 2 });
({ a }) + 3;
({ a } * 2);
(loop { let mut c = 0; if c == 10 { break c; } c += 1; }) + { a * 2 };
fn f(_: i32) {
todo!();
}
f(a + { 8 * 5 });
f(if b { 1 } else { 2 } + 3);
const _: i32 = { 2 * 4 } + 3;
const _: i32 = { 1 + 2 * 3 } + 3;
a as usize;
let _ = a as usize;
({ a } as usize);
2 * { a };
(({ a } + 4));
1;
}
pub fn decide(a: bool, b: bool) -> u32 {
(if a { 1 } else { 2 }) + if b { 3 } else { 5 }
}
|