]> git.lizzy.rs Git - rust.git/blob - src/tools/clippy/tests/ui/option_map_unit_fn_unfixable.rs
Rollup merge of #103178 - ferrocene:pa-coverage-reports-tests, r=Mark-Simulacrum
[rust.git] / src / tools / clippy / tests / ui / option_map_unit_fn_unfixable.rs
1 #![warn(clippy::option_map_unit_fn)]
2 #![allow(unused)]
3
4 fn do_nothing<T>(_: T) {}
5
6 fn diverge<T>(_: T) -> ! {
7     panic!()
8 }
9
10 fn plus_one(value: usize) -> usize {
11     value + 1
12 }
13
14 #[rustfmt::skip]
15 fn option_map_unit_fn() {
16
17     x.field.map(|value| { do_nothing(value); do_nothing(value) });
18
19     x.field.map(|value| if value > 0 { do_nothing(value); do_nothing(value) });
20
21     // Suggestion for the let block should be `{ ... }` as it's too difficult to build a
22     // proper suggestion for these cases
23     x.field.map(|value| {
24         do_nothing(value);
25         do_nothing(value)
26     });
27     x.field.map(|value| { do_nothing(value); do_nothing(value); });
28
29     // The following should suggest `if let Some(_X) ...` as it's difficult to generate a proper let variable name for them
30     Some(42).map(diverge);
31     "12".parse::<i32>().ok().map(diverge);
32     Some(plus_one(1)).map(do_nothing);
33
34     // Should suggest `if let Some(_y) ...` to not override the existing foo variable
35     let y = Some(42);
36     y.map(do_nothing);
37 }
38
39 fn main() {}