diff --git a/src/comparemode.rs b/src/comparemode.rs new file mode 100644 index 0000000..b31a077 --- /dev/null +++ b/src/comparemode.rs @@ -0,0 +1,24 @@ +use Fasching::hasher::HashType::BLAKE3; +use Fasching::snapshot::{Snapshot, SnapshotCompareResult}; +use crate::syscompare::Comparer; + +pub struct CompareMode { + left: Snapshot, + right: Snapshot, + args: Vec, + results: SnapshotCompareResult +} + +impl CompareMode { + pub fn new(args: Vec, in_path: String, out_path: String) -> CompareMode { + + + CompareMode { in_path, out_path, args, snapshot: Default::default() } + } +} + +impl Comparer for CompareMode { + fn run(&self) { + + } +} diff --git a/src/main.rs b/src/main.rs index b4e7d16..56967cd 100644 --- a/src/main.rs +++ b/src/main.rs @@ -1,5 +1,6 @@ pub mod syscompare; -mod createmode; +pub mod createmode; +pub mod comparemode; use std::env::args; use crate::syscompare::{SysCompareApp}; diff --git a/src/syscompare.rs b/src/syscompare.rs index 31a1c4a..d27e90c 100644 --- a/src/syscompare.rs +++ b/src/syscompare.rs @@ -26,16 +26,30 @@ impl SysCompareApp { CompareMode::Create => { let in_path = match self.args.get(2) { None => {panic!("Missing hash dir path as second argument")} - Some(r) => {r} + Some(r) => { + if r.replace("./", "").is_empty() { + panic!("Specify input file name") + } else { + r + } + } }; let out_path = match self.args.get(3) { None => {panic!("Missing output path as third argument")} - Some(r) => {r} + Some(r) => { + if r.replace("./", "").is_empty() { + panic!("Specify out path file name") + } else { + r + } + } }; let create = CreateMode::new(self.args.clone(), in_path.clone(), out_path.clone()); create.run() } - CompareMode::Compare => {} + CompareMode::Compare => { + + } } } }