diff options
| author | John Hodge <tpg@mutabah.net> | 2015-06-13 22:34:58 +0800 |
|---|---|---|
| committer | John Hodge <tpg@mutabah.net> | 2015-06-15 12:00:16 +0800 |
| commit | 0937c10f3ca21585f0cb00c1a112e4ff4a742456 (patch) | |
| tree | e3e83799a5ebf9dec1503115d93e33a7aff21aa6 | |
| parent | 172cd83490cc66065e72861aed53e3efec29b34f (diff) | |
| download | rust-0937c10f3ca21585f0cb00c1a112e4ff4a742456.tar.gz rust-0937c10f3ca21585f0cb00c1a112e4ff4a742456.zip | |
libcore/Result - RFC#1119 Add an 'expect' method to Result
| -rw-r--r-- | src/libcore/result.rs | 20 | ||||
| -rw-r--r-- | src/libcoretest/lib.rs | 1 | ||||
| -rw-r--r-- | src/libcoretest/result.rs | 13 |
3 files changed, 34 insertions, 0 deletions
diff --git a/src/libcore/result.rs b/src/libcore/result.rs index 003c4b2b78c..772831b1a58 100644 --- a/src/libcore/result.rs +++ b/src/libcore/result.rs @@ -731,6 +731,26 @@ impl<T, E: fmt::Debug> Result<T, E> { panic!("called `Result::unwrap()` on an `Err` value: {:?}", e) } } + + /// Unwraps a result, yielding the content of an `Ok`. + /// + /// Panics if the value is an `Err`, with a panic message including the + /// passed message, and the content of the `Err`. + /// + /// # Examples + /// ```{.should_panic} + /// #![feature(result_expect)] + /// let x: Result<u32, &str> = Err("emergency failure"); + /// x.expect("Testing expect"); // panics with `Testing expect: emergency failure` + /// ``` + #[inline] + #[unstable(feature = "result_expect", reason = "newly introduced")] + pub fn expect(self, msg: &str) -> T { + match self { + Ok(t) => t, + Err(e) => panic!("{}: {:?}", msg, e), + } + } } #[stable(feature = "rust1", since = "1.0.0")] diff --git a/src/libcoretest/lib.rs b/src/libcoretest/lib.rs index deef26022f7..64e34883ee7 100644 --- a/src/libcoretest/lib.rs +++ b/src/libcoretest/lib.rs @@ -28,6 +28,7 @@ #![feature(cell_extras)] #![feature(iter_empty)] #![feature(iter_once)] +#![feature(result_expect)] extern crate core; extern crate test; diff --git a/src/libcoretest/result.rs b/src/libcoretest/result.rs index 3fdb1028753..02ea6b10e6e 100644 --- a/src/libcoretest/result.rs +++ b/src/libcoretest/result.rs @@ -137,3 +137,16 @@ pub fn test_unwrap_or_else_panic() { let bad_err: Result<isize, &'static str> = Err("Unrecoverable mess."); let _ : isize = bad_err.unwrap_or_else(handler); } + + +#[test] +pub fn test_expect_ok() { + let ok: Result<isize, &'static str> = Ok(100); + assert_eq!(ok.expect("Unexpected error"), 100); +} +#[test] +#[should_panic(expected="Got expected error: \"All good\"")] +pub fn test_expect_err() { + let err: Result<isize, &'static str> = Err("All good"); + err.expect("Got expected error"); +} |
