diff options
| author | Nikhil Shagrithaya <nikhilshagri@gmail.com> | 2016-07-15 20:47:45 +0530 |
|---|---|---|
| committer | Nikhil Shagrithaya <nikhilshagri@gmail.com> | 2016-07-16 00:34:50 +0530 |
| commit | b28e9dcae8f0f1930bbd11c826dd7357093ea7ae (patch) | |
| tree | 7596213133d2956d76a2b1cf7b9f608d106cfd29 /src/libstd | |
| parent | 6998018bcec10e8c754878e263e94d081e63950b (diff) | |
| download | rust-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.rs | 20 |
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() }); |
