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 72 73 74 75 76 77
use crate::utils::pckg; use duckscript::types::command::{Command, CommandResult}; use fs_extra::dir; use fsio::directory::create_parent; 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, "CopyPath") } fn aliases(&self) -> Vec<String> { vec!["cp".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.len() < 2 { CommandResult::Error("Paths not provided.".to_string()) } else { let source_path_str = &arguments[0]; let source_path = Path::new(source_path_str); if !source_path.exists() { CommandResult::Error("Path does not exist.".to_string()) } else { let source_file = source_path.is_file(); let target_path_str = &arguments[1]; if source_file { match create_parent(target_path_str) { Ok(_) => match fs::copy(source_path_str, target_path_str) { Ok(_) => CommandResult::Continue(Some("true".to_string())), Err(error) => CommandResult::Error(error.to_string()), }, Err(error) => CommandResult::Error(error.to_string()), } } else { match fsio::directory::create(target_path_str) { Ok(_) => { let options = dir::CopyOptions::new(); match dir::copy(source_path_str, target_path_str, &options) { Ok(_) => CommandResult::Continue(Some("true".to_string())), Err(error) => CommandResult::Error(error.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(), }) }