Rollup merge of #82233 - ijackson:try-block-type-test, r=Mark-Simulacrum

try-back-block-type test: Use TryFromSliceError for From test

Using `i32` is rather fragile because it has many implementations.  Recently in an early draft of another MR (#82228) I did something that introduced a new `i32 as From<something>` impl and this test broke.

TryFromSliceError is nice because it doesn't seem likely to grow new conversions.  We still have one conversion, from Infallible.

My other MR is going to be reworked and won't need this any more but having done it I thought I would submit it rather than just throw it away.  Sorry for the tiny MR.
This commit is contained in:
Yuki Okushi 2021-02-21 15:26:48 +09:00 committed by GitHub
commit 2793859e86
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
2 changed files with 4 additions and 8 deletions

View File

@ -3,7 +3,7 @@
#![feature(try_blocks)] #![feature(try_blocks)]
pub fn main() { pub fn main() {
let res: Result<u32, i32> = try { let res: Result<u32, std::array::TryFromSliceError> = try {
Err("")?; //~ ERROR `?` couldn't convert the error Err("")?; //~ ERROR `?` couldn't convert the error
5 5
}; };

View File

@ -1,16 +1,12 @@
error[E0277]: `?` couldn't convert the error to `i32` error[E0277]: `?` couldn't convert the error to `TryFromSliceError`
--> $DIR/try-block-bad-type.rs:7:16 --> $DIR/try-block-bad-type.rs:7:16
| |
LL | Err("")?; LL | Err("")?;
| ^ the trait `From<&str>` is not implemented for `i32` | ^ the trait `From<&str>` is not implemented for `TryFromSliceError`
| |
= note: the question mark operation (`?`) implicitly performs a conversion on the error value using the `From` trait = note: the question mark operation (`?`) implicitly performs a conversion on the error value using the `From` trait
= help: the following implementations were found: = help: the following implementations were found:
<i32 as From<NonZeroI32>> <TryFromSliceError as From<Infallible>>
<i32 as From<bool>>
<i32 as From<i16>>
<i32 as From<i8>>
and 2 others
= note: required by `from` = note: required by `from`
error[E0271]: type mismatch resolving `<Result<i32, i32> as Try>::Ok == &str` error[E0271]: type mismatch resolving `<Result<i32, i32> as Try>::Ok == &str`