forked from rust-lang/rust
-
Notifications
You must be signed in to change notification settings - Fork 1
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Rollup merge of rust-lang#58267 - estebank:match-arms, r=matthewjasper
Tweak "incompatible match arms" error - Point at the body expression of the match arm with the type error. - Point at the prior match arms explicitly stating the evaluated type. - Point at the entire match expr in a secondary span, instead of primary. - For type errors in the first match arm, the cause is outside of the match, treat as implicit block error to give a more appropriate error. Fix rust-lang#46776, fix rust-lang#57206. CC rust-lang#24157, rust-lang#38234.
- Loading branch information
Showing
14 changed files
with
206 additions
and
62 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
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 |
---|---|---|
@@ -1,10 +1,11 @@ | ||
fn main() { | ||
if let Some(b) = None { //~ ERROR: `if let` arms have incompatible types | ||
//~^ expected (), found integer | ||
//~| expected type `()` | ||
//~| found type `{integer}` | ||
if let Some(b) = None { | ||
//~^ NOTE if let` arms have incompatible types | ||
() | ||
} else { | ||
1 | ||
}; | ||
//~^^ ERROR: `if let` arms have incompatible types | ||
//~| NOTE expected (), found integer | ||
//~| NOTE expected type `()` | ||
} |
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 |
---|---|---|
@@ -1,12 +1,14 @@ | ||
fn main() { | ||
match Some(10) { | ||
//~^ ERROR match arms have incompatible types | ||
//~| expected type `bool` | ||
//~| found type `()` | ||
//~| expected bool, found () | ||
//~^ NOTE `match` arms have incompatible types | ||
Some(5) => false, | ||
//~^ NOTE this is found to be of type `bool` | ||
Some(2) => true, | ||
//~^ NOTE this is found to be of type `bool` | ||
None => (), | ||
//~^ ERROR match arms have incompatible types | ||
//~| NOTE expected bool, found () | ||
//~| NOTE expected type `bool` | ||
_ => true | ||
} | ||
} |
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
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,45 @@ | ||
fn main() { | ||
let _ = test_func1(1); | ||
let _ = test_func2(1); | ||
} | ||
|
||
fn test_func1(n: i32) -> i32 { | ||
//~^ NOTE expected `i32` because of return type | ||
match n { | ||
12 => 'b', | ||
//~^ ERROR mismatched types | ||
//~| NOTE expected i32, found char | ||
_ => 42, | ||
} | ||
} | ||
|
||
fn test_func2(n: i32) -> i32 { | ||
let x = match n { | ||
//~^ NOTE `match` arms have incompatible types | ||
12 => 'b', | ||
//~^ NOTE this is found to be of type `char` | ||
_ => 42, | ||
//~^ ERROR match arms have incompatible types | ||
//~| NOTE expected char, found integer | ||
//~| NOTE expected type `char` | ||
}; | ||
x | ||
} | ||
|
||
fn test_func3(n: i32) -> i32 { | ||
let x = match n { | ||
//~^ NOTE `match` arms have incompatible types | ||
1 => 'b', | ||
2 => 'b', | ||
3 => 'b', | ||
4 => 'b', | ||
5 => 'b', | ||
6 => 'b', | ||
//~^ NOTE this and all prior arms are found to be of type `char` | ||
_ => 42, | ||
//~^ ERROR match arms have incompatible types | ||
//~| NOTE expected char, found integer | ||
//~| NOTE expected type `char` | ||
}; | ||
x | ||
} |
Oops, something went wrong.