mirror of
https://github.com/rust-lang/rust.git
synced 2025-01-20 19:52:48 +00:00
eb3970285b
In order to switch `clippy::uninlined_format_args` from pedantic to style, all existing tests must not raise a warning. I did not want to change the actual tests, so this is a relatively minor change that: * add `#![allow(clippy::uninlined_format_args)]` where needed * normalizes all allow/deny/warn attributes * all allow attributes are grouped together * sorted alphabetically * the `clippy::*` attributes are listed separate from the other ones. * deny and warn attributes are listed before the allowed ones changelog: none
116 lines
2.2 KiB
Rust
116 lines
2.2 KiB
Rust
#![feature(adt_const_params)]
|
|
#![warn(clippy::same_functions_in_if_condition)]
|
|
// ifs_same_cond warning is different from `ifs_same_cond`.
|
|
// clippy::if_same_then_else, clippy::comparison_chain -- all empty blocks
|
|
#![allow(incomplete_features)]
|
|
#![allow(
|
|
clippy::comparison_chain,
|
|
clippy::if_same_then_else,
|
|
clippy::ifs_same_cond,
|
|
clippy::uninlined_format_args
|
|
)]
|
|
|
|
fn function() -> bool {
|
|
true
|
|
}
|
|
|
|
fn fn_arg(_arg: u8) -> bool {
|
|
true
|
|
}
|
|
|
|
struct Struct;
|
|
|
|
impl Struct {
|
|
fn method(&self) -> bool {
|
|
true
|
|
}
|
|
fn method_arg(&self, _arg: u8) -> bool {
|
|
true
|
|
}
|
|
}
|
|
|
|
fn ifs_same_cond_fn() {
|
|
let a = 0;
|
|
let obj = Struct;
|
|
|
|
if function() {
|
|
} else if function() {
|
|
//~ ERROR ifs same condition
|
|
}
|
|
|
|
if fn_arg(a) {
|
|
} else if fn_arg(a) {
|
|
//~ ERROR ifs same condition
|
|
}
|
|
|
|
if obj.method() {
|
|
} else if obj.method() {
|
|
//~ ERROR ifs same condition
|
|
}
|
|
|
|
if obj.method_arg(a) {
|
|
} else if obj.method_arg(a) {
|
|
//~ ERROR ifs same condition
|
|
}
|
|
|
|
let mut v = vec![1];
|
|
if v.pop().is_none() {
|
|
//~ ERROR ifs same condition
|
|
} else if v.pop().is_none() {
|
|
}
|
|
|
|
if v.len() == 42 {
|
|
//~ ERROR ifs same condition
|
|
} else if v.len() == 42 {
|
|
}
|
|
|
|
if v.len() == 1 {
|
|
// ok, different conditions
|
|
} else if v.len() == 2 {
|
|
}
|
|
|
|
if fn_arg(0) {
|
|
// ok, different arguments.
|
|
} else if fn_arg(1) {
|
|
}
|
|
|
|
if obj.method_arg(0) {
|
|
// ok, different arguments.
|
|
} else if obj.method_arg(1) {
|
|
}
|
|
|
|
if a == 1 {
|
|
// ok, warning is on `ifs_same_cond` behalf.
|
|
} else if a == 1 {
|
|
}
|
|
}
|
|
|
|
fn main() {
|
|
// macro as condition (see #6168)
|
|
let os = if cfg!(target_os = "macos") {
|
|
"macos"
|
|
} else if cfg!(target_os = "windows") {
|
|
"windows"
|
|
} else {
|
|
"linux"
|
|
};
|
|
println!("{}", os);
|
|
|
|
#[derive(PartialEq, Eq)]
|
|
enum E {
|
|
A,
|
|
B,
|
|
}
|
|
fn generic<const P: E>() -> bool {
|
|
match P {
|
|
E::A => true,
|
|
E::B => false,
|
|
}
|
|
}
|
|
if generic::<{ E::A }>() {
|
|
println!("A");
|
|
} else if generic::<{ E::B }>() {
|
|
println!("B");
|
|
}
|
|
}
|