From bfcc10a6cc0e76d489c5df2e5f4bfcafbca3a619 Mon Sep 17 00:00:00 2001 From: negamartin Date: Mon, 19 Feb 2018 11:58:45 -0300 Subject: [PATCH] read mut_ref inside closure --- src/lib.rs | 9 ++------- 1 file changed, 2 insertions(+), 7 deletions(-) diff --git a/src/lib.rs b/src/lib.rs index 4744f82..8fc2ead 100644 --- a/src/lib.rs +++ b/src/lib.rs @@ -33,8 +33,7 @@ pub fn take(mut_ref: &mut T, closure: F) use std::ptr; unsafe { - let old_t = ptr::read(mut_ref); - let new_t = panic::catch_unwind(panic::AssertUnwindSafe(|| closure(old_t))) + let new_t = panic::catch_unwind(panic::AssertUnwindSafe(|| closure( ptr::read(mut_ref) ))) .unwrap_or_else(|_| ::std::process::abort()); ptr::write(mut_ref, new_t); } @@ -82,8 +81,7 @@ pub fn take_or_recover(mut_ref: &mut T, recover: R, closure: F) where F: FnOnce(T) -> T, R: FnOnce() -> T { use std::ptr; unsafe { - let old_t = ptr::read(mut_ref); - let new_t = panic::catch_unwind(panic::AssertUnwindSafe(|| closure(old_t))); + let new_t = panic::catch_unwind(panic::AssertUnwindSafe(|| closure( ptr::read(mut_ref) ))); match new_t { Err(err) => { let r = panic::catch_unwind(panic::AssertUnwindSafe(|| recover())) @@ -145,6 +143,3 @@ fn it_works_recover_panic() { assert!(res.is_err()); assert_eq!(&foo, &Foo::C); } - - -