2020-07-26 14:07:07 -05:00
|
|
|
// non rustfixable, see redundant_closure_call_fixable.rs
|
|
|
|
|
|
|
|
#![warn(clippy::redundant_closure_call)]
|
2021-12-06 05:33:31 -06:00
|
|
|
#![allow(clippy::needless_late_init)]
|
2020-07-26 14:07:07 -05:00
|
|
|
|
|
|
|
fn main() {
|
|
|
|
let mut i = 1;
|
|
|
|
|
|
|
|
// don't lint here, the closure is used more than once
|
|
|
|
let closure = |i| i + 1;
|
|
|
|
i = closure(3);
|
|
|
|
i = closure(4);
|
|
|
|
|
|
|
|
// lint here
|
|
|
|
let redun_closure = || 1;
|
|
|
|
i = redun_closure();
|
2023-08-24 14:32:12 -05:00
|
|
|
//~^ ERROR: closure called just once immediately after it was declared
|
|
|
|
//~| NOTE: `-D clippy::redundant-closure-call` implied by `-D warnings`
|
2020-07-26 14:07:07 -05:00
|
|
|
|
|
|
|
// shadowed closures are supported, lint here
|
|
|
|
let shadowed_closure = || 1;
|
|
|
|
i = shadowed_closure();
|
2023-08-24 14:32:12 -05:00
|
|
|
//~^ ERROR: closure called just once immediately after it was declared
|
2020-07-26 14:07:07 -05:00
|
|
|
let shadowed_closure = || 2;
|
|
|
|
i = shadowed_closure();
|
2023-08-24 14:32:12 -05:00
|
|
|
//~^ ERROR: closure called just once immediately after it was declared
|
2020-07-26 14:07:07 -05:00
|
|
|
|
|
|
|
// don't lint here
|
|
|
|
let shadowed_closure = || 2;
|
|
|
|
i = shadowed_closure();
|
|
|
|
i = shadowed_closure();
|
2020-08-28 09:10:16 -05:00
|
|
|
|
|
|
|
// Fix FP in #5916
|
|
|
|
let mut x;
|
|
|
|
let create = || 2 * 2;
|
|
|
|
x = create();
|
|
|
|
fun(move || {
|
|
|
|
x = create();
|
|
|
|
})
|
|
|
|
}
|
|
|
|
|
|
|
|
fn fun<T: 'static + FnMut()>(mut f: T) {
|
|
|
|
f();
|
2020-07-26 14:07:07 -05:00
|
|
|
}
|