dynix/src/main.rs
2026-03-22 17:10:26 +01:00

60 lines
1.7 KiB
Rust

// SPDX-FileCopyrightText: 2026 Qyriad <qyriad@qyriad.me>
//
// SPDX-License-Identifier: EUPL-1.1
use std::env;
use std::io::{self, IsTerminal};
use std::process::ExitCode;
use std::{error::Error as StdError, sync::Arc};
use clap::{ColorChoice, Parser as _};
use tracing_human_layer::HumanLayer;
use tracing_subscriber::util::SubscriberInitExt;
use tracing_subscriber::{EnvFilter, layer::SubscriberExt};
fn main_wrapped() -> Result<(), Box<dyn StdError + Send + Sync + 'static>> {
// Default RUST_LOG to warn if it's not specified.
if env::var_os("RUST_LOG").is_none() {
unsafe {
env::set_var("RUST_LOG", "warn");
}
}
let args = Arc::new(dynix::Args::parse());
let success = dynix::_CLI_ENABLE_COLOR.set(match args.color {
ColorChoice::Always => true,
ColorChoice::Auto => io::stdin().is_terminal(),
ColorChoice::Never => false,
});
if cfg!(debug_assertions) {
success.expect("logic error in CLI_ENABLE_COLOR");
}
tracing_subscriber::registry()
.with(HumanLayer::new().with_color_output(*dynix::SHOULD_COLOR))
.with(EnvFilter::from_default_env())
.init();
tracing::debug!("Parsed command-line arguments: {args:?}");
{
use dynix::args::Subcommand::*;
match &args.subcommand {
Append(append_args) => dynix::do_append(args.clone(), append_args.clone())?,
Daemon(daemon_args) => dynix::do_daemon(args.clone(), daemon_args.clone())?,
};
}
Ok(())
}
fn main() -> ExitCode {
match main_wrapped() {
Ok(_) => ExitCode::SUCCESS,
Err(e) => {
eprintln!("dynix: error: {}", e);
ExitCode::FAILURE
},
}
}