#error #setting #printing #up #utilities #ci #axoapp

axocli

common code for setting up a CLI App and handling errors/printing

3 unstable releases

0.2.0 Feb 16, 2024
0.1.1 Nov 24, 2023
0.1.0 Apr 4, 2023

#155 in Configuration

Download history 265/week @ 2024-01-28 202/week @ 2024-02-04 424/week @ 2024-02-11 378/week @ 2024-02-18 293/week @ 2024-02-25 203/week @ 2024-03-03 201/week @ 2024-03-10 270/week @ 2024-03-17 271/week @ 2024-03-24 345/week @ 2024-03-31 385/week @ 2024-04-07 141/week @ 2024-04-14 202/week @ 2024-04-21 572/week @ 2024-04-28 482/week @ 2024-05-05 579/week @ 2024-05-12

1,844 downloads per month
Used in 3 crates

MIT/Apache

20KB
175 lines

axocli

crates.io docs Rust CI

Common code for setting up a CLI App and handling errors/printing.

Example

See examples/axoapp.rs for a walkthrough/example.

Some various interesting example invocations to play with:

# clap help
cargo run --example axoapp -- --help

# success
cargo run --example axoapp -- 5
cargo run --example axoapp -- 5 --output-format=json

# normal error
cargo run --example axoapp -- 2
cargo run --example axoapp -- 2 --output-format=json

# panic (setting RUST_BACKTRACE=1 here is also interesting)
cargo run --example axoapp -- 0
cargo run --example axoapp -- 0 --output-format=json

# clap error
cargo run --example axoapp --

What Does It Do?

First off, it handles setting up:

  • a tracing subscriber (currently the kind that cargo-dist uses, more work needed for oranda's use)
  • a miette formatter (so we can have a shared Look And Feel)
  • a panic handler (to get more control over output if the app panics)
  • (not implemented but likely in the future) a tokio runtime

It also handles printing top-level errors, notably including a json_errors mode where the error gets formatted to json and printed to stdout, while still printing a human-friendly version to stderr. This is done for both an error returned from real_main and panics. So anything expecting machine-readable output from our apps will not freak out and get something unparseable when things error/panic. It will also set the process exit code on error (with std::process::exit, on the assumption that all cleanup was done when we returned/panicked out of real_main).

It also exposes the json diagnostic formatting machinery so you can Write them wherever or turn them into serde_json::Values. This is useful for returning a larger result with diagnostics nested inside of it (say, for reporting warnings).

License

Licensed under either of

at your option.

Dependencies

~5–14MB
~176K SLoC