rust/tests/ui/manual_map_option.rs

223 lines
4.1 KiB
Rust
Raw Normal View History

// edition:2018
2021-01-10 14:46:03 +00:00
// run-rustfix
#![warn(clippy::manual_map)]
#![allow(
clippy::no_effect,
clippy::map_identity,
clippy::unit_arg,
clippy::match_ref_pats,
clippy::redundant_pattern_matching,
dead_code
)]
2021-01-10 14:46:03 +00:00
fn main() {
match Some(0) {
Some(_) => Some(2),
None::<u32> => None,
};
match Some(0) {
Some(x) => Some(x + 1),
_ => None,
};
match Some("") {
Some(x) => Some(x.is_empty()),
None => None,
};
if let Some(x) = Some(0) {
Some(!x)
} else {
None
};
#[rustfmt::skip]
match Some(0) {
Some(x) => { Some(std::convert::identity(x)) }
None => { None }
};
match Some(&String::new()) {
Some(x) => Some(str::len(x)),
None => None,
};
match Some(0) {
Some(x) if false => Some(x + 1),
_ => None,
};
match &Some([0, 1]) {
Some(x) => Some(x[0]),
&None => None,
};
match &Some(0) {
&Some(x) => Some(x * 2),
None => None,
};
match Some(String::new()) {
Some(ref x) => Some(x.is_empty()),
_ => None,
};
match &&Some(String::new()) {
Some(x) => Some(x.len()),
_ => None,
};
match &&Some(0) {
&&Some(x) => Some(x + x),
&&_ => None,
};
2021-02-19 19:04:37 +00:00
#[warn(clippy::option_map_unit_fn)]
2021-01-10 14:46:03 +00:00
match &mut Some(String::new()) {
Some(x) => Some(x.push_str("")),
None => None,
};
2021-02-19 19:04:37 +00:00
#[allow(clippy::option_map_unit_fn)]
{
match &mut Some(String::new()) {
Some(x) => Some(x.push_str("")),
None => None,
};
}
2021-01-10 14:46:03 +00:00
match &mut Some(String::new()) {
2021-02-19 19:04:37 +00:00
Some(ref x) => Some(x.len()),
2021-01-10 14:46:03 +00:00
None => None,
};
match &mut &Some(String::new()) {
Some(x) => Some(x.is_empty()),
&mut _ => None,
};
match Some((0, 1, 2)) {
Some((x, y, z)) => Some(x + y + z),
None => None,
};
match Some([1, 2, 3]) {
Some([first, ..]) => Some(first),
None => None,
};
match &Some((String::new(), "test")) {
Some((x, y)) => Some((y, x)),
None => None,
};
match Some((String::new(), 0)) {
Some((ref x, y)) => Some((y, x)),
None => None,
};
match Some(Some(0)) {
Some(Some(_)) | Some(None) => Some(0),
None => None,
};
match Some(Some((0, 1))) {
Some(Some((x, 1))) => Some(x),
_ => None,
};
// #6795
fn f1() -> Result<(), ()> {
let _ = match Some(Ok(())) {
Some(x) => Some(x?),
None => None,
};
Ok(())
}
for &x in Some(Some(true)).iter() {
let _ = match x {
Some(x) => Some(if x { continue } else { x }),
None => None,
};
}
// #6797
let x1 = (Some(String::new()), 0);
let x2 = x1.0;
match x2 {
Some(x) => Some((x, x1.1)),
None => None,
};
struct S1 {
x: Option<String>,
y: u32,
}
impl S1 {
fn f(self) -> Option<(String, u32)> {
match self.x {
Some(x) => Some((x, self.y)),
None => None,
}
}
}
// #6811
match Some(0) {
Some(x) => Some(vec![x]),
None => None,
};
match option_env!("") {
Some(x) => Some(String::from(x)),
None => None,
};
// #6819
async fn f2(x: u32) -> u32 {
x
}
async fn f3() {
match Some(0) {
Some(x) => Some(f2(x).await),
None => None,
};
}
// #6847
if let Some(_) = Some(0) {
Some(0)
} else if let Some(x) = Some(0) {
Some(x + 1)
} else {
None
};
if true {
Some(0)
} else if let Some(x) = Some(0) {
Some(x + 1)
} else {
None
};
// #6967
const fn f4() {
match Some(0) {
Some(x) => Some(x + 1),
None => None,
};
}
// #7077
let s = &String::new();
let _: Option<&str> = match Some(s) {
Some(s) => Some(s),
None => None,
};
2021-01-10 14:46:03 +00:00
}