Skip to content

Commit

Permalink
Merge pull request #34862 from TimNN/revert-34836-panic-counter
Browse files Browse the repository at this point in the history
Revert #34836 "Refactored code to access TLS only in case of panic"
  • Loading branch information
alexcrichton authored Jul 16, 2016
2 parents d5b9850 + dd72785 commit 60564d0
Showing 1 changed file with 9 additions and 11 deletions.
20 changes: 9 additions & 11 deletions src/libstd/panicking.rs
Original file line number Diff line number Diff line change
Expand Up @@ -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()());
};
Expand All @@ -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()
});
Expand Down

0 comments on commit 60564d0

Please sign in to comment.