X-Git-Url: https://git.r.bdr.sh/rbdr/blog/blobdiff_plain/d620665f6b2e1ae5db4c98a09e35bd63133ae87f..172f4c8807d44ebe38c7f227b7fdc2d6a9dbe323:/src/main.rs diff --git a/src/main.rs b/src/main.rs index cb258c2..8867dc0 100644 --- a/src/main.rs +++ b/src/main.rs @@ -1,27 +1,48 @@ // mod argument_parser; mod configuration; mod command; +mod constants; +mod gemini_parser; +mod generator; +mod archiver; +mod metadata; +mod post; +mod template; +mod utils; +mod remote; +use std::iter::once; use std::env::args; use std::io::Result; -use configuration::Configuration; use command::{available_commands, Command, help::Help}; +use configuration::Configuration; fn main() -> Result<()> { let configuration = Configuration::new(); let commands = available_commands(); - - println!("CONFIGURATION DIRECTORY: {}", configuration.config_directory.display()); - println!("DATA DIRECTORY: {}", configuration.data_directory.display()); - println!("OUTPUT DIRECTORY: {}", configuration.output_directory.display()); - let arguments: Vec = args().collect(); if let Some(command_name) = arguments.get(1) { - if let Some(command) = commands.iter().find(|&c| c.command() == command_name) { - return command.execute(arguments.get(2)); + if let Some(main_command) = commands.into_iter().find(|c| c.command() == command_name) { + let before_commands = main_command.before_dependencies(); + let after_commands = main_command.after_dependencies(); + + let command_chain: Vec> = before_commands + .into_iter() + .chain(once(main_command)) + .chain(after_commands.into_iter()) + .collect(); + + for command in command_chain { + let result = command.execute(arguments.get(2), &configuration, command_name); + if let Err(_) = result { + return result; + } + } + + return Ok(()) } } - Help::new().execute(None) + Help::new().execute(None, &configuration, &"help".to_string()) }