about summary refs log tree commit diff
diff options
context:
space:
mode:
authorTim Neumann <mail@timnn.me>2016-07-16 22:19:43 +0200
committerGitHub <noreply@github.com>2016-07-16 22:19:43 +0200
commitdd72785af537c30aaf70f49cf7abdb9700085997 (patch)
treeb409f07a1daf8e2c7aa0e0b62305354e45e7c6d5
parentd5b9850d79beb87c0e498e0a0b8097e4a11bfae6 (diff)
downloadrust-dd72785af537c30aaf70f49cf7abdb9700085997.tar.gz
rust-dd72785af537c30aaf70f49cf7abdb9700085997.zip
Revert "Refactored code to access TLS only in case of panic"
-rw-r--r--src/libstd/panicking.rs20
1 files changed, 9 insertions, 11 deletions
diff --git a/src/libstd/panicking.rs b/src/libstd/panicking.rs
index a7de9d3a0c5..d73e9542d21 100644
--- a/src/libstd/panicking.rs
+++ b/src/libstd/panicking.rs
@@ -232,9 +232,10 @@ fn default_hook(info: &PanicInfo) {
 pub unsafe fn try<R, F: FnOnce() -> R>(f: F) -> Result<R, Box<Any + Send>> {
     let mut slot = None;
     let mut f = Some(f);
-    let ret;
+    let ret = PANIC_COUNT.with(|s| {
+        let prev = s.get();
+        s.set(0);
 
-    {
         let mut to_run = || {
             slot = Some(f.take().unwrap()());
         };
@@ -247,21 +248,18 @@ pub unsafe fn try<R, F: FnOnce() -> R>(f: F) -> Result<R, Box<Any + Send>> {
                                          dataptr,
                                          &mut any_data,
                                          &mut any_vtable);
+        s.set(prev);
+
         if r == 0 {
-            ret = Ok(());
+            Ok(())
         } else {
-            PANIC_COUNT.with(|s| {
-                let prev = s.get();
-                s.set(prev - 1);
-            });
-            ret = Err(mem::transmute(raw::TraitObject {
+            Err(mem::transmute(raw::TraitObject {
                 data: any_data as *mut _,
                 vtable: any_vtable as *mut _,
-            }));
+            }))
         }
-    }
+    });
 
-    debug_assert!(PANIC_COUNT.with(|c| c.get() == 0));
     return ret.map(|()| {
         slot.take().unwrap()
     });