2018-07-28 17:34:52 +02:00
|
|
|
#![feature(tool_lints)]
|
|
|
|
|
|
|
|
#![deny(clippy::panicking_unwrap, clippy::unnecessary_unwrap)]
|
|
|
|
#![allow(clippy::if_same_then_else)]
|
2018-06-08 05:55:11 +02:00
|
|
|
|
2018-05-28 00:02:38 +02:00
|
|
|
fn main() {
|
|
|
|
let x = Some(());
|
|
|
|
if x.is_some() {
|
2018-06-08 18:12:01 +02:00
|
|
|
x.unwrap(); // unnecessary
|
|
|
|
} else {
|
|
|
|
x.unwrap(); // will panic
|
2018-05-28 00:02:38 +02:00
|
|
|
}
|
|
|
|
if x.is_none() {
|
2018-06-08 18:12:01 +02:00
|
|
|
x.unwrap(); // will panic
|
2018-05-28 00:02:38 +02:00
|
|
|
} else {
|
2018-06-08 18:12:01 +02:00
|
|
|
x.unwrap(); // unnecessary
|
2018-05-28 00:02:38 +02:00
|
|
|
}
|
|
|
|
let mut x: Result<(), ()> = Ok(());
|
|
|
|
if x.is_ok() {
|
2018-06-08 18:12:01 +02:00
|
|
|
x.unwrap(); // unnecessary
|
|
|
|
x.unwrap_err(); // will panic
|
2018-05-28 00:02:38 +02:00
|
|
|
} else {
|
2018-06-08 18:12:01 +02:00
|
|
|
x.unwrap(); // will panic
|
|
|
|
x.unwrap_err(); // unnecessary
|
2018-05-28 00:02:38 +02:00
|
|
|
}
|
|
|
|
if x.is_err() {
|
2018-06-08 18:12:01 +02:00
|
|
|
x.unwrap(); // will panic
|
|
|
|
x.unwrap_err(); // unnecessary
|
2018-05-28 00:02:38 +02:00
|
|
|
} else {
|
2018-06-08 18:12:01 +02:00
|
|
|
x.unwrap(); // unnecessary
|
|
|
|
x.unwrap_err(); // will panic
|
2018-05-28 00:02:38 +02:00
|
|
|
}
|
|
|
|
if x.is_ok() {
|
|
|
|
x = Err(());
|
2018-06-08 18:12:01 +02:00
|
|
|
x.unwrap(); // not unnecessary because of mutation of x
|
2018-07-25 20:02:52 +02:00
|
|
|
// it will always panic but the lint is not smart enough to see this (it only checks if conditions).
|
2018-05-28 00:02:38 +02:00
|
|
|
} else {
|
|
|
|
x = Ok(());
|
2018-06-08 18:12:01 +02:00
|
|
|
x.unwrap_err(); // not unnecessary because of mutation of x
|
2018-07-25 20:02:52 +02:00
|
|
|
// it will always panic but the lint is not smart enough to see this (it only checks if conditions).
|
2018-05-28 00:02:38 +02:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
fn test_complex_conditions() {
|
|
|
|
let x: Result<(), ()> = Ok(());
|
|
|
|
let y: Result<(), ()> = Ok(());
|
|
|
|
if x.is_ok() && y.is_err() {
|
2018-06-08 18:12:01 +02:00
|
|
|
x.unwrap(); // unnecessary
|
|
|
|
x.unwrap_err(); // will panic
|
|
|
|
y.unwrap(); // will panic
|
|
|
|
y.unwrap_err(); // unnecessary
|
2018-05-28 00:02:38 +02:00
|
|
|
} else {
|
2018-06-08 18:12:01 +02:00
|
|
|
// not statically determinable whether any of the following will always succeed or always fail:
|
|
|
|
x.unwrap();
|
2018-05-28 00:02:38 +02:00
|
|
|
x.unwrap_err();
|
|
|
|
y.unwrap();
|
2018-06-08 18:12:01 +02:00
|
|
|
y.unwrap_err();
|
2018-05-28 00:02:38 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
if x.is_ok() || y.is_ok() {
|
2018-06-08 18:12:01 +02:00
|
|
|
// not statically determinable whether any of the following will always succeed or always fail:
|
2018-05-28 00:02:38 +02:00
|
|
|
x.unwrap();
|
|
|
|
y.unwrap();
|
|
|
|
} else {
|
2018-06-08 18:12:01 +02:00
|
|
|
x.unwrap(); // will panic
|
|
|
|
x.unwrap_err(); // unnecessary
|
|
|
|
y.unwrap(); // will panic
|
|
|
|
y.unwrap_err(); // unnecessary
|
2018-05-28 00:02:38 +02:00
|
|
|
}
|
|
|
|
let z: Result<(), ()> = Ok(());
|
|
|
|
if x.is_ok() && !(y.is_ok() || z.is_err()) {
|
2018-06-08 18:12:01 +02:00
|
|
|
x.unwrap(); // unnecessary
|
|
|
|
x.unwrap_err(); // will panic
|
|
|
|
y.unwrap(); // will panic
|
|
|
|
y.unwrap_err(); // unnecessary
|
|
|
|
z.unwrap(); // unnecessary
|
|
|
|
z.unwrap_err(); // will panic
|
2018-05-28 00:02:38 +02:00
|
|
|
}
|
|
|
|
if x.is_ok() || !(y.is_ok() && z.is_err()) {
|
2018-06-08 18:12:01 +02:00
|
|
|
// not statically determinable whether any of the following will always succeed or always fail:
|
|
|
|
x.unwrap();
|
2018-05-28 00:02:38 +02:00
|
|
|
y.unwrap();
|
2018-06-08 18:12:01 +02:00
|
|
|
z.unwrap();
|
|
|
|
} else {
|
|
|
|
x.unwrap(); // will panic
|
|
|
|
x.unwrap_err(); // unnecessary
|
|
|
|
y.unwrap(); // unnecessary
|
|
|
|
y.unwrap_err(); // will panic
|
|
|
|
z.unwrap(); // will panic
|
|
|
|
z.unwrap_err(); // unnecessary
|
2018-05-28 00:02:38 +02:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
fn test_nested() {
|
|
|
|
fn nested() {
|
|
|
|
let x = Some(());
|
|
|
|
if x.is_some() {
|
2018-06-08 18:12:01 +02:00
|
|
|
x.unwrap(); // unnecessary
|
|
|
|
} else {
|
|
|
|
x.unwrap(); // will panic
|
2018-05-28 00:02:38 +02:00
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|