2022-02-10 18:40:06 +01:00
|
|
|
#![warn(clippy::eq_op)]
|
|
|
|
#![allow(clippy::double_parens, clippy::identity_op, clippy::nonminimal_bool)]
|
2022-11-21 20:34:47 +01:00
|
|
|
#![allow(clippy::suspicious_xor_used_as_pow)]
|
2022-02-10 18:40:06 +01:00
|
|
|
|
2015-04-30 11:48:43 +02:00
|
|
|
fn main() {
|
2015-08-11 20:22:20 +02:00
|
|
|
// simple values and comparisons
|
2022-02-10 18:40:06 +01:00
|
|
|
let _ = 1 == 1;
|
2023-08-24 21:32:12 +02:00
|
|
|
//~^ ERROR: equal expressions as operands to `==`
|
|
|
|
//~| NOTE: `-D clippy::eq-op` implied by `-D warnings`
|
2022-02-10 18:40:06 +01:00
|
|
|
let _ = "no" == "no";
|
2023-08-24 21:32:12 +02:00
|
|
|
//~^ ERROR: equal expressions as operands to `==`
|
2015-08-11 20:22:20 +02:00
|
|
|
// even though I agree that no means no ;-)
|
2022-02-10 18:40:06 +01:00
|
|
|
let _ = false != false;
|
2023-08-24 21:32:12 +02:00
|
|
|
//~^ ERROR: equal expressions as operands to `!=`
|
2022-02-10 18:40:06 +01:00
|
|
|
let _ = 1.5 < 1.5;
|
2023-08-24 21:32:12 +02:00
|
|
|
//~^ ERROR: equal expressions as operands to `<`
|
2022-02-10 18:40:06 +01:00
|
|
|
let _ = 1u64 >= 1u64;
|
2023-08-24 21:32:12 +02:00
|
|
|
//~^ ERROR: equal expressions as operands to `>=`
|
2023-07-02 14:35:19 +02:00
|
|
|
let x = f32::NAN;
|
|
|
|
let _ = x != x;
|
2023-08-24 21:32:12 +02:00
|
|
|
//~^ ERROR: equal expressions as operands to `!=`
|
|
|
|
//~| NOTE: if you intended to check if the operand is NaN, use `.is_nan()` instead
|
2015-08-11 20:22:20 +02:00
|
|
|
|
2015-08-13 09:44:03 +02:00
|
|
|
// casts, methods, parentheses
|
2022-02-10 18:40:06 +01:00
|
|
|
let _ = (1u32 as u64) & (1u32 as u64);
|
2023-08-24 21:32:12 +02:00
|
|
|
//~^ ERROR: equal expressions as operands to `&`
|
2022-02-10 18:40:06 +01:00
|
|
|
#[rustfmt::skip]
|
|
|
|
{
|
|
|
|
let _ = 1 ^ ((((((1))))));
|
2023-08-24 21:32:12 +02:00
|
|
|
//~^ ERROR: equal expressions as operands to `^`
|
2022-02-10 18:40:06 +01:00
|
|
|
};
|
2015-08-11 20:22:20 +02:00
|
|
|
|
|
|
|
// unary and binary operators
|
2022-02-10 18:40:06 +01:00
|
|
|
let _ = (-(2) < -(2));
|
2023-08-24 21:32:12 +02:00
|
|
|
//~^ ERROR: equal expressions as operands to `<`
|
2022-02-10 18:40:06 +01:00
|
|
|
let _ = ((1 + 1) & (1 + 1) == (1 + 1) & (1 + 1));
|
2023-08-24 21:32:12 +02:00
|
|
|
//~^ ERROR: equal expressions as operands to `==`
|
|
|
|
//~| ERROR: equal expressions as operands to `&`
|
|
|
|
//~| ERROR: equal expressions as operands to `&`
|
2022-02-10 18:40:06 +01:00
|
|
|
let _ = (1 * 2) + (3 * 4) == 1 * 2 + 3 * 4;
|
2023-08-24 21:32:12 +02:00
|
|
|
//~^ ERROR: equal expressions as operands to `==`
|
2015-08-11 20:22:20 +02:00
|
|
|
|
|
|
|
// various other things
|
2022-02-10 18:40:06 +01:00
|
|
|
let _ = ([1] != [1]);
|
2023-08-24 21:32:12 +02:00
|
|
|
//~^ ERROR: equal expressions as operands to `!=`
|
2022-02-10 18:40:06 +01:00
|
|
|
let _ = ((1, 2) != (1, 2));
|
2023-08-24 21:32:12 +02:00
|
|
|
//~^ ERROR: equal expressions as operands to `!=`
|
2022-02-10 18:40:06 +01:00
|
|
|
let _ = vec![1, 2, 3] == vec![1, 2, 3]; //no error yet, as we don't match macros
|
2015-08-21 12:26:03 +02:00
|
|
|
|
|
|
|
// const folding
|
2022-02-10 18:40:06 +01:00
|
|
|
let _ = 1 + 1 == 2;
|
2023-08-24 21:32:12 +02:00
|
|
|
//~^ ERROR: equal expressions as operands to `==`
|
2022-02-10 18:40:06 +01:00
|
|
|
let _ = 1 - 1 == 0;
|
2023-08-24 21:32:12 +02:00
|
|
|
//~^ ERROR: equal expressions as operands to `==`
|
|
|
|
//~| ERROR: equal expressions as operands to `-`
|
2017-02-08 14:58:07 +01:00
|
|
|
|
2022-02-10 18:40:06 +01:00
|
|
|
let _ = 1 - 1;
|
2023-08-24 21:32:12 +02:00
|
|
|
//~^ ERROR: equal expressions as operands to `-`
|
2022-02-10 18:40:06 +01:00
|
|
|
let _ = 1 / 1;
|
2023-08-24 21:32:12 +02:00
|
|
|
//~^ ERROR: equal expressions as operands to `/`
|
2022-02-10 18:40:06 +01:00
|
|
|
let _ = true && true;
|
2023-08-24 21:32:12 +02:00
|
|
|
//~^ ERROR: equal expressions as operands to `&&`
|
2016-02-03 20:42:05 +01:00
|
|
|
|
2022-02-10 18:40:06 +01:00
|
|
|
let _ = true || true;
|
2023-08-24 21:32:12 +02:00
|
|
|
//~^ ERROR: equal expressions as operands to `||`
|
2016-01-30 20:10:14 +01:00
|
|
|
|
2016-11-16 21:57:56 +01:00
|
|
|
let a: u32 = 0;
|
|
|
|
let b: u32 = 0;
|
2016-03-24 16:11:38 +01:00
|
|
|
|
2022-02-10 18:40:06 +01:00
|
|
|
let _ = a == b && b == a;
|
2023-08-24 21:32:12 +02:00
|
|
|
//~^ ERROR: equal expressions as operands to `&&`
|
2022-02-10 18:40:06 +01:00
|
|
|
let _ = a != b && b != a;
|
2023-08-24 21:32:12 +02:00
|
|
|
//~^ ERROR: equal expressions as operands to `&&`
|
2022-02-10 18:40:06 +01:00
|
|
|
let _ = a < b && b > a;
|
2023-08-24 21:32:12 +02:00
|
|
|
//~^ ERROR: equal expressions as operands to `&&`
|
2022-02-10 18:40:06 +01:00
|
|
|
let _ = a <= b && b >= a;
|
2023-08-24 21:32:12 +02:00
|
|
|
//~^ ERROR: equal expressions as operands to `&&`
|
2017-02-08 14:58:07 +01:00
|
|
|
|
2016-01-30 20:10:14 +01:00
|
|
|
let mut a = vec![1];
|
2022-02-10 18:40:06 +01:00
|
|
|
let _ = a == a;
|
2023-08-24 21:32:12 +02:00
|
|
|
//~^ ERROR: equal expressions as operands to `==`
|
2022-02-10 18:40:06 +01:00
|
|
|
let _ = 2 * a.len() == 2 * a.len(); // ok, functions
|
|
|
|
let _ = a.pop() == a.pop(); // ok, functions
|
2017-04-28 17:07:39 +02:00
|
|
|
|
2017-12-22 10:37:44 -08:00
|
|
|
check_ignore_macro();
|
2018-03-23 20:26:52 +02:00
|
|
|
|
|
|
|
// named constants
|
|
|
|
const A: u32 = 10;
|
|
|
|
const B: u32 = 10;
|
|
|
|
const C: u32 = A / B; // ok, different named constants
|
|
|
|
const D: u32 = A / A;
|
2023-08-24 21:32:12 +02:00
|
|
|
//~^ ERROR: equal expressions as operands to `/`
|
2017-12-22 10:37:44 -08:00
|
|
|
}
|
|
|
|
|
|
|
|
macro_rules! check_if_named_foo {
|
2022-02-10 18:40:06 +01:00
|
|
|
($expression:expr) => {
|
2017-12-22 10:37:44 -08:00
|
|
|
if stringify!($expression) == "foo" {
|
|
|
|
println!("foo!");
|
|
|
|
} else {
|
|
|
|
println!("not foo.");
|
|
|
|
}
|
2022-02-10 18:40:06 +01:00
|
|
|
};
|
2017-12-22 10:37:44 -08:00
|
|
|
}
|
|
|
|
|
2020-01-22 16:48:00 +09:00
|
|
|
macro_rules! bool_macro {
|
|
|
|
($expression:expr) => {
|
|
|
|
true
|
|
|
|
};
|
|
|
|
}
|
|
|
|
|
2017-12-22 10:37:44 -08:00
|
|
|
fn check_ignore_macro() {
|
|
|
|
check_if_named_foo!(foo);
|
2020-01-22 16:48:00 +09:00
|
|
|
// checks if the lint ignores macros with `!` operator
|
2022-02-10 18:40:06 +01:00
|
|
|
let _ = !bool_macro!(1) && !bool_macro!("");
|
2015-04-30 11:48:43 +02:00
|
|
|
}
|
2020-12-06 15:01:03 +01:00
|
|
|
|
|
|
|
struct Nested {
|
|
|
|
inner: ((i32,), (i32,), (i32,)),
|
|
|
|
}
|
|
|
|
|
|
|
|
fn check_nested(n1: &Nested, n2: &Nested) -> bool {
|
|
|
|
// `n2.inner.0.0` mistyped as `n1.inner.0.0`
|
|
|
|
(n1.inner.0).0 == (n1.inner.0).0 && (n1.inner.1).0 == (n2.inner.1).0 && (n1.inner.2).0 == (n2.inner.2).0
|
2023-08-24 21:32:12 +02:00
|
|
|
//~^ ERROR: equal expressions as operands to `==`
|
2020-12-06 15:01:03 +01:00
|
|
|
}
|
2022-02-10 18:40:06 +01:00
|
|
|
|
|
|
|
#[test]
|
|
|
|
fn eq_op_shouldnt_trigger_in_tests() {
|
|
|
|
let a = 1;
|
|
|
|
let result = a + 1 == 1 + a;
|
|
|
|
assert!(result);
|
|
|
|
}
|
|
|
|
|
|
|
|
#[test]
|
|
|
|
fn eq_op_macros_shouldnt_trigger_in_tests() {
|
|
|
|
let a = 1;
|
|
|
|
let b = 2;
|
|
|
|
assert_eq!(a, a);
|
|
|
|
assert_eq!(a + b, b + a);
|
|
|
|
}
|