/**
|
* <p>This provides an easy abstraction to read bits at a time from a sequence of bytes, where the
|
* number of bits read is not often a multiple of 8.</p>
|
*
|
* <p>This class is thread-safe but not reentrant -- unless the caller modifies the bytes array
|
* it passed in, in which case all bets are off.</p>
|
*
|
* @author Sean Owen
|
*/
|
export default class BitSource {
|
private bytes;
|
private byteOffset;
|
private bitOffset;
|
/**
|
* @param bytes bytes from which this will read bits. Bits will be read from the first byte first.
|
* Bits are read within a byte from most-significant to least-significant bit.
|
*/
|
constructor(bytes: Uint8Array);
|
/**
|
* @return index of next bit in current byte which would be read by the next call to {@link #readBits(int)}.
|
*/
|
getBitOffset(): number;
|
/**
|
* @return index of next byte in input byte array which would be read by the next call to {@link #readBits(int)}.
|
*/
|
getByteOffset(): number;
|
/**
|
* @param numBits number of bits to read
|
* @return int representing the bits read. The bits will appear as the least-significant
|
* bits of the int
|
* @throws IllegalArgumentException if numBits isn't in [1,32] or more than is available
|
*/
|
readBits(numBits: number): number;
|
/**
|
* @return number of bits that can be read successfully
|
*/
|
available(): number;
|
}
|