#hash #deterministic #no-std

no-std deterministic-hash

Create deterministic hashes regardless of architecture

2 stable releases

1.0.1 Jul 12, 2021

#1278 in Cryptography

Download history 56/week @ 2024-01-01 228/week @ 2024-01-08 67/week @ 2024-01-15 82/week @ 2024-01-22 225/week @ 2024-01-29 149/week @ 2024-02-05 243/week @ 2024-02-12 237/week @ 2024-02-19 138/week @ 2024-02-26 55/week @ 2024-03-04 84/week @ 2024-03-11 256/week @ 2024-03-18 98/week @ 2024-03-25 125/week @ 2024-04-01 172/week @ 2024-04-08 97/week @ 2024-04-15

493 downloads per month
Used in 5 crates (4 directly)

MIT license

6KB
65 lines

deterministic-hash

Tiny Rust library to create deterministic hashes regardless of architecture. This library is no-std compatible and uses no allocations or dependencies.

The default core::hash::Hasher implementation ensures a platform dependant hashing of datastructures that use #[derive(Hash)]. Most notably by:

  • using to_ne_bytes for u{8,16,32,64,128}.
  • using the native bytelength of usize.

The DeterministicHasher of this library forces the use of to_le_bytes and casts usize to u64 regardless of your platform. Hence the hasher will be less efficient, but will be deterministic when using the same library in different architecture contexts. I use a common dataprotocol library both on ARM embedded systems, wasm and x64.

You can validate the operation of this library with cross by running:

cargo install cross
cross test --target=x86_64-unknown-linux-gnu
cross test --target=aarch64-unknown-linux-gnu
cross test --target=arm-unknown-linux-gnueabihf

lib.rs:

Tiny Rust library to create deterministic hashes regardless of architecture. This library is no-std compatible and uses no allocations or dependencies.

The default core::hash::Hasher implementation ensures a platform dependant hashing of datastructures that use #[derive(Hash)]. Most notably by:

  • using to_ne_bytes for u{8,16,32,64,128}.
  • using the native bytelength of usize.

The DeterministicHasher of this library forces the use of to_le_bytes and casts usize to u64 regardless of your platform. Hence the hasher will be less efficient, but will be deterministic when using the same library in different architecture contexts. I use a common dataprotocol library both on ARM embedded systems, wasm and x64.

From any hasher make it deterministic by inserting DeterministicHasher in between:

let hasher = crc::crc32::Digest::new(crc::crc32::KOOPMAN);
let hasher = deterministic_hash::DeterministicHasher::new(hasher);

No runtime deps