summaryrefslogtreecommitdiffstats
path: root/libimagref/src/hasher.rs
blob: fcdda5bde239e56405f86d0a4f728ab241f22f9d (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
use std::path::PathBuf;
use std::io::Read;

use error::RefErrorKind as REK;
use error::MapErrInto;

use crypto::sha1::Sha1;
use crypto::digest::Digest;

use result::Result;

/// The Hasher trait is used to implement custom hashing functions for the ref library.
/// This means that one can define how the hash of a reference is constructed from the content of
/// the file to ref to.
pub trait Hasher {

    fn hash_name(&self) -> &'static str;
    fn create_hash<R: Read>(&mut self, pb: &PathBuf, contents: &mut R) -> Result<String>;

}

pub struct DefaultHasher {
    hasher: Sha1,
}

impl DefaultHasher {

    pub fn new() -> DefaultHasher {
        DefaultHasher { hasher: Sha1::new() }
    }

}

impl Hasher for DefaultHasher {

    fn hash_name(&self) -> &'static str {
        "default"
    }

    fn create_hash<R: Read>(&mut self, _: &PathBuf, c: &mut R) -> Result<String> {
        let mut s = String::new();
        try!(c.read_to_string(&mut s).map_err_into(REK::UTF8Error).map_err_into(REK::IOError));
        self.hasher.input_str(&s[..]);
        Ok(self.hasher.result_str())
    }

}