2020-11-23 13:51:04 +01:00
|
|
|
#![warn(clippy::unnecessary_lazy_evaluations)]
|
2023-07-02 14:35:19 +02:00
|
|
|
#![allow(clippy::unnecessary_literal_unwrap)]
|
2023-08-24 21:32:12 +02:00
|
|
|
//@no-rustfix
|
2020-11-23 13:51:04 +01:00
|
|
|
struct Deep(Option<usize>);
|
|
|
|
|
|
|
|
#[derive(Copy, Clone)]
|
|
|
|
struct SomeStruct {
|
|
|
|
some_field: usize,
|
|
|
|
}
|
|
|
|
|
|
|
|
fn main() {
|
|
|
|
// fix will break type inference
|
|
|
|
let _ = Ok(1).unwrap_or_else(|()| 2);
|
2023-08-24 21:32:12 +02:00
|
|
|
//~^ ERROR: unnecessary closure used to substitute value for `Result::Err`
|
|
|
|
//~| NOTE: `-D clippy::unnecessary-lazy-evaluations` implied by `-D warnings`
|
2020-11-23 13:51:04 +01:00
|
|
|
mod e {
|
|
|
|
pub struct E;
|
|
|
|
}
|
|
|
|
let _ = Ok(1).unwrap_or_else(|e::E| 2);
|
2023-08-24 21:32:12 +02:00
|
|
|
//~^ ERROR: unnecessary closure used to substitute value for `Result::Err`
|
2020-11-23 13:51:04 +01:00
|
|
|
let _ = Ok(1).unwrap_or_else(|SomeStruct { .. }| 2);
|
2023-08-24 21:32:12 +02:00
|
|
|
//~^ ERROR: unnecessary closure used to substitute value for `Result::Err`
|
2020-12-20 17:19:49 +01:00
|
|
|
|
|
|
|
// Fix #6343
|
|
|
|
let arr = [(Some(1),)];
|
|
|
|
Some(&0).and_then(|&i| arr[i].0);
|
2020-11-23 13:51:04 +01:00
|
|
|
}
|
2023-10-21 14:16:11 +02:00
|
|
|
|
|
|
|
fn issue11672() {
|
|
|
|
// Return type annotation helps type inference and removing it can break code
|
|
|
|
let _ = true.then(|| -> &[u8] { &[] });
|
|
|
|
}
|