From d3c831ba4a4a2284f73e4f9147aa4900cab56815 Mon Sep 17 00:00:00 2001 From: Huon Wilson Date: Mon, 7 Apr 2014 22:32:49 +1000 Subject: std: use a `match` in `assert_eq!` to extend the lifetime of the args. This enables assert_eq!(foo.collect::>().as_slice(), &[1,2,3,4]); to work, by extending the lifetime of the .as_slice() rvalue. --- src/libstd/macros.rs | 16 +++++++++------- 1 file changed, 9 insertions(+), 7 deletions(-) (limited to 'src/libstd') diff --git a/src/libstd/macros.rs b/src/libstd/macros.rs index fbb48f2ebcb..9d06e38dd8e 100644 --- a/src/libstd/macros.rs +++ b/src/libstd/macros.rs @@ -117,13 +117,15 @@ macro_rules! assert( #[macro_export] macro_rules! assert_eq( ($given:expr , $expected:expr) => ({ - let given_val = &($given); - let expected_val = &($expected); - // check both directions of equality.... - if !((*given_val == *expected_val) && - (*expected_val == *given_val)) { - fail!("assertion failed: `(left == right) && (right == left)` \ - (left: `{}`, right: `{}`)", *given_val, *expected_val) + match (&($given), &($expected)) { + (given_val, expected_val) => { + // check both directions of equality.... + if !((*given_val == *expected_val) && + (*expected_val == *given_val)) { + fail!("assertion failed: `(left == right) && (right == left)` \ + (left: `{}`, right: `{}`)", *given_val, *expected_val) + } + } } }) ) -- cgit 1.4.1-3-g733a5