Fix problem noticed in PR106859 with char -> u8 suggestion
This commit is contained in:
parent
319b88c463
commit
747cdc0dfd
3 changed files with 57 additions and 3 deletions
|
@ -1922,7 +1922,8 @@ impl<'tcx> TypeErrCtxt<'_, 'tcx> {
|
||||||
(ty::Uint(ty::UintTy::U8), ty::Char) => {
|
(ty::Uint(ty::UintTy::U8), ty::Char) => {
|
||||||
if let Ok(code) = self.tcx.sess().source_map().span_to_snippet(span)
|
if let Ok(code) = self.tcx.sess().source_map().span_to_snippet(span)
|
||||||
&& let Some(code) = code.strip_prefix('\'').and_then(|s| s.strip_suffix('\''))
|
&& let Some(code) = code.strip_prefix('\'').and_then(|s| s.strip_suffix('\''))
|
||||||
&& code.chars().next().map_or(false, |c| c.is_ascii())
|
&& !code.starts_with("\\u") // forbid all Unicode escapes
|
||||||
|
&& code.chars().next().map_or(false, |c| c.is_ascii()) // forbids literal Unicode characters beyond ASCII
|
||||||
{
|
{
|
||||||
err.span_suggestion(
|
err.span_suggestion(
|
||||||
span,
|
span,
|
||||||
|
|
|
@ -12,7 +12,19 @@ fn main() {
|
||||||
//~^ ERROR: mismatched types [E0308]
|
//~^ ERROR: mismatched types [E0308]
|
||||||
//~| HELP: if you meant to write a byte literal, prefix with `b`
|
//~| HELP: if you meant to write a byte literal, prefix with `b`
|
||||||
|
|
||||||
|
let _a: u8 = '\x20';
|
||||||
|
//~^ ERROR: mismatched types [E0308]
|
||||||
|
//~| HELP: if you meant to write a byte literal, prefix with `b`
|
||||||
|
|
||||||
|
// Do not issue the suggestion if the char literal is a Unicode escape
|
||||||
|
foo('\u{0080}');
|
||||||
|
//~^ ERROR: mismatched types [E0308]
|
||||||
|
|
||||||
// Do not issue the suggestion if the char literal isn't ASCII
|
// Do not issue the suggestion if the char literal isn't ASCII
|
||||||
let _t: u8 = '€';
|
let _t: u8 = '€';
|
||||||
//~^ ERROR: mismatched types [E0308]
|
//~^ ERROR: mismatched types [E0308]
|
||||||
|
|
||||||
|
// Do not issue the suggestion if the char literal isn't ASCII
|
||||||
|
foo('\u{1f980}');
|
||||||
|
//~^ ERROR: mismatched types [E0308]
|
||||||
}
|
}
|
||||||
|
|
|
@ -30,13 +30,54 @@ LL | foo(b'#');
|
||||||
| ~~~~
|
| ~~~~
|
||||||
|
|
||||||
error[E0308]: mismatched types
|
error[E0308]: mismatched types
|
||||||
--> $DIR/type-mismatch-byte-literal.rs:16:18
|
--> $DIR/type-mismatch-byte-literal.rs:15:18
|
||||||
|
|
|
||||||
|
LL | let _a: u8 = '\x20';
|
||||||
|
| -- ^^^^^^ expected `u8`, found `char`
|
||||||
|
| |
|
||||||
|
| expected due to this
|
||||||
|
|
|
||||||
|
help: if you meant to write a byte literal, prefix with `b`
|
||||||
|
|
|
||||||
|
LL | let _a: u8 = b'\x20';
|
||||||
|
| ~~~~~~~
|
||||||
|
|
||||||
|
error[E0308]: mismatched types
|
||||||
|
--> $DIR/type-mismatch-byte-literal.rs:20:9
|
||||||
|
|
|
||||||
|
LL | foo('\u{0080}');
|
||||||
|
| --- ^^^^^^^^^^ expected `u8`, found `char`
|
||||||
|
| |
|
||||||
|
| arguments to this function are incorrect
|
||||||
|
|
|
||||||
|
note: function defined here
|
||||||
|
--> $DIR/type-mismatch-byte-literal.rs:4:4
|
||||||
|
|
|
||||||
|
LL | fn foo(_t: u8) {}
|
||||||
|
| ^^^ ------
|
||||||
|
|
||||||
|
error[E0308]: mismatched types
|
||||||
|
--> $DIR/type-mismatch-byte-literal.rs:24:18
|
||||||
|
|
|
|
||||||
LL | let _t: u8 = '€';
|
LL | let _t: u8 = '€';
|
||||||
| -- ^^^ expected `u8`, found `char`
|
| -- ^^^ expected `u8`, found `char`
|
||||||
| |
|
| |
|
||||||
| expected due to this
|
| expected due to this
|
||||||
|
|
||||||
error: aborting due to 3 previous errors
|
error[E0308]: mismatched types
|
||||||
|
--> $DIR/type-mismatch-byte-literal.rs:28:9
|
||||||
|
|
|
||||||
|
LL | foo('\u{1f980}');
|
||||||
|
| --- ^^^^^^^^^^^ expected `u8`, found `char`
|
||||||
|
| |
|
||||||
|
| arguments to this function are incorrect
|
||||||
|
|
|
||||||
|
note: function defined here
|
||||||
|
--> $DIR/type-mismatch-byte-literal.rs:4:4
|
||||||
|
|
|
||||||
|
LL | fn foo(_t: u8) {}
|
||||||
|
| ^^^ ------
|
||||||
|
|
||||||
|
error: aborting due to 6 previous errors
|
||||||
|
|
||||||
For more information about this error, try `rustc --explain E0308`.
|
For more information about this error, try `rustc --explain E0308`.
|
||||||
|
|
Loading…
Add table
Reference in a new issue