Index: media/base/bit_reader.cc |
diff --git a/media/base/bit_reader.cc b/media/base/bit_reader.cc |
index ed3dc6050f1f11383db82d6784c37ff82e9d124b..9f6f4098a1f205676f508a9282540866fb094bf7 100644 |
--- a/media/base/bit_reader.cc |
+++ b/media/base/bit_reader.cc |
@@ -15,6 +15,31 @@ BitReader::BitReader(const uint8* data, off_t size) |
BitReader::~BitReader() {} |
+bool BitReader::SkipBits(int num_bits) { |
+ DCHECK_GE(num_bits, 0); |
+ DLOG_IF(INFO, num_bits > 100) |
+ << "BitReader::SkipBits inefficient for large skips"; |
+ |
+ // Skip any bits in the current byte waiting to be processed, then |
+ // process full bytes until less than 8 bits remaining. |
+ while (num_bits > 0 && num_bits > num_remaining_bits_in_curr_byte_) { |
+ num_bits -= num_remaining_bits_in_curr_byte_; |
+ num_remaining_bits_in_curr_byte_ = 0; |
+ UpdateCurrByte(); |
+ |
+ // If there is no more data remaining, only return true if we |
+ // skipped all that were requested. |
+ if (num_remaining_bits_in_curr_byte_ == 0) |
+ return (num_bits == 0); |
+ } |
+ |
+ // Less than 8 bits remaining to skip. Use ReadBitsInternal to verify |
+ // that the remaining bits we need exist, and adjust them as necessary |
+ // for subsequent operations. |
+ uint64 not_needed; |
+ return ReadBitsInternal(num_bits, ¬_needed); |
+} |
+ |
int BitReader::bits_available() const { |
return 8 * bytes_left_ + num_remaining_bits_in_curr_byte_; |
} |