#digest #xx-hash #hash #fnv #xxh3

noncrypto-digests

Implement Digest trait for non-cryptographic hashing functions like fnv and xxhash

4 releases

0.3.1 Dec 21, 2023
0.3.0 Dec 21, 2023
0.2.3 Dec 20, 2023
0.1.0 Dec 8, 2023

#873 in Cryptography

Download history 41/week @ 2023-12-18 1/week @ 2024-01-22 44/week @ 2024-01-29 37/week @ 2024-02-05 77/week @ 2024-02-12 33/week @ 2024-02-19 117/week @ 2024-02-26 27/week @ 2024-03-04 29/week @ 2024-03-11 138/week @ 2024-03-18 111/week @ 2024-03-25 174/week @ 2024-04-01

453 downloads per month
Used in 2 crates (via sqlite-hashes)

MIT/Apache

13KB
227 lines

noncrypto-digests

GitHub crates.io version docs.rs docs crates.io version CI build

Implement digest::Digest trait for non-cryptographic hashing functions like fnv and xxhash. This allows users to use all cryptographic and non-cryptographic hashing functions polymorphically.

Usage

use digest::Digest;
use hex::ToHex;
use noncrypto_digests::{Fnv, Xxh3_64, Xxh3_128, Xxh32, Xxh64};

/// This function takes any Digest type, and returns a hex-encoded string.
pub fn hash<T: Digest>(data: impl AsRef<[u8]>) -> String {
  // Note that some hashers provide seed value set to 0 by default.
  // Use `...::from_hasher(hasher)` function to instantiate them.
  let mut hasher = T::new();
  hasher.update(data);
  hasher.finalize().to_vec().encode_hex_upper()
}

fn main() {
  assert_eq!(hash::<Fnv>("password"), "4B1A493507B3A318");
  assert_eq!(hash::<Xxh3_64>("password"), "336576D7E0E06F9A");
  assert_eq!(hash::<Xxh3_128>("password"), "9CFA9055952177DA0B120BE86072A8F0");
  assert_eq!(hash::<Xxh32>("password"), "106C6CED");
  assert_eq!(hash::<Xxh64>("password"), "90007DAF3980EF1F");
}

Development

  • This project is easier to develop with just, a modern alternative to make. Install it with cargo install just.
  • To get a list of available commands, run just.
  • To run tests, use just test.
  • On git push, it will run a few validations, including cargo fmt, cargo clippy, and cargo test. Use git push --no-verify to skip these checks.

License

Licensed under either of

Contribution

Unless you explicitly state otherwise, any contribution intentionally submitted for inclusion in the work by you, as defined in the Apache-2.0 license, shall be dual licensed as above, without any additional terms or conditions.

Dependencies

~365KB