feat: v1.12.0
This commit is contained in:
@@ -5,7 +5,7 @@ use std::io::Read;
|
||||
use clap::ArgMatches;
|
||||
use rust_util::XResult;
|
||||
|
||||
use crate::digestutil::{sha256, sha256_bytes};
|
||||
use crate::digestutil::DigestAlgorithm;
|
||||
|
||||
|
||||
pub fn get_sha256_digest_or_hash(sub_arg_matches: &ArgMatches) -> XResult<Vec<u8>> {
|
||||
@@ -13,6 +13,10 @@ pub fn get_sha256_digest_or_hash(sub_arg_matches: &ArgMatches) -> XResult<Vec<u8
|
||||
}
|
||||
|
||||
pub fn get_sha256_digest_or_hash_with_file_opt(sub_arg_matches: &ArgMatches, file_opt: &Option<String>) -> XResult<Vec<u8>> {
|
||||
get_digest_or_hash_with_file_opt(sub_arg_matches, file_opt, DigestAlgorithm::Sha256)
|
||||
}
|
||||
|
||||
pub fn get_digest_or_hash_with_file_opt(sub_arg_matches: &ArgMatches, file_opt: &Option<String>, digest: DigestAlgorithm) -> XResult<Vec<u8>> {
|
||||
let file_opt = file_opt.as_ref().map(String::as_str);
|
||||
if let Some(file) = sub_arg_matches.value_of("file").or(file_opt) {
|
||||
let metadata = opt_result!(fs::metadata(file), "Read file: {} metadata filed: {}", file);
|
||||
@@ -28,9 +32,9 @@ pub fn get_sha256_digest_or_hash_with_file_opt(sub_arg_matches: &ArgMatches, fil
|
||||
let mut f = opt_result!(File::open(file), "Open file: {} failed: {}", file);
|
||||
let mut content = vec![];
|
||||
opt_result!(f.read_to_end(&mut content), "Read file: {} failed: {}", file);
|
||||
Ok(sha256_bytes(&content))
|
||||
Ok(digest.digest(&content))
|
||||
} else if let Some(input) = sub_arg_matches.value_of("input") {
|
||||
Ok(sha256(input))
|
||||
Ok(digest.digest_str(input))
|
||||
} else if let Some(hash_hex) = sub_arg_matches.value_of("hash-hex") {
|
||||
Ok(opt_result!(hex::decode(hash_hex), "Parse hash-hex failed: {}"))
|
||||
} else {
|
||||
|
||||
Reference in New Issue
Block a user