mirror of
https://github.com/lifegpc/msg-tool.git
synced 2026-06-07 13:28:47 +08:00
56 lines
1.4 KiB
Rust
56 lines
1.4 KiB
Rust
//! Crc32 Utility
|
|
use lazy_static::lazy_static;
|
|
|
|
fn get_crc32normal_table() -> [u32; 256] {
|
|
let mut table = [0; 256];
|
|
for i in 0..256u32 {
|
|
let mut c = i << 24;
|
|
for _ in 0..8 {
|
|
if c & 0x80000000 != 0 {
|
|
c = (c << 1) ^ 0x04C11DB7; // Polynomial for CRC-32
|
|
} else {
|
|
c <<= 1;
|
|
}
|
|
}
|
|
table[i as usize] = c;
|
|
}
|
|
table
|
|
}
|
|
|
|
lazy_static! {
|
|
/// CRC32 Normal Table
|
|
pub static ref CRC32NORMAL_TABLE: [u32; 256] = get_crc32normal_table();
|
|
}
|
|
|
|
/// A CRC32 Normal implementation.
|
|
pub struct Crc32Normal {
|
|
crc: u32,
|
|
}
|
|
|
|
impl Crc32Normal {
|
|
/// Creates a new Crc32Normal instance with an initial CRC value.
|
|
pub fn new() -> Self {
|
|
Crc32Normal { crc: 0xFFFFFFFF }
|
|
}
|
|
|
|
/// Creates a new Crc32Normal instance with a specified initial CRC value.
|
|
pub fn update_crc(init_crc: u32, data: &[u8]) -> u32 {
|
|
let mut crc = init_crc;
|
|
for &byte in data {
|
|
let index = ((crc >> 24) ^ byte as u32) & 0xFF;
|
|
crc = (crc << 8) ^ CRC32NORMAL_TABLE[index as usize];
|
|
}
|
|
crc ^ 0xFFFFFFFF
|
|
}
|
|
|
|
/// Updates the CRC value with new data.
|
|
pub fn update(&mut self, data: &[u8]) {
|
|
self.crc = Self::update_crc(self.crc, data);
|
|
}
|
|
|
|
/// Returns the current CRC value.
|
|
pub fn value(&self) -> u32 {
|
|
self.crc
|
|
}
|
|
}
|