teascade-generator/src/main.rs

53 lines
1.4 KiB
Rust
Raw Normal View History

2018-04-16 20:25:46 +02:00
extern crate ansi_term;
2018-04-16 23:31:44 +02:00
extern crate pathdiff;
2018-04-16 13:10:05 +02:00
extern crate pulldown_cmark;
extern crate regex;
#[macro_use]
extern crate serde_derive;
2018-04-16 18:31:38 +02:00
#[macro_use]
extern crate structopt;
2018-04-16 13:10:05 +02:00
extern crate toml;
2018-04-16 15:58:16 +02:00
mod logger;
2018-04-16 18:31:38 +02:00
mod options;
2018-04-16 15:58:16 +02:00
mod error;
2018-04-16 13:10:05 +02:00
mod config_toml;
mod config;
mod template;
mod renderer;
2018-04-16 15:58:16 +02:00
mod builder;
2018-04-16 23:31:44 +02:00
mod new_page;
mod file_writer;
2018-04-16 13:10:05 +02:00
2018-04-16 18:31:38 +02:00
use structopt::StructOpt;
2018-04-16 15:58:16 +02:00
use logger::{LogLevel, Logger};
2018-04-16 18:31:38 +02:00
use options::{Opt, Subcommands};
2018-04-16 13:10:05 +02:00
fn main() {
2018-04-16 18:31:38 +02:00
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));
2018-04-16 13:10:05 +02:00
2018-04-16 18:31:38 +02:00
match opt.cmd {
Subcommands::Build(ops) => match builder::build(&logger, &ops) {
2018-04-16 18:31:38 +02:00
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.");
}
},
2018-04-16 23:31:44 +02:00
Subcommands::New(ops) => match new_page::generate_new_page(ops, &logger) {
Ok(_) => logger.log(
LogLevel::DETAILER,
"Generating the new page finished successfully.",
),
Err(err) => {
logger.log(err.severity(), err.description());
logger.log(LogLevel::SEVERE, "Aborting building due to error.");
}
2018-04-16 23:31:44 +02:00
},
2018-04-16 14:21:31 +02:00
}
2018-04-16 13:10:05 +02:00
}