From 6155cda40da740f46cb1c147e41f8f44a357cdcb Mon Sep 17 00:00:00 2001 From: Magic Len Date: Thu, 9 Nov 2023 11:41:34 +0800 Subject: [PATCH] improve cli --- Cargo.toml | 2 +- README.md | 5 +++-- src/cli.rs | 35 +++++++++++++++++++++++++++++++++-- 3 files changed, 37 insertions(+), 5 deletions(-) diff --git a/Cargo.toml b/Cargo.toml index 07e337d..5506381 100644 --- a/Cargo.toml +++ b/Cargo.toml @@ -1,6 +1,6 @@ [package] name = "xcompress" -version = "0.12.2" +version = "0.12.3" authors = ["Magic Len "] edition = "2021" rust-version = "1.70" diff --git a/README.md b/README.md index b0af6a8..1f6a0c0 100644 --- a/README.md +++ b/README.md @@ -13,6 +13,7 @@ xcompress a foo.wav # Archive foo.wav to foo.rar xcompress a foo.wav /root/bar.txt # Archive foo.wav and /root/bar.txt to foo.rar xcompress a -o /tmp/out.7z foo.wav # Archive foo.wav to /tmp/out.7z xcompress a -b foo/bar # Archive foo/bar folder to bar.rar as small as possible +xcompress a -f foo/bar -r 5 # Archive foo/bar folder to bar.rar as fast as possible and add 5% recovery record xcompress a -p password foo.wav # Archive foo.wav to foo.rar with a password xcompress x foo.rar # Extract foo.rar into current working directory xcompress x foo.tar.gz /tmp/out_folder # Extract foo.tar.gz into /tmp/out_folder @@ -28,7 +29,7 @@ Commands: Options: -q, --quiet Make programs not print anything on the screen -s, --single-thread Use only one thread - -p, --password Set password for your archive file. (Only supports 7Z, ZIP and RAR) Set an empty string to read a password from stdin + -p, --password [] Set password for your archive file. (Only supports 7Z, ZIP and RAR) Set an empty string to read a password from stdin --compress-path Specify the path of your compress executable binary file [default: compress] --zip-path Specify the path of your zip executable binary file [default: zip] --unzip-path Specify the path of your unzip executable binary file [default: unzip] @@ -47,7 +48,7 @@ Options: --pxz-path Specify the path of your pxz executable binary file [default: pxz] --lzma-path Specify the path of your lzma executable binary file [default: lzma] --unlzma-path Specify the path of your unlzma executable binary file [default: unlzma] - --7Z_PATH Specify the path of your 7z executable binary file [default: 7z] + --7z-path <7z-path> Specify the path of your 7z executable binary file [default: 7z] --tar-path Specify the path of your tar executable binary file [default: tar] --rar-path Specify the path of your rar executable binary file [default: rar] --unrar-path Specify the path of your unrar executable binary file [default: unrar] diff --git a/src/cli.rs b/src/cli.rs index fcc2e02..c5b4f99 100644 --- a/src/cli.rs +++ b/src/cli.rs @@ -88,150 +88,176 @@ pub struct ExecutablePaths { #[arg(long)] #[arg(global = true)] #[arg(default_value = DEFAULT_COMPRESS_PATH)] + #[arg(value_hint = clap::ValueHint::CommandName)] #[arg(help = "Specify the path of your compress executable binary file")] pub compress_path: String, #[arg(long)] #[arg(global = true)] #[arg(default_value = DEFAULT_ZIP_PATH)] + #[arg(value_hint = clap::ValueHint::CommandName)] #[arg(help = "Specify the path of your zip executable binary file")] pub zip_path: String, #[arg(long)] #[arg(global = true)] #[arg(default_value = DEFAULT_UNZIP_PATH)] + #[arg(value_hint = clap::ValueHint::CommandName)] #[arg(help = "Specify the path of your unzip executable binary file")] pub unzip_path: String, #[arg(long)] #[arg(global = true)] #[arg(default_value = DEFAULT_GZIP_PATH)] + #[arg(value_hint = clap::ValueHint::CommandName)] #[arg(help = "Specify the path of your gzip executable binary file")] pub gzip_path: String, #[arg(long)] #[arg(global = true)] #[arg(default_value = DEFAULT_GUNZIP_PATH)] + #[arg(value_hint = clap::ValueHint::CommandName)] #[arg(help = "Specify the path of your gunzip executable binary file")] pub gnuzip_path: String, #[arg(long)] #[arg(global = true)] #[arg(default_value = DEFAULT_PIGZ_PATH)] + #[arg(value_hint = clap::ValueHint::CommandName)] #[arg(help = "Specify the path of your pigz executable binary file")] pub pigz_path: String, #[arg(long)] #[arg(global = true)] #[arg(default_value = DEFAULT_BZIP2_PATH)] + #[arg(value_hint = clap::ValueHint::CommandName)] #[arg(help = "Specify the path of your bzip2 executable binary file")] pub bzip2_path: String, #[arg(long)] #[arg(global = true)] #[arg(default_value = DEFAULT_BUNZIP2_PATH)] + #[arg(value_hint = clap::ValueHint::CommandName)] #[arg(help = "Specify the path of your bunzip2 executable binary file")] pub bunzip2_path: String, #[arg(long)] #[arg(global = true)] #[arg(default_value = DEFAULT_LBZIP2_PATH)] + #[arg(value_hint = clap::ValueHint::CommandName)] #[arg(help = "Specify the path of your lbzip2 executable binary file")] pub lbzip2_path: String, #[arg(long)] #[arg(global = true)] #[arg(default_value = DEFAULT_PBZIP2_PATH)] + #[arg(value_hint = clap::ValueHint::CommandName)] #[arg(help = "Specify the path of your pbzip2 executable binary file")] pub pbzip2_path: String, #[arg(long)] #[arg(global = true)] #[arg(default_value = DEFAULT_LZIP_PATH)] + #[arg(value_hint = clap::ValueHint::CommandName)] #[arg(help = "Specify the path of your lzip executable binary file")] pub lzip_path: String, #[arg(long)] #[arg(global = true)] #[arg(default_value = DEFAULT_LUNZIP_PATH)] + #[arg(value_hint = clap::ValueHint::CommandName)] #[arg(help = "Specify the path of your lunzip executable binary file")] pub lunzip_path: String, #[arg(long)] #[arg(global = true)] #[arg(default_value = DEFAULT_PLZIP_PATH)] + #[arg(value_hint = clap::ValueHint::CommandName)] #[arg(help = "Specify the path of your plzip executable binary file")] pub plzip_path: String, #[arg(long)] #[arg(global = true)] #[arg(default_value = DEFAULT_XZ_PATH)] + #[arg(value_hint = clap::ValueHint::CommandName)] #[arg(help = "Specify the path of your xz executable binary file")] pub xz_path: String, #[arg(long)] #[arg(global = true)] #[arg(default_value = DEFAULT_UNXZ_PATH)] + #[arg(value_hint = clap::ValueHint::CommandName)] #[arg(help = "Specify the path of your unxz executable binary file")] pub unxz_path: String, #[arg(long)] #[arg(global = true)] #[arg(default_value = DEFAULT_PXZ_PATH)] + #[arg(value_hint = clap::ValueHint::CommandName)] #[arg(help = "Specify the path of your pxz executable binary file")] pub pxz_path: String, #[arg(long)] #[arg(global = true)] #[arg(default_value = DEFAULT_LZMA_PATH)] + #[arg(value_hint = clap::ValueHint::CommandName)] #[arg(help = "Specify the path of your lzma executable binary file")] pub lzma_path: String, #[arg(long)] #[arg(global = true)] #[arg(default_value = DEFAULT_UNLZMA_PATH)] + #[arg(value_hint = clap::ValueHint::CommandName)] #[arg(help = "Specify the path of your unlzma executable binary file")] pub unlzma_path: String, - #[arg(long = "7Z_PATH")] + #[arg(name = "7z-path")] + #[arg(long)] #[arg(global = true)] #[arg(default_value = DEFAULT_7Z_PATH)] + #[arg(value_hint = clap::ValueHint::CommandName)] #[arg(help = "Specify the path of your 7z executable binary file")] pub p7z_path: String, #[arg(long)] #[arg(global = true)] #[arg(default_value = DEFAULT_TAR_PATH)] + #[arg(value_hint = clap::ValueHint::CommandName)] #[arg(help = "Specify the path of your tar executable binary file")] pub tar_path: String, #[arg(long)] #[arg(global = true)] #[arg(default_value = DEFAULT_RAR_PATH)] + #[arg(value_hint = clap::ValueHint::CommandName)] #[arg(help = "Specify the path of your rar executable binary file")] pub rar_path: String, #[arg(long)] #[arg(global = true)] #[arg(default_value = DEFAULT_UNRAR_PATH)] + #[arg(value_hint = clap::ValueHint::CommandName)] #[arg(help = "Specify the path of your unrar executable binary file")] pub unrar_path: String, #[arg(long)] #[arg(global = true)] #[arg(default_value = DEFAULT_ZSTD_PATH)] + #[arg(value_hint = clap::ValueHint::CommandName)] #[arg(help = "Specify the path of your zstd executable binary file")] pub zstd_path: String, #[arg(long)] #[arg(global = true)] #[arg(default_value = DEFAULT_UNZSTD_PATH)] + #[arg(value_hint = clap::ValueHint::CommandName)] #[arg(help = "Specify the path of your unzstd executable binary file")] pub unzstd_path: String, #[arg(long)] #[arg(global = true)] #[arg(default_value = DEFAULT_PZSTD_PATH)] + #[arg(value_hint = clap::ValueHint::CommandName)] #[arg(help = "Specify the path of your pzstd executable binary file")] pub pzstd_path: String, } @@ -241,14 +267,17 @@ pub enum CLICommands { #[command(about = "Extract files with full path")] #[command(after_help = AFTER_HELP)] X { + #[arg(value_hint = clap::ValueHint::FilePath)] #[arg( help = "Assign the source of your original files. It should be at least one file path" )] input_path: PathBuf, - #[arg(help = "Assign a destination of your extracted files. It should be a directory path")] + #[arg(value_hint = clap::ValueHint::DirPath)] #[arg(conflicts_with = "output")] + #[arg(help = "Assign a destination of your extracted files. It should be a directory path")] output_path: Option, #[arg(short, long)] + #[arg(value_hint = clap::ValueHint::DirPath)] #[arg(conflicts_with = "output_path")] #[arg(help = "Assign a destination of your extracted files. It should be a directory path")] output: Option, @@ -259,11 +288,13 @@ pub enum CLICommands { #[command(after_help = AFTER_HELP)] A { #[arg(required = true)] + #[arg(value_hint = clap::ValueHint::AnyPath)] #[arg( help = "Assign the source of your original files. It should be at least one file path" )] input_paths: Vec, #[arg(short, long)] + #[arg(value_hint = clap::ValueHint::FilePath)] #[arg(help = "Assign a destination of your extracted files. It should be a file path. \ Specify the file extension name in order to determine which archive \ format you want to use. [default archive format: RAR]")]