ffizer 2.13.9

ffizer is a files and folders initializer / generator. It creates or updates any kind (or part) of project from template(s)
Documentation
use clap::Parser;
use ffizer::ApplyOpts;
use ffizer::CliOpts;
use ffizer::Command;
use ffizer::Ctx;
use ffizer::ReapplyOpts;
use ffizer::SourceLoc;
use ffizer::TestSamplesOpts;
use ffizer::provide_json_schema;
use std::error::Error;
use tracing::{debug, error, info, trace};
use tracing_error::ErrorLayer;
use tracing_subscriber::prelude::*;
use tracing_subscriber::{filter, fmt};

fn tracing_level_from_usize(level: u8) -> tracing::Level {
    match level {
        0 => tracing::Level::ERROR,
        1 => tracing::Level::WARN,
        2 => tracing::Level::INFO,
        3 => tracing::Level::DEBUG,
        _ => tracing::Level::TRACE,
    }
}

fn init_log(level_min: tracing::Level) {
    // a builder for `FmtSubscriber`.
    let fmt_layer = fmt::layer()
        // .with_target(false)
        .with_writer(std::io::stderr)
        .with_ansi(true)
        .pretty();
    // let filter_layer = filter::EnvFilter::try_from_default_env()
    //     .or_else(|_| EnvFilter::try_new("info"))
    //     .unwrap();
    let filter_layer = filter::LevelFilter::from_level(level_min);
    tracing_subscriber::registry()
        .with(ErrorLayer::default())
        .with(filter_layer)
        .with(fmt_layer)
        .init();
    info!(version = env!("CARGO_PKG_VERSION"), "start");
    debug!("debug enabled");
    trace!("trace enabled");
}

#[tracing::instrument]
fn apply(cmd_opt: ApplyOpts) -> Result<(), Box<dyn Error>> {
    let ctx = Ctx { cmd_opt };
    ffizer::process(&ctx)?;
    Ok(())
}

#[tracing::instrument]
fn reapply(cmd_opt: ReapplyOpts) -> Result<(), Box<dyn Error>> {
    ffizer::reprocess(cmd_opt)?;
    Ok(())
}

#[tracing::instrument]
fn inspect() -> Result<(), Box<dyn Error>> {
    println!(
        "remote cache folder: {}",
        SourceLoc::find_remote_cache_folder()?.to_string_lossy()
    );
    Ok(())
}

#[tracing::instrument]
fn show_json_schema() -> Result<(), Box<dyn Error>> {
    let schema = provide_json_schema()?;
    println!("{}", schema);
    Ok(())
}

#[tracing::instrument]
fn test_samples(cfg: &TestSamplesOpts) -> Result<(), Box<dyn Error>> {
    ffizer::tools::test_samples(cfg)?;
    Ok(())
}

fn main() {
    human_panic::setup_panic!();
    let cli_opts = CliOpts::parse();

    let log_level = tracing_level_from_usize(1 + cli_opts.verbose);
    init_log(log_level);
    debug!(cmd = ?&cli_opts, "parsed args");

    let r = match &cli_opts.cmd {
        Command::Apply(g) => apply(g.clone()),
        Command::Inspect => inspect(),
        Command::ShowJsonSchema => show_json_schema(),
        Command::TestSamples(g) => test_samples(g),
        Command::Reapply(g) => reapply(g.clone()),
    };
    if let Err(e) = r {
        error!("cmd: {:#?}", &cli_opts);
        error!("failed: {:#?}", &e);
        std::process::exit(1)
    }
}