teascade-generator/src/main.rs

51 lines
1.3 KiB
Rust

extern crate pulldown_cmark;
extern crate regex;
#[macro_use]
extern crate serde_derive;
#[macro_use]
extern crate structopt;
extern crate toml;
mod logger;
mod options;
mod error;
mod config_toml;
mod config;
mod template;
mod renderer;
mod builder;
mod file_writer;
use structopt::StructOpt;
use logger::{LogLevel, Logger};
use options::{Opt, Subcommands};
fn main() {
let opt = Opt::from_args();
let log_level = (3 - opt.quiet as i8 + opt.verbose as i8).max(0).min(5);
let logger = Logger::new(LogLevel::from(log_level as u8));
match opt.cmd {
Subcommands::Build(ops) => match builder::build(&logger, &ops) {
Ok(_) => logger.log(LogLevel::DETAILER, "Building finished successfully."),
Err(err) => {
logger.log(err.severity(), err.description());
logger.log(LogLevel::SEVERE, "Aborting building due to error.");
}
},
Subcommands::New(ops) => {
logger.log(
LogLevel::DETAIL,
format!("Creating a new .toml file at {:?}", ops.toml_path),
);
match file_writer::write_file(ops.toml_path, "Hello!", ops.overwrite) {
Ok(_) => logger.log(LogLevel::INFO, "Done."),
Err(err) => logger.log(err.severity(), err.description()),
}
}
}
}