mirror of
https://github.com/rust-lang/rust.git
synced 2025-01-26 22:53:28 +00:00
17c1ff9faa
fix clippy format using `cargo fmt -p clippy_{lints,utils}` manually revert rustfmt line truncations rename to hir::Let in clippy Undo the shadowing of various `expr` variables after renaming `scrutinee` reduce destructuring of hir::Let to avoid `expr` collisions cargo fmt -p clippy_{lints,utils} bless new clippy::author output
51 lines
2.0 KiB
Plaintext
51 lines
2.0 KiB
Plaintext
if_chain! {
|
|
if let StmtKind::Local(local) = stmt.kind;
|
|
if let Some(init) = local.init;
|
|
if let ExprKind::If(cond, then, Some(else_expr)) = init.kind;
|
|
if let ExprKind::DropTemps(expr) = cond.kind;
|
|
if let ExprKind::Lit(ref lit) = expr.kind;
|
|
if let LitKind::Bool(true) = lit.node;
|
|
if let ExprKind::Block(block, None) = then.kind;
|
|
if block.stmts.len() == 1;
|
|
if let StmtKind::Semi(e) = block.stmts[0].kind;
|
|
if let ExprKind::Binary(op, left, right) = e.kind;
|
|
if BinOpKind::Eq == op.node;
|
|
if let ExprKind::Lit(ref lit1) = left.kind;
|
|
if let LitKind::Int(1, LitIntType::Unsuffixed) = lit1.node;
|
|
if let ExprKind::Lit(ref lit2) = right.kind;
|
|
if let LitKind::Int(1, LitIntType::Unsuffixed) = lit2.node;
|
|
if block.expr.is_none();
|
|
if let ExprKind::Block(block1, None) = else_expr.kind;
|
|
if block1.stmts.len() == 1;
|
|
if let StmtKind::Semi(e1) = block1.stmts[0].kind;
|
|
if let ExprKind::Binary(op1, left1, right1) = e1.kind;
|
|
if BinOpKind::Eq == op1.node;
|
|
if let ExprKind::Lit(ref lit3) = left1.kind;
|
|
if let LitKind::Int(2, LitIntType::Unsuffixed) = lit3.node;
|
|
if let ExprKind::Lit(ref lit4) = right1.kind;
|
|
if let LitKind::Int(2, LitIntType::Unsuffixed) = lit4.node;
|
|
if block1.expr.is_none();
|
|
if let PatKind::Wild = local.pat.kind;
|
|
then {
|
|
// report your lint here
|
|
}
|
|
}
|
|
if_chain! {
|
|
if let ExprKind::If(cond, then, Some(else_expr)) = expr.kind;
|
|
if let ExprKind::Let(let_expr) = cond.kind;
|
|
if let PatKind::Lit(lit_expr) = let_expr.pat.kind;
|
|
if let ExprKind::Lit(ref lit) = lit_expr.kind;
|
|
if let LitKind::Bool(true) = lit.node;
|
|
if let ExprKind::Path(ref qpath) = let_expr.init.kind;
|
|
if match_qpath(qpath, &["a"]);
|
|
if let ExprKind::Block(block, None) = then.kind;
|
|
if block.stmts.is_empty();
|
|
if block.expr.is_none();
|
|
if let ExprKind::Block(block1, None) = else_expr.kind;
|
|
if block1.stmts.is_empty();
|
|
if block1.expr.is_none();
|
|
then {
|
|
// report your lint here
|
|
}
|
|
}
|