panicui

Crates.iopanicui
lib.rspanicui
version0.1.0
sourcesrc
created_at2023-01-30 07:23:03.087105
updated_at2023-01-30 07:23:03.087105
descriptionThe needed solution for panicking with user interface.
homepage
repositoryhttps://github.com/imajindevon/panicui
max_upload_size
id771509
size77,904
Imajin (ImajinDevon)

documentation

README

panicui

panicui icon

Description

panicui provides a simple solution to easier debugging by utilizing user interface.

panicui allows you to create panic hooks that open a crash log window in just 7 lines of code.

panicui UI preview

Why use panicui?

1. Extremely lightweight

Binary size of the program shown above (no strip, with debug symbols): ~1,010KB (0.98MB)

2. Fast build times

panicui only uses one direct dependency, fltk-rs.

3. Portable across every platform

panicui uses fltk for UI, which works across practically every platform. This includes:

  • UNIX
  • Linux (X11)
  • Windows
  • MacOS X

Example usage

More examples are available in the examples folder.

#![windows_subsystem = "windows"]

use panicui::app::PanicApplication;
use panicui::style::Style;
use panicui::window::PanicWindow;
use std::backtrace::Backtrace;
use std::panic;
use std::panic::PanicInfo;

fn panic_hook(info: &PanicInfo) {
    let backtrace = Backtrace::force_capture();
    let crash_text = format!("{info}\n{backtrace}");

    let win = PanicWindow::new(Style::default(), crash_text);

    let mut app = PanicApplication::new(win);
    app.run().expect("Unable to run application.");
}

fn main() {
    panic::set_hook(Box::new(panic_hook));

    // Cause some random panic.
    Result::<(), _>::Err(5i32).unwrap();
}
Commit count: 8

cargo fmt