2 Commits
v0.2 ... v0.2.1

Author SHA1 Message Date
54500810a0 v0.2.1 2025-10-17 14:01:13 +03:00
c93bf8f1d2 v0.2 2025-10-17 13:51:38 +03:00
2 changed files with 16 additions and 28 deletions

View File

@@ -2,6 +2,7 @@ mod utils;
use clap::Parser;
use std::collections::HashMap;
use std::fmt::format;
use std::io::Write;
use std::{fs, io, time};
use utils::{Metadata, Zsdiff, get_hash};
@@ -20,38 +21,26 @@ async fn walk_dir(dir: String) -> HashMap<String, FileInfo> {
for e in WalkDir::new(&dir) {
let e = e.unwrap();
let path = e.path();
println!(
"Path: {}, {}",
path.display(),
path.display().to_string().eq(&dir)
);
if path.display().to_string().eq(&dir) {
continue;
}
let content: Vec<u8>;
if path.is_dir() {
let path_str = path.display().to_string();
let hash = get_hash(path_str.clone().into_bytes()).await;
let file_info = FileInfo {
relative_path: path_str[dir.len() + 1..].to_string(),
path: path_str,
hash: hash.clone(),
is_dir: true,
};
hash_list.entry(hash).or_insert(file_info);
content = path_str.into_bytes();
} else {
let content = fs::read(path).unwrap();
let hash = get_hash(content).await;
let path_str = path.display().to_string();
let file_info = FileInfo {
relative_path: path_str[dir.len() + 1..].to_string(),
path: path_str,
hash: hash.clone(),
is_dir: false,
};
hash_list.entry(hash).or_insert(file_info);
content = fs::read(path).unwrap();
}
let hash = get_hash(content).await;
let path_str = path.display().to_string();
let file_info = FileInfo {
relative_path: path_str[dir.len() + 1..].to_string(),
path: path_str,
hash: hash.clone(),
is_dir: path.is_dir(),
};
hash_list.entry(hash).or_insert(file_info);
}
println!("{:?}", hash_list);
hash_list
}
@@ -77,7 +66,6 @@ async fn compare_hashes(old: HashMap<String, FileInfo>, new: HashMap<String, Fil
}
if new_fileinfo.is_dir {
println!("{}", new_fileinfo.is_dir);
continue;
}
@@ -121,7 +109,7 @@ pub async fn zsdiff(
utils::compress_parts(parts, &fs::File::create(output_filename)?, level).await;
let output_data = fs::read(output_filename)?;
let size_after = output_data.len();
let output_hash = get_hash(output_data).await;
let output_hash = format!("{} {}", get_hash(output_data).await, output_filename);
fs::File::create(format!("{}.md5", output_filename))?.write_all(output_hash.as_bytes())?;
let elapsed = now.elapsed();
println!("Zsdiff hash: {}", output_hash);

View File

@@ -34,9 +34,9 @@ async fn extract_files(zsdiff: &Zsdiff, filename: String) -> Result<String, io::
async fn check_hash(filename: String) -> Result<(), io::Error> {
let file_data = read(format!("{}.zdiff", filename))?;
let hash_file = read(format!("{}.zdiff.md5", filename))?;
let hash_file = String::from_utf8(read(format!("{}.zdiff.md5", filename))?).unwrap();
let hash = utils::get_hash(file_data).await;
if !String::from_utf8(hash_file).unwrap().eq(&hash) {
if !hash_file.split(" ").next().unwrap().eq(&hash) {
return Err(io::Error::new(io::ErrorKind::Other, "Hash mismatch"));
}
println!("Zsdiff hash: {}", hash);