2023-04-20 14:37:15 +00:00
|
|
|
//@run-rustfix
|
2022-05-04 18:13:06 +01:00
|
|
|
#![warn(clippy::identity_op)]
|
2022-10-02 15:13:22 -04:00
|
|
|
#![allow(unused)]
|
2022-05-04 18:13:06 +01:00
|
|
|
#![allow(
|
|
|
|
clippy::eq_op,
|
|
|
|
clippy::no_effect,
|
|
|
|
clippy::unnecessary_operation,
|
|
|
|
clippy::op_ref,
|
|
|
|
clippy::double_parens,
|
2022-10-02 15:13:22 -04:00
|
|
|
clippy::uninlined_format_args
|
2022-05-04 18:13:06 +01:00
|
|
|
)]
|
|
|
|
|
2022-04-03 21:40:58 -06:00
|
|
|
use std::fmt::Write as _;
|
|
|
|
|
2018-12-09 23:26:16 +01:00
|
|
|
const ONE: i64 = 1;
|
|
|
|
const NEG_ONE: i64 = -1;
|
|
|
|
const ZERO: i64 = 0;
|
|
|
|
|
2021-12-28 08:19:47 -08:00
|
|
|
struct A(String);
|
|
|
|
|
|
|
|
impl std::ops::Shl<i32> for A {
|
|
|
|
type Output = A;
|
|
|
|
fn shl(mut self, other: i32) -> Self {
|
2022-04-03 21:40:58 -06:00
|
|
|
let _ = write!(self.0, "{}", other);
|
2021-12-28 08:19:47 -08:00
|
|
|
self
|
|
|
|
}
|
|
|
|
}
|
2021-12-31 09:37:39 +01:00
|
|
|
|
|
|
|
struct Length(u8);
|
|
|
|
struct Meter;
|
|
|
|
|
|
|
|
impl core::ops::Mul<Meter> for u8 {
|
|
|
|
type Output = Length;
|
|
|
|
fn mul(self, _: Meter) -> Length {
|
|
|
|
Length(self)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2018-12-11 00:59:59 +01:00
|
|
|
#[rustfmt::skip]
|
2015-05-15 18:46:43 +02:00
|
|
|
fn main() {
|
2015-08-11 20:22:20 +02:00
|
|
|
let x = 0;
|
|
|
|
|
2017-02-08 14:58:07 +01:00
|
|
|
x + 0;
|
|
|
|
x + (1 - 1);
|
2015-08-17 11:46:45 +02:00
|
|
|
x + 1;
|
2017-02-08 14:58:07 +01:00
|
|
|
0 + x;
|
2015-08-17 11:46:45 +02:00
|
|
|
1 + x;
|
2018-12-09 23:26:16 +01:00
|
|
|
x - ZERO; //no error, as we skip lookups (for now)
|
2017-02-08 14:58:07 +01:00
|
|
|
x | (0);
|
2018-12-11 00:59:59 +01:00
|
|
|
((ZERO)) | x; //no error, as we skip lookups (for now)
|
2015-08-11 20:22:20 +02:00
|
|
|
|
2017-02-08 14:58:07 +01:00
|
|
|
x * 1;
|
|
|
|
1 * x;
|
2018-12-09 23:26:16 +01:00
|
|
|
x / ONE; //no error, as we skip lookups (for now)
|
2015-08-11 20:22:20 +02:00
|
|
|
|
2018-12-09 23:26:16 +01:00
|
|
|
x / 2; //no false positive
|
2015-08-17 11:46:45 +02:00
|
|
|
|
2018-12-09 23:26:16 +01:00
|
|
|
x & NEG_ONE; //no error, as we skip lookups (for now)
|
2017-02-08 14:58:07 +01:00
|
|
|
-1 & x;
|
2017-09-30 11:33:15 +03:00
|
|
|
|
2018-12-09 23:26:16 +01:00
|
|
|
let u: u8 = 0;
|
2017-09-30 11:33:15 +03:00
|
|
|
u & 255;
|
2020-05-15 21:17:37 +02:00
|
|
|
|
|
|
|
1 << 0; // no error, this case is allowed, see issue 3430
|
|
|
|
42 << 0;
|
|
|
|
1 >> 0;
|
|
|
|
42 >> 0;
|
2021-12-28 08:19:47 -08:00
|
|
|
&x >> 0;
|
2021-12-28 08:32:55 -08:00
|
|
|
x >> &0;
|
2021-12-28 08:19:47 -08:00
|
|
|
|
2022-08-05 20:59:50 -03:00
|
|
|
let mut a = A(String::new());
|
2021-12-28 08:19:47 -08:00
|
|
|
let b = a << 0; // no error: non-integer
|
2021-12-31 09:37:39 +01:00
|
|
|
|
|
|
|
1 * Meter; // no error: non-integer
|
2022-03-11 11:31:17 +08:00
|
|
|
|
|
|
|
2 % 3;
|
|
|
|
-2 % 3;
|
2022-03-27 21:48:15 +08:00
|
|
|
2 % -3 + x;
|
|
|
|
-2 % -3 + x;
|
2022-03-11 11:31:17 +08:00
|
|
|
x + 1 % 3;
|
|
|
|
(x + 1) % 3; // no error
|
|
|
|
4 % 3; // no error
|
2022-03-27 21:48:15 +08:00
|
|
|
4 % -3; // no error
|
2022-04-22 10:39:38 +09:00
|
|
|
|
|
|
|
// See #8724
|
|
|
|
let a = 0;
|
|
|
|
let b = true;
|
|
|
|
0 + if b { 1 } else { 2 };
|
2022-05-04 18:13:06 +01:00
|
|
|
0 + if b { 1 } else { 2 } + if b { 3 } else { 4 };
|
2022-04-22 10:39:38 +09:00
|
|
|
0 + match a { 0 => 10, _ => 20 };
|
2022-05-04 18:13:06 +01:00
|
|
|
0 + match a { 0 => 10, _ => 20 } + match a { 0 => 30, _ => 40 };
|
|
|
|
0 + if b { 1 } else { 2 } + match a { 0 => 30, _ => 40 };
|
|
|
|
0 + match a { 0 => 10, _ => 20 } + if b { 3 } else { 4 };
|
|
|
|
(if b { 1 } else { 2 }) + 0;
|
|
|
|
|
|
|
|
0 + { a } + 3;
|
|
|
|
0 + { a } * 2;
|
|
|
|
0 + loop { let mut c = 0; if c == 10 { break c; } c += 1; } + { a * 2 };
|
|
|
|
|
2022-04-22 10:39:38 +09:00
|
|
|
fn f(_: i32) {
|
|
|
|
todo!();
|
|
|
|
}
|
|
|
|
f(1 * a + { 8 * 5 });
|
2022-05-04 18:13:06 +01:00
|
|
|
f(0 + if b { 1 } else { 2 } + 3);
|
2022-04-22 10:39:38 +09:00
|
|
|
const _: i32 = { 2 * 4 } + 0 + 3;
|
2022-05-04 18:13:06 +01:00
|
|
|
const _: i32 = 0 + { 1 + 2 * 3 } + 3;
|
|
|
|
|
|
|
|
0 + a as usize;
|
|
|
|
let _ = 0 + a as usize;
|
|
|
|
0 + { a } as usize;
|
|
|
|
|
|
|
|
2 * (0 + { a });
|
|
|
|
1 * ({ a } + 4);
|
|
|
|
1 * 1;
|
2022-11-30 16:25:57 -05:00
|
|
|
|
|
|
|
// Issue #9904
|
|
|
|
let x = 0i32;
|
|
|
|
let _: i32 = &x + 0;
|
2022-05-04 18:13:06 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
pub fn decide(a: bool, b: bool) -> u32 {
|
|
|
|
0 + if a { 1 } else { 2 } + if b { 3 } else { 5 }
|
2015-05-15 18:46:43 +02:00
|
|
|
}
|