mirror of
https://github.com/rust-lang/rust-clippy
synced 2025-02-17 06:28:42 +00:00
Fix ice
This commit is contained in:
parent
b105fb4c39
commit
68d2082d69
3 changed files with 11 additions and 3 deletions
|
@ -62,7 +62,7 @@ impl<'tcx> LateLintPass<'tcx> for RedundantLocals {
|
|||
if let Res::Local(binding_id) = cx.qpath_res(&qpath, expr.hir_id);
|
||||
if let Node::Pat(binding_pat) = cx.tcx.hir().get(binding_id);
|
||||
// the previous binding has the same mutability
|
||||
if find_binding(binding_pat, ident).unwrap().1 == mutability;
|
||||
if find_binding(binding_pat, ident).is_some_and(|bind| bind.1 == mutability);
|
||||
// the local does not change the effect of assignments to the binding. see #11290
|
||||
if !affects_assignments(cx, mutability, binding_id, local.hir_id);
|
||||
// the local does not affect the code's drop behavior
|
||||
|
|
|
@ -117,6 +117,14 @@ fn macros() {
|
|||
let x = 1;
|
||||
let x = x;
|
||||
}
|
||||
|
||||
let x = 10;
|
||||
macro_rules! rebind_outer_macro {
|
||||
($x:ident) => {
|
||||
let x = x;
|
||||
};
|
||||
}
|
||||
rebind_outer_macro!(y);
|
||||
}
|
||||
|
||||
struct WithDrop(usize);
|
||||
|
|
|
@ -157,13 +157,13 @@ LL | let x = 1;
|
|||
| ^
|
||||
|
||||
error: redundant redefinition of a binding `a`
|
||||
--> $DIR/redundant_locals.rs:144:5
|
||||
--> $DIR/redundant_locals.rs:152:5
|
||||
|
|
||||
LL | let a = a;
|
||||
| ^^^^^^^^^^
|
||||
|
|
||||
help: `a` is initially defined here
|
||||
--> $DIR/redundant_locals.rs:142:9
|
||||
--> $DIR/redundant_locals.rs:150:9
|
||||
|
|
||||
LL | let a = WithoutDrop(1);
|
||||
| ^
|
||||
|
|
Loading…
Add table
Reference in a new issue