@@ -9,28 +9,35 @@ if let StmtKind::Let(local) = stmt.kind
9
9
&& let ExprKind::Call(func, args) = e.kind
10
10
&& paths::STD_IO_STDIO__PRINT.matches_path(cx, func) // Add the path to `clippy_utils::paths` if needed
11
11
&& 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
15
21
&& 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
19
32
&& let LitKind::Str(s, _) = lit.node
20
33
&& s.as_str() == ""
21
- && let ExprKind::Lit(ref lit1) = elements [1].kind
34
+ && let ExprKind::Lit(ref lit1) = elements1 [1].kind
22
35
&& let LitKind::Str(s1, _) = lit1.node
23
36
&& 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
31
38
&& 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"
34
41
{
35
42
// report your lint here
36
43
}
0 commit comments