diff options
| author | Fenrir <[email protected]> | 2017-08-01 15:24:05 -0600 |
|---|---|---|
| committer | Fenrir <[email protected]> | 2017-08-01 15:24:05 -0600 |
| commit | b2ba0fa9af69b7ff12b68e1c8b1f2c923c455e2e (patch) | |
| tree | 200404e7ea82f6db3456cbe76f3542407da99037 /ctr-std/src/panicking.rs | |
| parent | Update pinned nightly to 2017-07-31 (diff) | |
| download | ctru-rs-b2ba0fa9af69b7ff12b68e1c8b1f2c923c455e2e.tar.xz ctru-rs-b2ba0fa9af69b7ff12b68e1c8b1f2c923c455e2e.zip | |
Properly set up main thread
Diffstat (limited to 'ctr-std/src/panicking.rs')
| -rw-r--r-- | ctr-std/src/panicking.rs | 33 |
1 files changed, 11 insertions, 22 deletions
diff --git a/ctr-std/src/panicking.rs b/ctr-std/src/panicking.rs index c2e0832..7047334 100644 --- a/ctr-std/src/panicking.rs +++ b/ctr-std/src/panicking.rs @@ -354,25 +354,17 @@ fn default_hook(info: &PanicInfo) { }; // 3DS-specific code begins here - use libctru::{consoleInit, consoleDebugInit, debugDevice, - consoleClear, gfxScreen_t, threadGetCurrent}; + use libctru::{consoleDebugInit, debugDevice}; use sys::stdio::Stderr; let mut err = Stderr::new().ok(); let thread = thread_info::current_thread(); - let name; + let name = thread.as_ref() + .and_then(|t| t.name()) + .unwrap_or("<unnamed>"); unsafe { - // Set up a new console, overwriting whatever was on the bottom screen - // before we started panicking - let _console = consoleInit(gfxScreen_t::GFX_BOTTOM, ptr::null_mut()); - consoleClear(); consoleDebugInit(debugDevice::debugDevice_CONSOLE); - - // Determine thread name - name = thread.as_ref() - .and_then(|t| t.name()) - .unwrap_or(if threadGetCurrent() == ptr::null_mut() {"main"} else {"<unnamed>"}); } let write = |err: &mut ::io::Write| { @@ -405,10 +397,6 @@ fn default_hook(info: &PanicInfo) { (None, Some(ref mut err)) => { write(err) } _ => {} } - // Citra will crash and die horribly if we allow it to go further than this, - // So we just trap control flow in this loop instead. You'll still see the panic - // message, and Citra won't die quite as horribly. It's a win-win! Well, mostly. - loop { } } #[cfg(not(feature = "citra"))] @@ -441,17 +429,18 @@ fn default_hook(info: &PanicInfo) { } }; + // 3DS-specific code begins here - use libctru::{errorInit, errorText, errorDisp, threadGetCurrent, + use libctru::{errorInit, errorText, errorDisp, errorConf, errorType, CFG_Language}; use libc; - unsafe { - let thread = thread_info::current_thread(); - let name = thread.as_ref() - .and_then(|t| t.name()) - .unwrap_or(if threadGetCurrent() == ptr::null_mut() {"main"} else {"<unnamed>"}); + let thread = thread_info::current_thread(); + let name = thread.as_ref() + .and_then(|t| t.name()) + .unwrap_or("<unnamed>"); + unsafe { // Setup error payload let error_text = format!("thread '{}' panicked at '{}', {}:{}:{}", name, msg, file, line, col); |