diff options
| author | bors <bors@rust-lang.org> | 2017-01-14 17:33:46 +0000 |
|---|---|---|
| committer | bors <bors@rust-lang.org> | 2017-01-14 17:33:46 +0000 |
| commit | 2f9dedb528d40a46c47c9970b30cc3e2fdd1e0bb (patch) | |
| tree | 8799645d76d2f7dbb2c19082235cf5b0551fdd37 /src/libcore | |
| parent | d4b063de86a061041285bd97af7c059fc7168fab (diff) | |
| parent | e520b77efed718dd6ba4509f5a8d5860ad80e660 (diff) | |
| download | rust-2f9dedb528d40a46c47c9970b30cc3e2fdd1e0bb.tar.gz rust-2f9dedb528d40a46c47c9970b30cc3e2fdd1e0bb.zip | |
Auto merge of #38982 - clarcharr:expect_err, r=aturon
expect_err for Result. This adds an `expect_err` method to `Result`. Considering how `unwrap_err` already exists, this seems to make sense. Inconsistency noted in Manishearth/rust-clippy#1435.
Diffstat (limited to 'src/libcore')
| -rw-r--r-- | src/libcore/result.rs | 25 |
1 files changed, 25 insertions, 0 deletions
diff --git a/src/libcore/result.rs b/src/libcore/result.rs index 99c407e5273..f02df88bb2e 100644 --- a/src/libcore/result.rs +++ b/src/libcore/result.rs @@ -798,6 +798,31 @@ impl<T: fmt::Debug, E> Result<T, E> { Err(e) => e, } } + + /// Unwraps a result, yielding the content of an `Err`. + /// + /// # Panics + /// + /// Panics if the value is an `Ok`, with a panic message including the + /// passed message, and the content of the `Ok`. + /// + /// # Examples + /// + /// Basic usage: + /// + /// ```{.should_panic} + /// # #![feature(result_expect_err)] + /// let x: Result<u32, &str> = Ok(10); + /// x.expect_err("Testing expect_err"); // panics with `Testing expect_err: 10` + /// ``` + #[inline] + #[unstable(feature = "result_expect_err", issue = "39041")] + pub fn expect_err(self, msg: &str) -> E { + match self { + Ok(t) => unwrap_failed(msg, t), + Err(e) => e, + } + } } impl<T: Default, E> Result<T, E> { |
