@@ -9,28 +9,35 @@ if let StmtKind::Let(local) = stmt.kind
99 && let ExprKind::Call(func, args) = e.kind
1010 && paths::STD_IO_STDIO__PRINT.matches_path(cx, func) // Add the path to `clippy_utils::paths` if needed
1111 && args.len() == 1
12- && let ExprKind::Call(func1, args1) = args[0].kind
13- && paths::CORE_FMT_RT_NEW_V1.matches_path(cx, func1) // Add the path to `clippy_utils::paths` if needed
14- && args1.len() == 2
12+ && let ExprKind::Block(block1, None) = args[0].kind
13+ && block1.stmts.len() == 1
14+ && let StmtKind::Let(local1) = block1.stmts[0].kind
15+ && let Some(init1) = local1.init
16+ && let ExprKind::Array(elements) = init1.kind
17+ && elements.len() == 1
18+ && let ExprKind::Call(func1, args1) = elements[0].kind
19+ && paths::CORE_FMT_RT_ARGUMENT_NEW_DISPLAY.matches_path(cx, func1) // Add the path to `clippy_utils::paths` if needed
20+ && args1.len() == 1
1521 && let ExprKind::AddrOf(BorrowKind::Ref, Mutability::Not, inner) = args1[0].kind
16- && let ExprKind::Array(elements) = inner.kind
17- && elements.len() == 2
18- && let ExprKind::Lit(ref lit) = elements[0].kind
22+ && let PatKind::Binding(BindingMode::NONE, _, name, None) = local1.pat.kind
23+ && name.as_str() == "args"
24+ && let Some(trailing_expr) = block1.expr
25+ && let ExprKind::Call(func2, args2) = trailing_expr.kind
26+ && paths::CORE_FMT_RT_NEW_V1.matches_path(cx, func2) // Add the path to `clippy_utils::paths` if needed
27+ && args2.len() == 2
28+ && let ExprKind::AddrOf(BorrowKind::Ref, Mutability::Not, inner1) = args2[0].kind
29+ && let ExprKind::Array(elements1) = inner1.kind
30+ && elements1.len() == 2
31+ && let ExprKind::Lit(ref lit) = elements1[0].kind
1932 && let LitKind::Str(s, _) = lit.node
2033 && s.as_str() == ""
21- && let ExprKind::Lit(ref lit1) = elements [1].kind
34+ && let ExprKind::Lit(ref lit1) = elements1 [1].kind
2235 && let LitKind::Str(s1, _) = lit1.node
2336 && s1.as_str() == "\n"
24- && let ExprKind::AddrOf(BorrowKind::Ref, Mutability::Not, inner1) = args1[1].kind
25- && let ExprKind::Array(elements1) = inner1.kind
26- && elements1.len() == 1
27- && let ExprKind::Call(func2, args2) = elements1[0].kind
28- && paths::CORE_FMT_RT_ARGUMENT_NEW_DISPLAY.matches_path(cx, func2) // Add the path to `clippy_utils::paths` if needed
29- && args2.len() == 1
30- && let ExprKind::AddrOf(BorrowKind::Ref, Mutability::Not, inner2) = args2[0].kind
37+ && let ExprKind::AddrOf(BorrowKind::Ref, Mutability::Not, inner2) = args2[1].kind
3138 && block.expr.is_none()
32- && let PatKind::Binding(BindingMode::NONE, _, name , None) = local.pat.kind
33- && name .as_str() == "print_text"
39+ && let PatKind::Binding(BindingMode::NONE, _, name1 , None) = local.pat.kind
40+ && name1 .as_str() == "print_text"
3441{
3542 // report your lint here
3643}
0 commit comments