X-Git-Url: https://git.r.bdr.sh/rbdr/page/blobdiff_plain/1e2d00b62ecce95f71d4bfd60a043c8e86631eee..d843a0b2c2590b96781a6c12af6c856b8056bf64:/src/main.rs diff --git a/src/main.rs b/src/main.rs index 4b8a79f..fc085d8 100644 --- a/src/main.rs +++ b/src/main.rs @@ -2,16 +2,47 @@ mod gemini_parser; 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}; -use crate::gemini_parser::parse; use crate::file_finder::find_files; +use crate::file_handler::FileHandler; -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); +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); - let files = find_files(current_dir().unwrap()); - println!("Found {} files", files.len()); + // 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(()) }