cf-modkit 0.6.4

Core ModKit library
Documentation
use std::sync::Once;

static PANIC_HOOK_INIT: Once = Once::new();

pub fn init_panic_tracing() {
    PANIC_HOOK_INIT.call_once(|| {
        std::panic::set_hook(Box::new(|panic_info| {
            let backtrace = std::backtrace::Backtrace::force_capture();
            let location = panic_info.location().map_or_else(
                || "unknown location".to_owned(),
                |loc| format!("{}:{}:{}", loc.file(), loc.line(), loc.column()),
            );
            let payload = if let Some(s) = panic_info.payload().downcast_ref::<&str>() {
                (*s).to_owned()
            } else if let Some(s) = panic_info.payload().downcast_ref::<String>() {
                s.clone()
            } else {
                "non-string panic payload".to_owned()
            };

            tracing::error!(%location, %payload, %backtrace, "PANIC");
        }));

        tracing::debug!("tracing of panic is initialized");
    });
}