2 releases

new 0.1.1 May 6, 2024
0.1.0 Aug 22, 2023

#547 in Algorithms

Download history 378/week @ 2024-01-18 232/week @ 2024-01-25 264/week @ 2024-02-01 219/week @ 2024-02-08 630/week @ 2024-02-15 314/week @ 2024-02-22 239/week @ 2024-02-29 269/week @ 2024-03-07 141/week @ 2024-03-14 326/week @ 2024-03-21 133/week @ 2024-03-28 233/week @ 2024-04-04 162/week @ 2024-04-11 352/week @ 2024-04-18 410/week @ 2024-04-25 359/week @ 2024-05-02

1,325 downloads per month
Used in 4 crates (via malwaredb-lzjd)

MIT license

13KB
302 lines

TestLintCrates.io Version

MurmurHash3.rs

A rust implementation of the MurmurHash3 algorithm. Both 32 bit and 128 bit versions are included. The 128 bit version is implemented with 64 bit datatypes, making it most suitable for x86_64 or other 64 bit architectures.

This is a minor change from the upstream version. Modifications here remove dependencies on crates which prevented compilation on non-x86 hardware, and updated to Rust edition 2021.

Usage

In your Cargo.toml:

[dependencies]
malwaredb-murmurhash3 = "0.1"

Then you can start to use either murmurhash3_x86_32 or murmurhash3_x64_128:

use malwaredb_murmurhash3::murmurhash3_x64_128;

fn hash_value() {
    let data = "test data";
    let seed = 48221234;

    let hash = murmurhash3_x64_128(data.as_bytes(), seed);
}

Unfortunately, there is a bug in the HashState library implementation which prevents implementation of new Hasher implementations for use in for example HashMap. Additionally, only the 32 bit hasher can be used there since HashMap uses a 64 bit hash internally.

Tests

Run cargo test

No runtime deps