2019-09-25 11:30:27 -05:00
|
|
|
// non rustfixable, see redundant_closure_call_fixable.rs
|
|
|
|
|
2018-07-28 10:34:52 -05:00
|
|
|
#![warn(clippy::redundant_closure_call)]
|
2021-11-18 07:54:49 -06:00
|
|
|
#![allow(clippy::needless_late_init)]
|
2016-03-03 13:14:49 -06:00
|
|
|
|
|
|
|
fn main() {
|
2018-12-09 16:26:16 -06:00
|
|
|
let mut i = 1;
|
2016-03-03 13:14:49 -06:00
|
|
|
|
2020-07-14 13:27:25 -05:00
|
|
|
// don't lint here, the closure is used more than once
|
2018-12-09 16:26:16 -06:00
|
|
|
let closure = |i| i + 1;
|
|
|
|
i = closure(3);
|
|
|
|
i = closure(4);
|
2018-11-14 00:01:39 -06:00
|
|
|
|
2020-07-14 13:27:25 -05:00
|
|
|
// lint here
|
|
|
|
let redun_closure = || 1;
|
|
|
|
i = redun_closure();
|
2023-07-28 14:35:48 -05:00
|
|
|
//~^ ERROR: closure called just once immediately after it was declared
|
|
|
|
//~| NOTE: `-D clippy::redundant-closure-call` implied by `-D warnings`
|
2020-07-14 13:27:25 -05:00
|
|
|
|
2020-07-19 04:47:32 -05:00
|
|
|
// shadowed closures are supported, lint here
|
|
|
|
let shadowed_closure = || 1;
|
|
|
|
i = shadowed_closure();
|
2023-07-28 14:35:48 -05:00
|
|
|
//~^ ERROR: closure called just once immediately after it was declared
|
2020-07-19 04:47:32 -05:00
|
|
|
let shadowed_closure = || 2;
|
|
|
|
i = shadowed_closure();
|
2023-07-28 14:35:48 -05:00
|
|
|
//~^ ERROR: closure called just once immediately after it was declared
|
2020-07-19 04:47:32 -05:00
|
|
|
|
|
|
|
// don't lint here
|
|
|
|
let shadowed_closure = || 2;
|
|
|
|
i = shadowed_closure();
|
|
|
|
i = shadowed_closure();
|
2020-08-18 09:00:21 -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();
|
2016-03-03 13:14:49 -06:00
|
|
|
}
|