Crate human_panic [−] [src]
human-panic
[][2] [][4] [][6] []8
Panic messages for humans. Replacement for
std::panic::catch_unwind
to make errors nice for humans.
Why?
When you're building a CLI, polish is super important. Even though Rust is pretty great at safety, it's not unheard of to access the wrong index in a vector or have an assert fail somewhere.
When an error eventually occurs, you probably will want to know about it. So instead of just providing an error message on the command line, we can create a call to action for people to submit a report.
This should empower people to engage in communication, lowering the chances people might get frustrated. And making it easier to figure out what might be causing bugs.
Default Output
thread 'main' panicked at 'oops', examples/main.rs:2:3
note: Run with `RUST_BACKTRACE=1` for a backtrace.
Human-Panic Output
Well, this is embarrasing.
human-panic had a problem and crashed. To help us diagnose the problem you can
send us a crash report.
We have generated a report file at "<reports not generated yet>". Submit an
issue or email with the subject of "human-panic Crash Report" and include the
report as an attachment.
- Homepage: https://github.com/yoshuawuyts/human-panic
- Authors: Yoshua Wuyts <yoshuawuyts@gmail.com>
We take privacy seriously, and do not perform any automated error collection. In
order to improve the software, we rely on people to submit reports.
Thank you kindly!
Usage
extern crate human_panic; human_panic::catch_unwind(|| { panic!("something went wrong"); });
Notes
Because we rely on std::panic::catch_unwind
, we inherit some of the same
limitations. More specifically: we can only catch unwinding panics, not
aborts. This
should be alright for most cases, but it's good to be aware of what the
limitations are.
Installation
$ cargo add human-panic
License
MIT OR Apache-2.0
Macros
setup_panic |
Setup the human panic hook that will make all panics as beautiful as your shitty code. |
Structs
Metadata |
A convenient metadata struct that describes a crate |
Functions
handle_dump |
Utility function which will handle dumping information to disk |
print_msg |
Utility function that prints a message to our human users |