Bug 1895153 - Implement "Find in page..." menu functionality r=android-reviewers...
[gecko.git] / third_party / rust / bitreader / README.md
blob640071bf23285f10e627002ec1e3698db77afa98
1 # BitReader
3 BitReader is a helper type to extract strings of bits from a slice of bytes.
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)
9 Here is how you read first a single bit, then three bits and finally four bits from a byte buffer:
11     use bitreader::BitReader;
13     let slice_of_u8 = &[0b1000_1111];
14     let mut reader = BitReader::new(slice_of_u8);
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
21 You can naturally read bits from longer buffer of data than just a single byte.
23 As 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).
25 ## License
27 Licensed under the Apache License, Version 2.0 or the MIT license, at your option.