X-Git-Url: https://git.r.bdr.sh/rbdr/page/blobdiff_plain/8d4fac527ea33456de21933b4632a5bf4abbfc8d..260e8ec69b8e08b9fd105bf688e7a3a9fafecd61:/src/main.rs diff --git a/src/main.rs b/src/main.rs index aa3fb93..533a6bb 100644 --- a/src/main.rs +++ b/src/main.rs @@ -1,9 +1,49 @@ mod gemini_parser; +mod html_renderer; +mod file_finder; +mod file_handler; -use crate::gemini_parser::parse; +use std::io::Result; +use std::process::exit; +use std::env::current_dir; +use std::fs::{create_dir_all, remove_dir_all}; -fn main() { - let gemini_source = "# Test\n## 2nd H\na line\n another line\n```\npreformat\n=> preformat\n```\n=> http://lol.com\n=> http://lol.com lol\n* lol\nbla\n* lol\n* lmao\n> blabla\n> blabla"; - let html = parse(gemini_source); - println!("{}", html) +use crate::file_finder::find_files; +use crate::file_handler::FileHandler; + +fn main() -> Result<()> { + let source = current_dir()?; + let source_name = source.file_name().unwrap().to_string_lossy(); + let parent = source.parent().unwrap(); + let gemini_destination_name = format!("{}_gemini", source_name); + let gemini_destination = parent.join(gemini_destination_name); + let html_destination_name = format!("{}_html", source_name); + let html_destination = parent.join(html_destination_name); + + // Step 1. Identify the files + let files = find_files(&source); + + // Step 2. Prepare the target priority + match remove_dir_all(&html_destination) { + _ => {} + }; + create_dir_all(&html_destination)?; + match remove_dir_all(&gemini_destination) { + _ => {} + }; + create_dir_all(&gemini_destination)?; + + // Step 3. Load the layout + let mut file_handler = FileHandler::default(); + match file_handler.get_layout_or_panic(&files) { + Ok(_) => {}, + Err(error) => { + eprintln!("{}", error); + exit(1); + } + } + + // Step 4. Process all files + file_handler.handle_all(&source, &html_destination, &gemini_destination, &files); + Ok(()) }