diff options
| author | Yuki Okushi <huyuumi.dev@gmail.com> | 2020-01-11 04:50:45 +0900 |
|---|---|---|
| committer | GitHub <noreply@github.com> | 2020-01-11 04:50:45 +0900 |
| commit | 2dbcf0841a81fbada9a2b3af253b62b30a8318cc (patch) | |
| tree | d505e70506be89f42026b296a4adece3135ae1d6 /src | |
| parent | f795e8a216b44982706d41e5cbfa245d13b83fc1 (diff) | |
| parent | 6f0672c08b7609c7ed77245a3feea3040221b804 (diff) | |
| download | rust-2dbcf0841a81fbada9a2b3af253b62b30a8318cc.tar.gz rust-2dbcf0841a81fbada9a2b3af253b62b30a8318cc.zip | |
Rollup merge of #66045 - mzabaluev:unwrap-infallible, r=dtolnay
Add method Result::into_ok Implementation of https://github.com/rust-lang/rfcs/pull/2799 Tracking issue #61695
Diffstat (limited to 'src')
| -rw-r--r-- | src/libcore/result.rs | 38 | ||||
| -rw-r--r-- | src/libcore/tests/lib.rs | 2 | ||||
| -rw-r--r-- | src/libcore/tests/result.rs | 22 |
3 files changed, 62 insertions, 0 deletions
diff --git a/src/libcore/result.rs b/src/libcore/result.rs index c6062493b86..aa57c7788c6 100644 --- a/src/libcore/result.rs +++ b/src/libcore/result.rs @@ -1092,6 +1092,44 @@ impl<T: Default, E> Result<T, E> { } } +#[unstable(feature = "unwrap_infallible", reason = "newly added", issue = "61695")] +impl<T, E: Into<!>> Result<T, E> { + /// Unwraps a result that can never be an [`Err`], yielding the content of the [`Ok`]. + /// + /// Unlike [`unwrap`], this method is known to never panic on the + /// result types it is implemented for. Therefore, it can be used + /// instead of `unwrap` as a maintainability safeguard that will fail + /// to compile if the error type of the `Result` is later changed + /// to an error that can actually occur. + /// + /// [`Ok`]: enum.Result.html#variant.Ok + /// [`Err`]: enum.Result.html#variant.Err + /// [`unwrap`]: enum.Result.html#method.unwrap + /// + /// # Examples + /// + /// Basic usage: + /// + /// ``` + /// # #![feature(never_type)] + /// # #![feature(unwrap_infallible)] + /// + /// fn only_good_news() -> Result<String, !> { + /// Ok("this is fine".into()) + /// } + /// + /// let s: String = only_good_news().into_ok(); + /// println!("{}", s); + /// ``` + #[inline] + pub fn into_ok(self) -> T { + match self { + Ok(x) => x, + Err(e) => e.into(), + } + } +} + #[unstable(feature = "inner_deref", reason = "newly added", issue = "50264")] impl<T: Deref, E> Result<T, E> { /// Converts from `Result<T, E>` (or `&Result<T, E>`) to `Result<&T::Target, &E>`. diff --git a/src/libcore/tests/lib.rs b/src/libcore/tests/lib.rs index 39f6133f2a6..09b54857f7d 100644 --- a/src/libcore/tests/lib.rs +++ b/src/libcore/tests/lib.rs @@ -40,6 +40,8 @@ #![feature(slice_from_raw_parts)] #![feature(const_slice_from_raw_parts)] #![feature(const_raw_ptr_deref)] +#![feature(never_type)] +#![feature(unwrap_infallible)] extern crate test; diff --git a/src/libcore/tests/result.rs b/src/libcore/tests/result.rs index 499a5613bd2..254d4539eac 100644 --- a/src/libcore/tests/result.rs +++ b/src/libcore/tests/result.rs @@ -184,6 +184,28 @@ pub fn test_unwrap_or_default() { } #[test] +pub fn test_into_ok() { + fn infallible_op() -> Result<isize, !> { + Ok(666) + } + + assert_eq!(infallible_op().into_ok(), 666); + + enum MyNeverToken {} + impl From<MyNeverToken> for ! { + fn from(never: MyNeverToken) -> ! { + match never {} + } + } + + fn infallible_op2() -> Result<isize, MyNeverToken> { + Ok(667) + } + + assert_eq!(infallible_op2().into_ok(), 667); +} + +#[test] fn test_try() { fn try_result_some() -> Option<u8> { let val = Ok(1)?; |
