X-Git-Url: https://git.r.bdr.sh/rbdr/page/blobdiff_plain/7235e9b1b7ad396e68d2657c58aeb1d9147047c4..260e8ec69b8e08b9fd105bf688e7a3a9fafecd61:/src/main.rs diff --git a/src/main.rs b/src/main.rs index fdfe863..533a6bb 100644 --- a/src/main.rs +++ b/src/main.rs @@ -1,8 +1,10 @@ mod gemini_parser; +mod html_renderer; mod file_finder; mod file_handler; use std::io::Result; +use std::process::exit; use std::env::current_dir; use std::fs::{create_dir_all, remove_dir_all}; @@ -13,23 +15,35 @@ fn main() -> Result<()> { let source = current_dir()?; let source_name = source.file_name().unwrap().to_string_lossy(); let parent = source.parent().unwrap(); - let destination_name = format!("{}_html", source_name); - let destination = parent.join(destination_name); + 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(&destination) { + match remove_dir_all(&html_destination) { _ => {} }; - create_dir_all(&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(); - file_handler.get_layout_or_panic(&files); + 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, &destination, &files); + file_handler.handle_all(&source, &html_destination, &gemini_destination, &files); Ok(()) }