use super::Algorithm;
-use crossbeam_channel::bounded;
-use crossbeam_channel::Receiver;
use md5::{Digest, Md5};
use sha1::Sha1;
use sha2::Sha256;
+use sha2::Sha512;
use std::error::Error;
use std::fs::File;
use std::io::prelude::*;
use std::path::Path;
+use std::sync::mpsc::{channel, Receiver};
use std::sync::Arc;
use std::thread;
use std::thread::JoinHandle;
let mut handles = vec![];
if algorithms.contains(&Algorithm::Md5) {
- let (s, r) = bounded::<Arc<Vec<u8>>>(1);
+ let (s, r) = channel();
senders.push(s);
handles.push(md5_digest(r));
}
if algorithms.contains(&Algorithm::Sha1) {
- let (s, r) = bounded::<Arc<Vec<u8>>>(1);
+ let (s, r) = channel();
senders.push(s);
handles.push(sha1_digest(r));
}
if algorithms.contains(&Algorithm::Sha256) {
- let (s, r) = bounded::<Arc<Vec<u8>>>(1);
+ let (s, r) = channel();
senders.push(s);
handles.push(sha256_digest(r));
}
+ if algorithms.contains(&Algorithm::Sha512) {
+ let (s, r) = channel();
+ senders.push(s);
+ handles.push(sha512_digest(r));
+ }
// 64 KB chunks will be read from the input at 64 KB and supplied to all hashing threads at once
// Right now that could be up to three threads. If CPU-bound, the other threads will mostly block while the slowest one finishes
})
}
+/// Calculate the sha512 digest of some data on the given channel
+fn sha512_digest(rx: Receiver<Arc<Vec<u8>>>) -> JoinHandle<(Algorithm, Vec<u8>)> {
+ thread::spawn(move || {
+ let mut sha512 = Sha512::new();
+ while let Ok(chunk) = rx.recv() {
+ sha512.update(&*chunk);
+ }
+ let result = sha512.finalize();
+ (Algorithm::Sha512, result.to_vec())
+ })
+}
+
#[cfg(test)]
mod tests {
use super::*;