#[structopt(name = "hashgood")]
pub struct Opt {
/// Read the hash from the clipboard
+ #[cfg(feature = "paste")]
#[structopt(short = "p", long = "paste")]
paste: bool,
hash: Option<String>,
}
+impl Opt {
+ fn get_paste(&self) -> bool {
+ #[cfg(feature = "paste")] {
+ return self.paste;
+ }
+ #[cfg(not(feature = "paste"))] {
+ return false;
+ }
+ }
+}
+
/// Types of supported digest algorithm
#[derive(Debug, PartialEq, Copy, Clone)]
pub enum Algorithm {
fn get_verified_options() -> Result<Opt, String> {
let opt = Opt::from_args();
let hash_methods =
- opt.hash.is_some() as i32 + opt.paste as i32 + opt.hash_file.is_some() as i32;
+ opt.hash.is_some() as i32 + opt.get_paste() as i32 + opt.hash_file.is_some() as i32;
if hash_methods > 1 {
if opt.hash.is_some() {
eprintln!("* specified as command line argument");
}
- if opt.paste {
+ if opt.get_paste() {
eprintln!("* paste from clipboard (-p)")
}
if opt.hash_file.is_some() {
Algorithm, CandidateHash, CandidateHashes, Hash, MatchLevel, MessageLevel, Opt, Verification,
VerificationSource,
};
-use clipboard::ClipboardContext;
-use clipboard::ClipboardProvider;
+#[cfg(feature = "paste")]
+use clipboard::{ClipboardContext, ClipboardProvider};
use regex::Regex;
use std::fs::File;
use std::io;
pub fn get_candidate_hashes(opt: &Opt) -> Result<Option<CandidateHashes>, String> {
if let Some(hash_string) = &opt.hash {
return Ok(Some(get_by_parameter(hash_string)?));
- } else if opt.paste {
+ } else if opt.get_paste() {
return Ok(Some(get_from_clipboard()?));
} else if let Some(hash_file) = &opt.hash_file {
return Ok(Some(get_from_file(hash_file)?));
/// Generate a candidate hash from the system clipboard, or throw an error.
fn get_from_clipboard() -> Result<CandidateHashes, String> {
- let mut ctx: ClipboardContext = match ClipboardProvider::new() {
- Ok(ctx) => ctx,
- Err(e) => return Err(format!("Error getting system clipboard: {}", e)),
- };
-
- let possible_hash = match ctx.get_contents() {
- Ok(value) => value,
- Err(e) => format!("Error reading from clipboard: {}", e),
- };
-
- let bytes = hex::decode(&possible_hash)
- .map_err(|_| "Clipboard contains invalid or truncated hex".to_owned())?;
- let alg = Algorithm::from_len(bytes.len())?;
- let candidate = CandidateHash {
- filename: None,
- bytes,
- };
- Ok(CandidateHashes {
- alg,
- hashes: vec![candidate],
- source: VerificationSource::Clipboard,
- })
+ #[cfg(feature = "paste")] {
+ let mut ctx: ClipboardContext = match ClipboardProvider::new() {
+ Ok(ctx) => ctx,
+ Err(e) => return Err(format!("Error getting system clipboard: {}", e)),
+ };
+
+ let possible_hash = match ctx.get_contents() {
+ Ok(value) => value,
+ Err(e) => format!("Error reading from clipboard: {}", e),
+ };
+
+ let bytes = hex::decode(&possible_hash)
+ .map_err(|_| "Clipboard contains invalid or truncated hex".to_owned())?;
+ let alg = Algorithm::from_len(bytes.len())?;
+ let candidate = CandidateHash {
+ filename: None,
+ bytes,
+ };
+ return Ok(CandidateHashes {
+ alg,
+ hashes: vec![candidate],
+ source: VerificationSource::Clipboard,
+ });
+ }
+ #[cfg(not(feature = "paste"))] {
+ return Err("Paste not implemented".to_owned());
+ }
}
/// Generate a candidate hash from the digests file specified (could be "-" for STDIN), or throw an error.