Skip to content

Commit

Permalink
run-rustfix
Browse files Browse the repository at this point in the history
  • Loading branch information
sinkuu committed Mar 4, 2020
1 parent 45f61ea commit 246709f
Show file tree
Hide file tree
Showing 4 changed files with 136 additions and 18 deletions.
5 changes: 3 additions & 2 deletions clippy_lints/src/question_mark.rs
Expand Up @@ -57,7 +57,8 @@ impl QuestionMark {
if Self::is_option(cx, subject);

then {
let receiver_str = &Sugg::hir(cx, subject, "..");
let mut applicability = Applicability::MachineApplicable;
let receiver_str = snippet_with_applicability(cx, subject.span, "..", &mut applicability);
let mut replacement: Option<String> = None;
if let Some(else_) = else_ {
if_chain! {
Expand Down Expand Up @@ -86,7 +87,7 @@ impl QuestionMark {
expr.span,
"replace it with",
replacement_str,
Applicability::MaybeIncorrect, // snippet
applicability,
);
}
)
Expand Down
113 changes: 113 additions & 0 deletions tests/ui/question_mark.fixed
@@ -0,0 +1,113 @@
// run-rustfix
#![allow(unreachable_code)]

fn some_func(a: Option<u32>) -> Option<u32> {
a?;

a
}

fn some_other_func(a: Option<u32>) -> Option<u32> {
if a.is_none() {
return None;
} else {
return Some(0);
}
unreachable!()
}

pub enum SeemsOption<T> {
Some(T),
None,
}

impl<T> SeemsOption<T> {
pub fn is_none(&self) -> bool {
match *self {
SeemsOption::None => true,
SeemsOption::Some(_) => false,
}
}
}

fn returns_something_similar_to_option(a: SeemsOption<u32>) -> SeemsOption<u32> {
if a.is_none() {
return SeemsOption::None;
}

a
}

pub struct CopyStruct {
pub opt: Option<u32>,
}

impl CopyStruct {
#[rustfmt::skip]
pub fn func(&self) -> Option<u32> {
(self.opt)?;

self.opt?;

let _ = Some(self.opt?);

let _ = self.opt?;

self.opt
}
}

#[derive(Clone)]
pub struct MoveStruct {
pub opt: Option<Vec<u32>>,
}

impl MoveStruct {
pub fn ref_func(&self) -> Option<Vec<u32>> {
self.opt.as_ref()?;

self.opt.clone()
}

pub fn mov_func_reuse(self) -> Option<Vec<u32>> {
self.opt.as_ref()?;

self.opt
}

pub fn mov_func_no_use(self) -> Option<Vec<u32>> {
self.opt.as_ref()?;
Some(Vec::new())
}

pub fn if_let_ref_func(self) -> Option<Vec<u32>> {
let v: &Vec<_> = self.opt.as_ref()?;

Some(v.clone())
}

pub fn if_let_mov_func(self) -> Option<Vec<u32>> {
let v = self.opt?;

Some(v)
}
}

fn main() {
some_func(Some(42));
some_func(None);
some_other_func(Some(42));

let copy_struct = CopyStruct { opt: Some(54) };
copy_struct.func();

let move_struct = MoveStruct {
opt: Some(vec![42, 1337]),
};
move_struct.ref_func();
move_struct.clone().mov_func_reuse();
move_struct.mov_func_no_use();

let so = SeemsOption::Some(45);
returns_something_similar_to_option(so);
}
8 changes: 6 additions & 2 deletions tests/ui/question_mark.rs
@@ -1,3 +1,6 @@
// run-rustfix
#![allow(unreachable_code)]

fn some_func(a: Option<u32>) -> Option<u32> {
if a.is_none() {
return None;
Expand Down Expand Up @@ -98,7 +101,7 @@ impl MoveStruct {
}

pub fn if_let_ref_func(self) -> Option<Vec<u32>> {
let mut v: &Vec<_> = if let Some(ref v) = self.opt {
let v: &Vec<_> = if let Some(ref v) = self.opt {
v
} else {
return None;
Expand All @@ -108,7 +111,7 @@ impl MoveStruct {
}

pub fn if_let_mov_func(self) -> Option<Vec<u32>> {
let mut v = if let Some(v) = self.opt {
let v = if let Some(v) = self.opt {
v
} else {
return None;
Expand All @@ -121,6 +124,7 @@ impl MoveStruct {
fn main() {
some_func(Some(42));
some_func(None);
some_other_func(Some(42));

let copy_struct = CopyStruct { opt: Some(54) };
copy_struct.func();
Expand Down
28 changes: 14 additions & 14 deletions tests/ui/question_mark.stderr
@@ -1,5 +1,5 @@
error: this block may be rewritten with the `?` operator
--> $DIR/question_mark.rs:2:5
--> $DIR/question_mark.rs:5:5
|
LL | / if a.is_none() {
LL | | return None;
Expand All @@ -9,23 +9,23 @@ LL | | }
= note: `-D clippy::question-mark` implied by `-D warnings`

error: this block may be rewritten with the `?` operator
--> $DIR/question_mark.rs:47:9
--> $DIR/question_mark.rs:50:9
|
LL | / if (self.opt).is_none() {
LL | | return None;
LL | | }
| |_________^ help: replace it with: `(self.opt)?;`

error: this block may be rewritten with the `?` operator
--> $DIR/question_mark.rs:51:9
--> $DIR/question_mark.rs:54:9
|
LL | / if self.opt.is_none() {
LL | | return None
LL | | }
| |_________^ help: replace it with: `self.opt?;`

error: this block may be rewritten with the `?` operator
--> $DIR/question_mark.rs:55:17
--> $DIR/question_mark.rs:58:17
|
LL | let _ = if self.opt.is_none() {
| _________________^
Expand All @@ -36,7 +36,7 @@ LL | | };
| |_________^ help: replace it with: `Some(self.opt?)`

error: this if-let-else may be rewritten with the `?` operator
--> $DIR/question_mark.rs:61:17
--> $DIR/question_mark.rs:64:17
|
LL | let _ = if let Some(x) = self.opt {
| _________________^
Expand All @@ -47,45 +47,45 @@ LL | | };
| |_________^ help: replace it with: `self.opt?`

error: this block may be rewritten with the `?` operator
--> $DIR/question_mark.rs:78:9
--> $DIR/question_mark.rs:81:9
|
LL | / if self.opt.is_none() {
LL | | return None;
LL | | }
| |_________^ help: replace it with: `self.opt.as_ref()?;`

error: this block may be rewritten with the `?` operator
--> $DIR/question_mark.rs:86:9
--> $DIR/question_mark.rs:89:9
|
LL | / if self.opt.is_none() {
LL | | return None;
LL | | }
| |_________^ help: replace it with: `self.opt.as_ref()?;`

error: this block may be rewritten with the `?` operator
--> $DIR/question_mark.rs:94:9
--> $DIR/question_mark.rs:97:9
|
LL | / if self.opt.is_none() {
LL | | return None;
LL | | }
| |_________^ help: replace it with: `self.opt.as_ref()?;`

error: this if-let-else may be rewritten with the `?` operator
--> $DIR/question_mark.rs:101:30
--> $DIR/question_mark.rs:104:26
|
LL | let mut v: &Vec<_> = if let Some(ref v) = self.opt {
| ______________________________^
LL | let v: &Vec<_> = if let Some(ref v) = self.opt {
| __________________________^
LL | | v
LL | | } else {
LL | | return None;
LL | | };
| |_________^ help: replace it with: `self.opt.as_ref()?`

error: this if-let-else may be rewritten with the `?` operator
--> $DIR/question_mark.rs:111:21
--> $DIR/question_mark.rs:114:17
|
LL | let mut v = if let Some(v) = self.opt {
| _____________________^
LL | let v = if let Some(v) = self.opt {
| _________________^
LL | | v
LL | | } else {
LL | | return None;
Expand Down

0 comments on commit 246709f

Please sign in to comment.