Skip to content

Commit

Permalink
Auto merge of #5481 - sinkuu:no_as_ref, r=phansch
Browse files Browse the repository at this point in the history
question_mark: don't add `as_ref()` for a call expression

If a call returns a `!Copy` value, it does so regardless of whether `as_ref()` is added. For example, `foo.into_option().as_ref()?` can be simplified to `foo.into_option()?`.

---

changelog: Improved `question_mark` lint suggestion so that it doesn't add redundant `as_ref()`
  • Loading branch information
bors committed Apr 17, 2020
2 parents 8ae143f + f58bb5b commit 82be9dc
Show file tree
Hide file tree
Showing 4 changed files with 40 additions and 4 deletions.
8 changes: 5 additions & 3 deletions clippy_lints/src/question_mark.rs
Original file line number Diff line number Diff line change
Expand Up @@ -70,10 +70,12 @@ impl QuestionMark {
replacement = Some(format!("Some({}?)", receiver_str));
}
}
} else if Self::moves_by_default(cx, subject) {
replacement = Some(format!("{}.as_ref()?;", receiver_str));
} else if Self::moves_by_default(cx, subject)
&& !matches!(subject.kind, ExprKind::Call(..) | ExprKind::MethodCall(..))
{
replacement = Some(format!("{}.as_ref()?;", receiver_str));
} else {
replacement = Some(format!("{}?;", receiver_str));
replacement = Some(format!("{}?;", receiver_str));
}

if let Some(replacement_str) = replacement {
Expand Down
12 changes: 12 additions & 0 deletions tests/ui/question_mark.fixed
Original file line number Diff line number Diff line change
Expand Up @@ -93,6 +93,16 @@ impl MoveStruct {
}
}

fn func() -> Option<i32> {
fn f() -> Option<String> {
Some(String::new())
}

f()?;

Some(0)
}

fn main() {
some_func(Some(42));
some_func(None);
Expand All @@ -110,4 +120,6 @@ fn main() {

let so = SeemsOption::Some(45);
returns_something_similar_to_option(so);

func();
}
14 changes: 14 additions & 0 deletions tests/ui/question_mark.rs
Original file line number Diff line number Diff line change
Expand Up @@ -121,6 +121,18 @@ impl MoveStruct {
}
}

fn func() -> Option<i32> {
fn f() -> Option<String> {
Some(String::new())
}

if f().is_none() {
return None;
}

Some(0)
}

fn main() {
some_func(Some(42));
some_func(None);
Expand All @@ -138,4 +150,6 @@ fn main() {

let so = SeemsOption::Some(45);
returns_something_similar_to_option(so);

func();
}
10 changes: 9 additions & 1 deletion tests/ui/question_mark.stderr
Original file line number Diff line number Diff line change
Expand Up @@ -92,5 +92,13 @@ LL | | return None;
LL | | };
| |_________^ help: replace it with: `self.opt?`

error: aborting due to 10 previous errors
error: this block may be rewritten with the `?` operator
--> $DIR/question_mark.rs:129:5
|
LL | / if f().is_none() {
LL | | return None;
LL | | }
| |_____^ help: replace it with: `f()?;`

error: aborting due to 11 previous errors

0 comments on commit 82be9dc

Please sign in to comment.