Skip to content

Commit

Permalink
feat(console): init error handling before subcmds (#365)
Browse files Browse the repository at this point in the history
This way, if running a subcommand panics/errors, we still get nice
`color-eyre` reports.
  • Loading branch information
hawkw committed Sep 29, 2023
1 parent da2a89c commit ec66eda
Showing 1 changed file with 8 additions and 7 deletions.
15 changes: 8 additions & 7 deletions tokio-console/src/main.rs
Original file line number Diff line number Diff line change
Expand Up @@ -26,6 +26,13 @@ mod warnings;
#[tokio::main]
async fn main() -> color_eyre::Result<()> {
let mut args = config::Config::parse()?;
// initialize error handling first, in case panics occur while setting up
// other stuff.
let styles = view::Styles::from_config(args.view_options.clone());
styles.error_init()?;

args.trace_init()?;
tracing::debug!(?args.target_addr, ?args.view_options);

match args.subcmd {
Some(config::OptionalCmd::GenConfig) => {
Expand All @@ -40,16 +47,10 @@ async fn main() -> color_eyre::Result<()> {
None => {}
}

let retain_for = args.retain_for();
args.trace_init()?;
tracing::debug!(?args.target_addr, ?args.view_options);

let target = args.target_addr();
tracing::info!(?target, "using target addr");

let styles = view::Styles::from_config(args.view_options);
styles.error_init()?;

let retain_for = args.retain_for();
let (mut terminal, _cleanup) = term::init_crossterm()?;
terminal.clear()?;
let mut conn = conn::Connection::new(target);
Expand Down

0 comments on commit ec66eda

Please sign in to comment.