| Top |  |  |  |  | 
GstBitReader provides a bit reader that can read any number of bits from a memory buffer. It provides functions for reading any number of bits into 8, 16, 32 and 64 bit variables.
#define GST_BIT_READER_INIT(data, size) {data, size, 0, 0}
A GstBitReader must be initialized with this macro, before it can be
used. This macro can used be to initialize a variable, but it cannot
be assigned to a variable. In that case you have to use
gst_bit_reader_init().
GstBitReader * gst_bit_reader_new (const guint8 *data,guint size);
Create a new GstBitReader instance, which will read from data
.
Free-function: gst_bit_reader_free
| data | Data from which the GstBitReader should read. | [array length=size] | 
| size | Size of  | 
void
gst_bit_reader_free (GstBitReader *reader);
Frees a GstBitReader instance, which was previously allocated by
gst_bit_reader_new().
void gst_bit_reader_init (GstBitReader *reader,const guint8 *data,guint size);
Initializes a GstBitReader instance to read from data
. This function
can be called on already initialized instances.
| reader | a GstBitReader instance | |
| data | data from which the bit reader should read. | [in][array length=size] | 
| size | Size of  | 
guint
gst_bit_reader_get_pos (const GstBitReader *reader);
Returns the current position of a GstBitReader instance in bits.
guint
gst_bit_reader_get_remaining (const GstBitReader *reader);
Returns the remaining number of bits of a GstBitReader instance.
gboolean gst_bit_reader_set_pos (GstBitReader *reader,guint pos);
Sets the new position of a GstBitReader instance to pos
 in bits.
guint
gst_bit_reader_get_size (const GstBitReader *reader);
Returns the total number of bits of a GstBitReader instance.
gboolean gst_bit_reader_skip (GstBitReader *reader,guint nbits);
Skips nbits
 bits of the GstBitReader instance.
gboolean
gst_bit_reader_skip_to_byte (GstBitReader *reader);
Skips until the next byte.
gboolean gst_bit_reader_get_bits_uint16 (GstBitReader *reader,guint16 *val,guint nbits);
Read nbits
 bits into val
 and update the current position.
| reader | a GstBitReader instance | |
| val | Pointer to a guint16 to store the result. | [out] | 
| nbits | number of bits to read | 
gboolean gst_bit_reader_get_bits_uint32 (GstBitReader *reader,guint32 *val,guint nbits);
Read nbits
 bits into val
 and update the current position.
| reader | a GstBitReader instance | |
| val | Pointer to a guint32 to store the result. | [out] | 
| nbits | number of bits to read | 
gboolean gst_bit_reader_get_bits_uint64 (GstBitReader *reader,guint64 *val,guint nbits);
Read nbits
 bits into val
 and update the current position.
| reader | a GstBitReader instance | |
| val | Pointer to a guint64 to store the result. | [out] | 
| nbits | number of bits to read | 
gboolean gst_bit_reader_get_bits_uint8 (GstBitReader *reader,guint8 *val,guint nbits);
Read nbits
 bits into val
 and update the current position.
| reader | a GstBitReader instance | |
| val | Pointer to a guint8 to store the result. | [out] | 
| nbits | number of bits to read | 
gboolean gst_bit_reader_peek_bits_uint16 (const GstBitReader *reader,guint16 *val,guint nbits);
Read nbits
 bits into val
 but keep the current position.
| reader | a GstBitReader instance | |
| val | Pointer to a guint16 to store the result. | [out] | 
| nbits | number of bits to read | 
gboolean gst_bit_reader_peek_bits_uint32 (const GstBitReader *reader,guint32 *val,guint nbits);
Read nbits
 bits into val
 but keep the current position.
| reader | a GstBitReader instance | |
| val | Pointer to a guint32 to store the result. | [out] | 
| nbits | number of bits to read | 
gboolean gst_bit_reader_peek_bits_uint64 (const GstBitReader *reader,guint64 *val,guint nbits);
Read nbits
 bits into val
 but keep the current position.
| reader | a GstBitReader instance | |
| val | Pointer to a guint64 to store the result. | [out] | 
| nbits | number of bits to read | 
gboolean gst_bit_reader_peek_bits_uint8 (const GstBitReader *reader,guint8 *val,guint nbits);
Read nbits
 bits into val
 but keep the current position.
| reader | a GstBitReader instance | |
| val | Pointer to a guint8 to store the result. | [out] | 
| nbits | number of bits to read | 
void gst_bit_reader_skip_unchecked (GstBitReader *reader,guint nbits);
Skips nbits
 bits of the GstBitReader instance without checking if there
are enough bits available in the bit reader.
void
gst_bit_reader_skip_to_byte_unchecked (GstBitReader *reader);
Skips until the next byte without checking if there are enough bits available in the bit reader.
guint16 gst_bit_reader_get_bits_uint16_unchecked (GstBitReader *reader,guint nbits);
Read nbits
 bits into val
 and update the current position without
checking if there are enough bits available in the bit reader.
guint32 gst_bit_reader_get_bits_uint32_unchecked (GstBitReader *reader,guint nbits);
Read nbits
 bits into val
 and update the current position without
checking if there are enough bits available in the bit reader.
guint64 gst_bit_reader_get_bits_uint64_unchecked (GstBitReader *reader,guint nbits);
Read nbits
 bits into val
 and update the current position without
checking if there are enough bits available in the bit reader.
guint8 gst_bit_reader_get_bits_uint8_unchecked (GstBitReader *reader,guint nbits);
Read nbits
 bits into val
 and update the current position without
checking if there are enough bits available in the bit reader.
guint16 gst_bit_reader_peek_bits_uint16_unchecked (const GstBitReader *reader,guint nbits);
Read nbits
 bits into val
 but keep the current position without
checking if there are enough bits available in the bit reader
guint32 gst_bit_reader_peek_bits_uint32_unchecked (const GstBitReader *reader,guint nbits);
Read nbits
 bits into val
 but keep the current position without
checking if there are enough bits available in the bit reader
guint64 gst_bit_reader_peek_bits_uint64_unchecked (const GstBitReader *reader,guint nbits);
Read nbits
 bits into val
 but keep the current position without
checking if there are enough bits available in the bit reader
guint8 gst_bit_reader_peek_bits_uint8_unchecked (const GstBitReader *reader,guint nbits);
Read nbits
 bits into val
 but keep the current position without
checking if there are enough bits available in the bit reader