Crates.io | panicui |
lib.rs | panicui |
version | 0.1.0 |
source | src |
created_at | 2023-01-30 07:23:03.087105 |
updated_at | 2023-01-30 07:23:03.087105 |
description | The needed solution for panicking with user interface. |
homepage | |
repository | https://github.com/imajindevon/panicui |
max_upload_size | |
id | 771509 |
size | 77,904 |
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.
Binary size of the program shown above (no strip, with debug symbols): ~1,010KB (0.98MB)
panicui only uses one direct dependency, fltk-rs.
panicui uses fltk for UI, which works across practically every platform. This includes:
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();
}