• Home
  • History
  • Annotate
Name Date Size #Lines LOC

..03-May-2022-

src/H03-May-2022-786488

.cargo-checksum.jsonH A D03-May-202289 11

.cargo_vcs_info.jsonH A D01-Jan-197094 66

.gitignoreH A D29-Nov-197324 43

.travis.ymlH A D29-Nov-197344 54

Cargo.tomlH A D01-Jan-19701.1 KiB2825

Cargo.toml.orig-cargoH A D29-Nov-1973624 2819

LICENSE-APACHEH A D29-Nov-197311.1 KiB203169

LICENSE-MITH A D29-Nov-19731 KiB2622

README.mdH A D29-Nov-19731.2 KiB2817

README.md

1# BitReader
2
3BitReader is a helper type to extract strings of bits from a slice of bytes.
4
5[![Published Package](https://img.shields.io/crates/v/bitreader.svg)](https://crates.io/crates/bitreader)
6[![Documentation](https://docs.rs/bitreader/badge.svg)](https://docs.rs/bitreader)
7[![Build Status](https://travis-ci.org/irauta/bitreader.svg?branch=master)](https://travis-ci.org/irauta/bitreader)
8
9Here is how you read first a single bit, then three bits and finally four bits from a byte buffer:
10
11    use bitreader::BitReader;
12
13    let slice_of_u8 = &[0b1000_1111];
14    let mut reader = BitReader::new(slice_of_u8);
15
16    // You obviously should use try! or some other error handling mechanism here
17    let a_single_bit = reader.read_u8(1).unwrap(); // 1
18    let more_bits = reader.read_u8(3).unwrap(); // 0
19    let last_bits_of_byte = reader.read_u8(4).unwrap(); // 0b1111
20
21You can naturally read bits from longer buffer of data than just a single byte.
22
23As you read bits, the internal cursor of BitReader moves on along the stream of bits. Big endian format is assumed when reading the multi-byte values. BitReader supports reading maximum of 64 bits at a time (with read_u64).
24
25## License
26
27Licensed under the Apache License, Version 2.0 or the MIT license, at your option.
28