Crate human_panic [] [src]

human-panic

[crates.io version][2] [build status][4] [downloads][6] [docs.rs docs]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