about summary refs log tree commit diff
path: root/src/libstd
diff options
context:
space:
mode:
authorNikhil Shagrithaya <nikhilshagri@gmail.com>2016-07-15 20:47:45 +0530
committerNikhil Shagrithaya <nikhilshagri@gmail.com>2016-07-16 00:34:50 +0530
commitb28e9dcae8f0f1930bbd11c826dd7357093ea7ae (patch)
tree7596213133d2956d76a2b1cf7b9f608d106cfd29 /src/libstd
parent6998018bcec10e8c754878e263e94d081e63950b (diff)
downloadrust-b28e9dcae8f0f1930bbd11c826dd7357093ea7ae.tar.gz
rust-b28e9dcae8f0f1930bbd11c826dd7357093ea7ae.zip
Refactored code to access TLS only in case of panic
Diffstat (limited to 'src/libstd')
-rw-r--r--src/libstd/panicking.rs20
1 files changed, 11 insertions, 9 deletions
diff --git a/src/libstd/panicking.rs b/src/libstd/panicking.rs
index d73e9542d21..a7de9d3a0c5 100644
--- a/src/libstd/panicking.rs
+++ b/src/libstd/panicking.rs
@@ -232,10 +232,9 @@ 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 = PANIC_COUNT.with(|s| {
-        let prev = s.get();
-        s.set(0);
+    let ret;
 
+    {
         let mut to_run = || {
             slot = Some(f.take().unwrap()());
         };
@@ -248,18 +247,21 @@ 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 {
-            Ok(())
+            ret = Ok(());
         } else {
-            Err(mem::transmute(raw::TraitObject {
+            PANIC_COUNT.with(|s| {
+                let prev = s.get();
+                s.set(prev - 1);
+            });
+            ret = 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()
     });