# crc [![Build Status](https://travis-ci.org/mrhooray/crc-rs.svg?branch=master)](https://travis-ci.org/mrhooray/crc-rs)
> Rust implementation of CRC(16, 32, 64) with support of various standards
* [Crate](https://crates.io/crates/crc)
* [Documentation](https://docs.rs/crc/)
* [Usage](#usage)
* [Benchmark](#benchmark)
* [License](#license)
## Usage
Add `crc` to `Cargo.toml`
```toml
[dependencies]
crc = "^1.0.0"
```
or
```toml
[dependencies.crc]
git = "https://github.com/mrhooray/crc-rs"
```
Add this to crate root
```rust
extern crate crc;
```
### Compute CRC16
```rust
use crc::{crc16, Hasher16};
assert_eq!(crc16::checksum_x25(b"123456789"), 0x906e);
assert_eq!(crc16::checksum_usb(b"123456789"), 0xb4c8);
// use provided or custom polynomial
let mut digest = crc16::Digest::new(crc16::X25);
digest.write(b"123456789");
assert_eq!(digest.sum16(), 0x906e);
// with initial
let mut digest = crc16::Digest::new_with_initial(crc16::X25, 0u16);
digest.write(b"123456789");
assert_eq!(digest.sum16(), 0x906e);
```
### Compute CRC32
```rust
use crc::{crc32, Hasher32};
// CRC-32-IEEE being the most commonly used one
assert_eq!(crc32::checksum_ieee(b"123456789"), 0xcbf43926);
assert_eq!(crc32::checksum_castagnoli(b"123456789"), 0xe3069283);
assert_eq!(crc32::checksum_koopman(b"123456789"), 0x2d3dd0ae);
// use provided or custom polynomial
let mut digest = crc32::Digest::new(crc32::IEEE);
digest.write(b"123456789");
assert_eq!(digest.sum32(), 0xcbf43926);
// with initial
let mut digest = crc32::Digest::new_with_initial(crc32::IEEE, 0u32);
digest.write(b"123456789");
assert_eq!(digest.sum32(), 0xcbf43926);
```
### Compute CRC64
```rust
use crc::{crc64, Hasher64};
assert_eq!(crc64::checksum_ecma(b"123456789"), 0x995dc9bbdf1939fa);
assert_eq!(crc64::checksum_iso(b"123456789"), 0xb90956c775a41001);
// use provided or custom polynomial
let mut digest = crc64::Digest::new(crc64::ECMA);
digest.write(b"123456789");
assert_eq!(digest.sum64(), 0x995dc9bbdf1939fa);
// with initial
let mut digest = crc64::Digest::new_with_initial(crc64::ECMA, 0u64);
digest.write(b"123456789");
assert_eq!(digest.sum64(), 0x995dc9bbdf1939fa);
```
## Benchmark
> Bencher is currently not available in Rust stable releases.
`cargo bench` with 2.3 GHz Intel Core i7 results ~430MB/s throughput. [Comparison](http://create.stephan-brumme.com/crc32/)
```
cargo bench
Running target/release/bench-5c82e94dab3e9c79
running 4 tests
test bench_crc32_make_table ... bench: 439 ns/iter (+/- 82)
test bench_crc32_update_megabytes ... bench: 2327803 ns/iter (+/- 138845)
test bench_crc64_make_table ... bench: 1200 ns/iter (+/- 223)
test bench_crc64_update_megabytes ... bench: 2322472 ns/iter (+/- 92870)
test result: ok. 0 passed; 0 failed; 0 ignored; 4 measured
```
## License
Licensed under either of
* Apache License, Version 2.0 ([LICENSE-APACHE](LICENSE-APACHE) or http://www.apache.org/licenses/LICENSE-2.0)
* MIT License ([LICENSE-MIT](LICENSE-MIT) or http://opensource.org/licenses/MIT)
at your option.
### Contribution
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.