2024-03-10 01:12:15 +01:00
|
|
|
#![warn(clippy::manual_unwrap_or_default)]
|
2024-06-08 14:34:59 +01:00
|
|
|
#![allow(clippy::unnecessary_literal_unwrap, clippy::manual_unwrap_or)]
|
2024-03-08 22:04:31 +01:00
|
|
|
|
|
|
|
fn main() {
|
|
|
|
let x: Option<Vec<String>> = None;
|
|
|
|
match x {
|
|
|
|
//~^ ERROR: match can be simplified with `.unwrap_or_default()`
|
|
|
|
Some(v) => v,
|
|
|
|
None => Vec::default(),
|
|
|
|
};
|
|
|
|
|
|
|
|
let x: Option<Vec<String>> = None;
|
|
|
|
match x {
|
|
|
|
//~^ ERROR: match can be simplified with `.unwrap_or_default()`
|
|
|
|
Some(v) => v,
|
|
|
|
_ => Vec::default(),
|
|
|
|
};
|
|
|
|
|
|
|
|
let x: Option<String> = None;
|
|
|
|
match x {
|
|
|
|
//~^ ERROR: match can be simplified with `.unwrap_or_default()`
|
|
|
|
Some(v) => v,
|
|
|
|
None => String::new(),
|
|
|
|
};
|
|
|
|
|
|
|
|
let x: Option<Vec<String>> = None;
|
|
|
|
match x {
|
|
|
|
//~^ ERROR: match can be simplified with `.unwrap_or_default()`
|
|
|
|
None => Vec::default(),
|
|
|
|
Some(v) => v,
|
|
|
|
};
|
|
|
|
|
|
|
|
let x: Option<Vec<String>> = None;
|
|
|
|
if let Some(v) = x {
|
|
|
|
//~^ ERROR: if let can be simplified with `.unwrap_or_default()`
|
|
|
|
v
|
|
|
|
} else {
|
|
|
|
Vec::default()
|
|
|
|
};
|
2024-04-01 20:18:03 +05:30
|
|
|
|
|
|
|
// Issue #12564
|
|
|
|
// No error as &Vec<_> doesn't implement std::default::Default
|
|
|
|
let mut map = std::collections::HashMap::from([(0, vec![0; 3]), (1, vec![1; 3]), (2, vec![2])]);
|
|
|
|
let x: &[_] = if let Some(x) = map.get(&0) { x } else { &[] };
|
|
|
|
// Same code as above written using match.
|
|
|
|
let x: &[_] = match map.get(&0) {
|
|
|
|
Some(x) => x,
|
|
|
|
None => &[],
|
|
|
|
};
|
2024-06-06 21:33:37 +01:00
|
|
|
|
|
|
|
let x: Result<String, i64> = Ok(String::new());
|
|
|
|
match x {
|
|
|
|
//~^ ERROR: match can be simplified with `.unwrap_or_default()`
|
|
|
|
Ok(v) => v,
|
|
|
|
Err(_) => String::new(),
|
|
|
|
};
|
|
|
|
|
|
|
|
let x: Result<String, i64> = Ok(String::new());
|
|
|
|
if let Ok(v) = x {
|
|
|
|
//~^ ERROR: if let can be simplified with `.unwrap_or_default()`
|
|
|
|
v
|
|
|
|
} else {
|
|
|
|
String::new()
|
|
|
|
};
|
2024-03-08 22:04:31 +01:00
|
|
|
}
|
2024-03-22 12:21:35 +01:00
|
|
|
|
|
|
|
// Issue #12531
|
|
|
|
unsafe fn no_deref_ptr(a: Option<i32>, b: *const Option<i32>) -> i32 {
|
|
|
|
match a {
|
|
|
|
// `*b` being correct depends on `a == Some(_)`
|
|
|
|
Some(_) => match *b {
|
|
|
|
Some(v) => v,
|
|
|
|
_ => 0,
|
|
|
|
},
|
|
|
|
_ => 0,
|
|
|
|
}
|
|
|
|
}
|
2024-03-27 16:28:15 +08:00
|
|
|
|
|
|
|
const fn issue_12568(opt: Option<bool>) -> bool {
|
|
|
|
match opt {
|
|
|
|
Some(s) => s,
|
|
|
|
None => false,
|
|
|
|
}
|
|
|
|
}
|
2024-03-30 09:18:53 +08:00
|
|
|
|
|
|
|
fn issue_12569() {
|
|
|
|
let match_none_se = match 1u32.checked_div(0) {
|
|
|
|
Some(v) => v,
|
|
|
|
None => {
|
|
|
|
println!("important");
|
|
|
|
0
|
|
|
|
},
|
|
|
|
};
|
|
|
|
let match_some_se = match 1u32.checked_div(0) {
|
|
|
|
Some(v) => {
|
|
|
|
println!("important");
|
|
|
|
v
|
|
|
|
},
|
|
|
|
None => 0,
|
|
|
|
};
|
|
|
|
let iflet_else_se = if let Some(v) = 1u32.checked_div(0) {
|
|
|
|
v
|
|
|
|
} else {
|
|
|
|
println!("important");
|
|
|
|
0
|
|
|
|
};
|
|
|
|
let iflet_then_se = if let Some(v) = 1u32.checked_div(0) {
|
|
|
|
println!("important");
|
|
|
|
v
|
|
|
|
} else {
|
|
|
|
0
|
|
|
|
};
|
|
|
|
}
|
2024-06-19 17:26:52 +02:00
|
|
|
|
|
|
|
// Should not warn!
|
|
|
|
fn issue_12928() {
|
|
|
|
let x = Some((1, 2));
|
|
|
|
let y = if let Some((a, _)) = x { a } else { 0 };
|
|
|
|
let y = if let Some((a, ..)) = x { a } else { 0 };
|
|
|
|
let x = Some([1, 2]);
|
|
|
|
let y = if let Some([a, _]) = x { a } else { 0 };
|
|
|
|
let y = if let Some([a, ..]) = x { a } else { 0 };
|
|
|
|
|
|
|
|
struct X {
|
|
|
|
a: u8,
|
|
|
|
b: u8,
|
|
|
|
}
|
|
|
|
let x = Some(X { a: 0, b: 0 });
|
|
|
|
let y = if let Some(X { a, .. }) = x { a } else { 0 };
|
|
|
|
struct Y(u8, u8);
|
|
|
|
let x = Some(Y(0, 0));
|
|
|
|
let y = if let Some(Y(a, _)) = x { a } else { 0 };
|
|
|
|
let y = if let Some(Y(a, ..)) = x { a } else { 0 };
|
|
|
|
}
|