-
Notifications
You must be signed in to change notification settings - Fork 1.6k
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Merge pull request #2664 from phansch/move_unnecessary_fold_ui_tests
Move unnecessary_fold UI tests to separate file
- Loading branch information
Showing
4 changed files
with
77 additions
and
74 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,40 @@ | ||
/// Calls which should trigger the `UNNECESSARY_FOLD` lint | ||
fn unnecessary_fold() { | ||
// Can be replaced by .any | ||
let _ = (0..3).fold(false, |acc, x| acc || x > 2); | ||
// Can be replaced by .all | ||
let _ = (0..3).fold(true, |acc, x| acc && x > 2); | ||
// Can be replaced by .sum | ||
let _ = (0..3).fold(0, |acc, x| acc + x); | ||
// Can be replaced by .product | ||
let _ = (0..3).fold(1, |acc, x| acc * x); | ||
} | ||
|
||
/// Should trigger the `UNNECESSARY_FOLD` lint, with an error span including exactly `.fold(...)` | ||
fn unnecessary_fold_span_for_multi_element_chain() { | ||
let _ = (0..3).map(|x| 2 * x).fold(false, |acc, x| acc || x > 2); | ||
} | ||
|
||
/// Calls which should not trigger the `UNNECESSARY_FOLD` lint | ||
fn unnecessary_fold_should_ignore() { | ||
let _ = (0..3).fold(true, |acc, x| acc || x > 2); | ||
let _ = (0..3).fold(false, |acc, x| acc && x > 2); | ||
let _ = (0..3).fold(1, |acc, x| acc + x); | ||
let _ = (0..3).fold(0, |acc, x| acc * x); | ||
let _ = (0..3).fold(0, |acc, x| 1 + acc + x); | ||
|
||
// We only match against an accumulator on the left | ||
// hand side. We could lint for .sum and .product when | ||
// it's on the right, but don't for now (and this wouldn't | ||
// be valid if we extended the lint to cover arbitrary numeric | ||
// types). | ||
let _ = (0..3).fold(false, |acc, x| x > 2 || acc); | ||
let _ = (0..3).fold(true, |acc, x| x > 2 && acc); | ||
let _ = (0..3).fold(0, |acc, x| x + acc); | ||
let _ = (0..3).fold(1, |acc, x| x * acc); | ||
|
||
let _ = [(0..2), (0..3)].iter().fold(0, |a, b| a + b.len()); | ||
let _ = [(0..2), (0..3)].iter().fold(1, |a, b| a * b.len()); | ||
} | ||
|
||
fn main() {} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,34 @@ | ||
error: this `.fold` can be written more succinctly using another method | ||
--> $DIR/unnecessary_fold.rs:4:19 | ||
| | ||
4 | let _ = (0..3).fold(false, |acc, x| acc || x > 2); | ||
| ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ help: try: `.any(|x| x > 2)` | ||
| | ||
= note: `-D unnecessary-fold` implied by `-D warnings` | ||
|
||
error: this `.fold` can be written more succinctly using another method | ||
--> $DIR/unnecessary_fold.rs:6:19 | ||
| | ||
6 | let _ = (0..3).fold(true, |acc, x| acc && x > 2); | ||
| ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ help: try: `.all(|x| x > 2)` | ||
|
||
error: this `.fold` can be written more succinctly using another method | ||
--> $DIR/unnecessary_fold.rs:8:19 | ||
| | ||
8 | let _ = (0..3).fold(0, |acc, x| acc + x); | ||
| ^^^^^^^^^^^^^^^^^^^^^^^^^^ help: try: `.sum()` | ||
|
||
error: this `.fold` can be written more succinctly using another method | ||
--> $DIR/unnecessary_fold.rs:10:19 | ||
| | ||
10 | let _ = (0..3).fold(1, |acc, x| acc * x); | ||
| ^^^^^^^^^^^^^^^^^^^^^^^^^^ help: try: `.product()` | ||
|
||
error: this `.fold` can be written more succinctly using another method | ||
--> $DIR/unnecessary_fold.rs:15:34 | ||
| | ||
15 | let _ = (0..3).map(|x| 2 * x).fold(false, |acc, x| acc || x > 2); | ||
| ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ help: try: `.any(|x| x > 2)` | ||
|
||
error: aborting due to 5 previous errors | ||
|