Crates.io | const-crc32 |
lib.rs | const-crc32 |
version | 1.3.0 |
source | src |
created_at | 2022-10-05 16:46:40.763376 |
updated_at | 2023-09-06 17:59:08.125661 |
description | A `const fn` implementation of crc32 checksum algorithm |
homepage | |
repository | https://git.shipyard.rs/jstrong/const-crc32 |
max_upload_size | |
id | 680640 |
size | 8,850 |
A const fn
crc32 checksum implementation.
const BYTES: &[u8] = "The quick brown fox jumps over the lazy dog".as_bytes();
const CKSUM: u32 = const_crc32::crc32(BYTES);
assert_eq!(CKSUM, 0x414fa339_u32);
This is a naive implementation that should be expected to have poor performance
if used on dynamic data at runtime. Usage should generally be restricted to declaring
const
variables based on static
or const
data available at build time.
#[const_eval_limit]
You may need to increase the crate-wide const_eval_limit
setting to use const_crc32
for larger byte slices.
Increating const_eval_limit
requires the nightly-only #![feature(const_eval_limit)]
.
Previously, this crate set the limit itself, however, as of the 2022-10-30 nightly, the value set in const_crc32
does not increase the limit for crates which use the library.
Compile time for const
data around 100k is less than 1s.