fix type suggestions in match arms
This commit is contained in:
parent
b72e896268
commit
08f3deb3d5
@ -1942,7 +1942,8 @@ impl<'tcx> TypeErrCtxt<'_, 'tcx> {
|
||||
escaped
|
||||
}
|
||||
let mut err = struct_span_err!(self.tcx.sess, span, E0308, "{}", failure_str);
|
||||
if let Some((expected, found)) = trace.values.ty() {
|
||||
let values = self.resolve_vars_if_possible(trace.values);
|
||||
if let Some((expected, found)) = values.ty() {
|
||||
match (expected.kind(), found.kind()) {
|
||||
(ty::Tuple(_), ty::Tuple(_)) => {}
|
||||
// If a tuple of length one was expected and the found expression has
|
||||
|
@ -10,3 +10,12 @@ fn main() {
|
||||
let _: char = '人'; //~ ERROR mismatched types
|
||||
let _: char = '\''; //~ ERROR mismatched types
|
||||
}
|
||||
|
||||
// regression test for https://github.com/rust-lang/rust/issues/109586
|
||||
#[allow(dead_code)]
|
||||
fn convert_c_to_str(c: char) {
|
||||
match c {
|
||||
'A' => {} //~ ERROR mismatched types
|
||||
_ => {}
|
||||
}
|
||||
}
|
||||
|
@ -10,3 +10,12 @@ fn main() {
|
||||
let _: char = "人"; //~ ERROR mismatched types
|
||||
let _: char = "'"; //~ ERROR mismatched types
|
||||
}
|
||||
|
||||
// regression test for https://github.com/rust-lang/rust/issues/109586
|
||||
#[allow(dead_code)]
|
||||
fn convert_c_to_str(c: char) {
|
||||
match c {
|
||||
"A" => {} //~ ERROR mismatched types
|
||||
_ => {}
|
||||
}
|
||||
}
|
||||
|
@ -37,6 +37,19 @@ help: if you meant to write a `char` literal, use single quotes
|
||||
LL | let _: char = '\'';
|
||||
| ~~~~
|
||||
|
||||
error: aborting due to 3 previous errors
|
||||
error[E0308]: mismatched types
|
||||
--> $DIR/char-as-str-single.rs:18:9
|
||||
|
|
||||
LL | match c {
|
||||
| - this expression has type `char`
|
||||
LL | "A" => {}
|
||||
| ^^^ expected `char`, found `&str`
|
||||
|
|
||||
help: if you meant to write a `char` literal, use single quotes
|
||||
|
|
||||
LL | 'A' => {}
|
||||
| ~~~
|
||||
|
||||
error: aborting due to 4 previous errors
|
||||
|
||||
For more information about this error, try `rustc --explain E0308`.
|
||||
|
Loading…
x
Reference in New Issue
Block a user