| Crates.io | shabal |
| lib.rs | shabal |
| version | 0.5.0-rc.1 |
| created_at | 2019-02-25 20:30:43.607419+00 |
| updated_at | 2026-01-24 17:25:32.558122+00 |
| description | Shabal hash functions |
| homepage | |
| repository | https://github.com/RustCrypto/hashes |
| max_upload_size | |
| id | 117199 |
| size | 51,736 |
Pure Rust implementation of the Shabal cryptographic hash algorithm.
There are 5 standard algorithms specified in the Shabal standard: [Shabal192], [Shabal224], [Shabal256], [Shabal384], [Shabal512].
use shabal::{Shabal256, Digest};
use hex_literal::hex;
let mut hasher = Shabal256::new();
hasher.update(b"helloworld");
let hash = hasher.finalize();
assert_eq!(hash, hex!("d945dee21ffca23ac232763aa9cac6c15805f144db9d6c97395437e01c8595a8"));
// Hex-encode hash using https://docs.rs/base16ct
let hex_hash = base16ct::lower::encode_string(&hash);
assert_eq!(hex_hash, "d945dee21ffca23ac232763aa9cac6c15805f144db9d6c97395437e01c8595a8");
Also, see the examples section in the RustCrypto/hashes readme.
The crate is licensed under either of:
at your option.
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.