|
@ -10,29 +10,28 @@ extern crate docopt; |
|
|
use std::path::Path;
|
|
|
use std::path::Path;
|
|
|
use docopt::Docopt;
|
|
|
use docopt::Docopt;
|
|
|
|
|
|
|
|
|
|
|
|
// Getting the version information from cargo during compile time
|
|
|
|
|
|
const VERSION: &'static str = env!("CARGO_PKG_VERSION");
|
|
|
|
|
|
|
|
|
// The usage description
|
|
|
// The usage description
|
|
|
const USAGE: &'static str = "
|
|
|
const USAGE: &'static str = "
|
|
|
Perceptual Image Hashing (pihash)
|
|
|
Perceptual Image Hashing (pihash)
|
|
|
|
|
|
|
|
|
Usage: |
|
|
Usage: |
|
|
pihash [options] \
|
|
|
|
|
|
<path>...
|
|
|
|
|
|
|
|
|
pihash [options] <path>...
|
|
|
pihash (--help | --version)
|
|
|
pihash (--help | --version)
|
|
|
|
|
|
|
|
|
Options: |
|
|
Options: |
|
|
-h, --help \
|
|
|
|
|
|
Show this screen.
|
|
|
|
|
|
|
|
|
-h, --help Show this screen.
|
|
|
-V, --version Print version.
|
|
|
-V, --version Print version.
|
|
|
-a, \
|
|
|
|
|
|
--ahash Include an ahash calculation.
|
|
|
|
|
|
-d, --dhash \
|
|
|
|
|
|
Include an dhash calculation.
|
|
|
|
|
|
-p, --phash Include an phash \
|
|
|
|
|
|
calculation.
|
|
|
|
|
|
|
|
|
-a, --ahash Include an ahash calculation.
|
|
|
|
|
|
-d, --dhash Include an dhash calculation.
|
|
|
|
|
|
-p, --phash Include an phash calculation.
|
|
|
";
|
|
|
";
|
|
|
|
|
|
|
|
|
#[derive(Debug, RustcDecodable)]
|
|
|
#[derive(Debug, RustcDecodable)]
|
|
|
struct Args {
|
|
|
struct Args {
|
|
|
|
|
|
flag_version: bool,
|
|
|
flag_ahash: bool,
|
|
|
flag_ahash: bool,
|
|
|
flag_dhash: bool,
|
|
|
flag_dhash: bool,
|
|
|
flag_phash: bool,
|
|
|
flag_phash: bool,
|
|
@ -43,10 +42,18 @@ fn main() { |
|
|
let args: Args = Docopt::new(USAGE)
|
|
|
let args: Args = Docopt::new(USAGE)
|
|
|
.and_then(|d| d.decode())
|
|
|
.and_then(|d| d.decode())
|
|
|
.unwrap_or_else(|e| e.exit());
|
|
|
.unwrap_or_else(|e| e.exit());
|
|
|
|
|
|
|
|
|
|
|
|
// Print version information and exit
|
|
|
|
|
|
if args.flag_version {
|
|
|
|
|
|
println!("Perceptual Image Hashing: v{}", VERSION);
|
|
|
|
|
|
std::process::exit(0);
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
// Init the hashing library
|
|
|
// Init the hashing library
|
|
|
pihash::init();
|
|
|
pihash::init();
|
|
|
|
|
|
|
|
|
// println!("{:?}", args);
|
|
|
// println!("{:?}", args);
|
|
|
|
|
|
|
|
|
// All flags set or, no flags set
|
|
|
// All flags set or, no flags set
|
|
|
if (args.flag_ahash && args.flag_dhash && args.flag_phash) ||
|
|
|
if (args.flag_ahash && args.flag_dhash && args.flag_phash) ||
|
|
|
(!args.flag_ahash && !args.flag_dhash && !args.flag_phash) {
|
|
|
(!args.flag_ahash && !args.flag_dhash && !args.flag_phash) {
|
|
@ -62,7 +69,8 @@ fn main() { |
|
|
hashes.orig_path,
|
|
|
hashes.orig_path,
|
|
|
hashes.ahash,
|
|
|
hashes.ahash,
|
|
|
hashes.dhash,
|
|
|
hashes.dhash,
|
|
|
hashes.phash);
|
|
|
|
|
|
|
|
|
hashes.phash
|
|
|
|
|
|
);
|
|
|
println!("{}", hash_result);
|
|
|
println!("{}", hash_result);
|
|
|
}
|
|
|
}
|
|
|
// Otherwise process only specific hashes
|
|
|
// Otherwise process only specific hashes
|
|
|