1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71
use crate::utils::{flags, pckg}; use duckscript::types::command::{Command, CommandResult}; use std::fs; use std::path::Path; #[cfg(test)] #[path = "./mod_test.rs"] mod mod_test; #[derive(Clone)] pub(crate) struct CommandImpl { package: String, } impl Command for CommandImpl { fn name(&self) -> String { pckg::concat(&self.package, "DeletePath") } fn aliases(&self) -> Vec<String> { vec!["rm".to_string()] } fn help(&self) -> String { include_str!("help.md").to_string() } fn clone_and_box(&self) -> Box<dyn Command> { Box::new((*self).clone()) } fn run(&self, arguments: Vec<String>) -> CommandResult { if arguments.is_empty() || (arguments.len() == 1 && flags::is_unix_flags_argument(&arguments[0])) { CommandResult::Error("Path not provided.".to_string()) } else { let (path_str, recursive) = if arguments.len() == 1 { (&arguments[0], false) } else if flags::is_unix_flags_argument(&arguments[0]) { let recursive = flags::is_unix_flag_exists('r', &arguments[0]); (&arguments[1], recursive) } else { (&arguments[0], false) }; let path = Path::new(path_str); let result = if !path.exists() { Ok(()) } else if path.is_file() { fs::remove_file(&arguments[0]) } else if recursive { fs::remove_dir_all(&path) } else { fs::remove_dir(&path) }; match result { Ok(_) => CommandResult::Continue(Some("true".to_string())), Err(error) => CommandResult::Error(error.to_string()), } } } } pub(crate) fn create(package: &str) -> Box<dyn Command> { Box::new(CommandImpl { package: package.to_string(), }) }