teascade-generator/src/main.rs

143 lines
4.3 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;
2018-04-18 19:27:00 +02:00
extern crate serde;
2018-04-16 13:10:05 +02:00
#[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-17 00:17:47 +02:00
use std::collections::HashMap;
use std::path::PathBuf;
use std::process::exit;
2018-04-17 00:17:47 +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-17 00:17:47 +02:00
use config_toml::{GlobalConfigToml, NavbarConfig, NavbarItem, WebsiteConfig};
2018-04-16 13:10:05 +02:00
2018-04-19 21:21:49 +02:00
//TODO: Custom markdown
2018-04-16 13:10:05 +02:00
fn main() {
exit(match run() {
Ok(()) => 0,
Err(()) => 1,
})
}
fn run() -> Result<(), ()> {
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
match opt.clone().cmd {
Subcommands::Build(build_opt) => match builder::build(&logger, &opt, &build_opt) {
Ok(_) => {
logger.log(LogLevel::DETAILER, "Building finished successfully.");
Ok(())
}
2018-04-16 18:31:38 +02:00
Err(err) => {
logger.log(err.severity(), err.description());
logger.log(LogLevel::SEVERE, "Aborting building due to error.");
Err(())
2018-04-16 18:31:38 +02:00
}
},
Subcommands::New(new_opt) => match new_page::generate_new_page(&logger, &opt, &new_opt) {
Ok(_) => {
logger.log(
LogLevel::DETAILER,
"Generating the new page finished successfully.",
);
Ok(())
}
2018-04-16 23:31:44 +02:00
Err(err) => {
logger.log(err.severity(), err.description());
logger.log(LogLevel::SEVERE, "Aborting building due to error.");
Err(())
}
2018-04-16 23:31:44 +02:00
},
Subcommands::Initialize(init_opt) => {
2018-04-17 00:17:47 +02:00
logger.log(LogLevel::DETAIL, "Generating config.toml");
let mut navbar = None;
if !init_opt.no_default_navbar {
2018-04-17 00:17:47 +02:00
let mut hashmap = HashMap::new();
hashmap.insert(
"test".to_owned(),
NavbarItem {
title: "Home".to_owned(),
link: "/home.html".to_owned(),
image_url: Some("/img/image.png".to_owned()),
},
);
hashmap.insert(
"other".to_owned(),
NavbarItem {
title: "Other".to_owned(),
link: "/other.html".to_owned(),
image_url: None,
},
);
navbar = Some(NavbarConfig {
items: vec!["test".to_owned(), "other".to_owned()],
item_map: hashmap,
})
}
2018-04-18 19:27:00 +02:00
2018-04-17 00:17:47 +02:00
let config = GlobalConfigToml {
website: WebsiteConfig {
website_name: init_opt.name,
2018-04-17 00:17:47 +02:00
built_pages: Vec::new(),
use_default_css: true,
2018-04-19 21:21:49 +02:00
use_default_js: true,
2018-04-17 00:17:47 +02:00
javascript: Vec::new(),
css: Vec::new(),
favicon: init_opt.favicon,
2018-04-17 00:17:47 +02:00
before_navbar_url: None,
before_content_url: None,
after_content_url: None,
mobile_viewport: None,
meta_description: None,
charset: Some("utf-8".to_owned()),
meta_og: None,
2018-04-19 00:42:12 +02:00
output: None,
2018-04-17 00:17:47 +02:00
},
navbar: navbar,
2018-04-19 00:12:18 +02:00
resources: None,
twitter: None,
google: None,
2018-04-17 00:17:47 +02:00
};
match file_writer::write_toml(&PathBuf::from("config.toml"), &config, opt.overwrite) {
Ok(_) => {
logger.log(LogLevel::INFO, "Done!");
Ok(())
}
Err(err) => {
logger.log(
err.severity(),
format!("Initialization failed: {}", err.description()),
);
Err(())
}
2018-04-17 00:17:47 +02:00
}
}
2018-04-16 14:21:31 +02:00
}
2018-04-16 13:10:05 +02:00
}