| // Copyright 2015 The Chromium Authors. All rights reserved. | 
 | // Use of this source code is governed by a BSD-style license that can be | 
 | // found in the LICENSE file. | 
 | // | 
 |  | 
 | /* | 
 |  * Copyright (c) 2010, The WebM Project authors. All rights reserved. | 
 |  * | 
 |  * Redistribution and use in source and binary forms, with or without | 
 |  * modification, are permitted provided that the following conditions are | 
 |  * met: | 
 |  * | 
 |  *   * Redistributions of source code must retain the above copyright | 
 |  *     notice, this list of conditions and the following disclaimer. | 
 |  * | 
 |  *   * Redistributions in binary form must reproduce the above copyright | 
 |  *     notice, this list of conditions and the following disclaimer in | 
 |  *     the documentation and/or other materials provided with the | 
 |  *     distribution. | 
 |  * | 
 |  *   * Neither the name of Google, nor the WebM Project, nor the names | 
 |  *     of its contributors may be used to endorse or promote products | 
 |  *     derived from this software without specific prior written | 
 |  *     permission. | 
 |  * | 
 |  * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS | 
 |  * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT | 
 |  * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR | 
 |  * A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT | 
 |  * HOLDER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, | 
 |  * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT | 
 |  * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, | 
 |  * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY | 
 |  * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT | 
 |  * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE | 
 |  * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | 
 |  */ | 
 |  | 
 | // This file is modified from the dboolhuff.{c,h} from the WebM's libvpx | 
 | // project. (http://www.webmproject.org/code) | 
 | // It is used to decode bits from a vp8 stream. | 
 |  | 
 | #ifndef MEDIA_PARSERS_VP8_BOOL_DECODER_H_ | 
 | #define MEDIA_PARSERS_VP8_BOOL_DECODER_H_ | 
 |  | 
 | #include <stddef.h> | 
 | #include <stdint.h> | 
 | #include <sys/types.h> | 
 |  | 
 | #include "base/macros.h" | 
 | #include "media/parsers/media_parsers_export.h" | 
 |  | 
 | namespace media { | 
 |  | 
 | // A class to decode the VP8's boolean entropy coded stream. It's a variant of | 
 | // arithmetic coding. See RFC 6386 - Chapter 7. Boolean Entropy Decoder. | 
 | class MEDIA_PARSERS_EXPORT Vp8BoolDecoder { | 
 |  public: | 
 |   Vp8BoolDecoder(); | 
 |  | 
 |   // Initializes the decoder to start decoding |data|, |size| being size | 
 |   // of |data| in bytes. Returns false if |data| is NULL or empty. | 
 |   bool Initialize(const uint8_t* data, size_t size); | 
 |  | 
 |   // Reads a boolean from the coded stream. Returns false if it has reached the | 
 |   // end of |data| and failed to read the boolean. The probability of |out| to | 
 |   // be true is |probability| / 256, e.g., when |probability| is 0x80, the | 
 |   // chance is 1/2 (i.e., 0x80 / 256). | 
 |   bool ReadBool(bool* out, uint8_t probability); | 
 |  | 
 |   // Reads a boolean from the coded stream with the default probability 1/2. | 
 |   // Returns false if it has reached the end of |data| and failed to read the | 
 |   // boolean. | 
 |   bool ReadBool(bool* out); | 
 |  | 
 |   // Reads a "literal", that is, a "num_bits"-wide unsigned value whose bits | 
 |   // come high- to low-order, with each bit encoded at probability 1/2. | 
 |   // Returns false if it has reached the end of |data| and failed to read the | 
 |   // literal. | 
 |   bool ReadLiteral(size_t num_bits, int* out); | 
 |  | 
 |   // Reads a literal with sign from the coded stream. This is similar to | 
 |   // the ReadListeral(), it first read a "num_bits"-wide unsigned value, and | 
 |   // then read an extra bit as the sign of the literal. Returns false if it has | 
 |   // reached the end of |data| and failed to read the literal or the sign. | 
 |   // This is different from the "read_signed_literal(d, n)" defined in RFC 6386. | 
 |   bool ReadLiteralWithSign(size_t num_bits, int* out); | 
 |  | 
 |   // The following methods are used to get the internal states of the decoder. | 
 |  | 
 |   // Returns the bit offset to the current top bit of the coded stream. It is | 
 |   // also the number of bits that have been written in the corresponding | 
 |   // encoding state. More specifically, we have the following constraint: | 
 |   //    w + (bottom * S) <= v < w + (bottom + range) * S, | 
 |   // where "w" is for the bits already written, | 
 |   //       "v" is for the possible values of the coded number. | 
 |   //       "S" is the scale for the current bit position, | 
 |   //           i.e., S = pow(2, -(n + 8)), where "n" is the bit number of "w". | 
 |   // BitOffset() returns the bit count of "w", i.e., "n". | 
 |   size_t BitOffset(); | 
 |  | 
 |   // Gets the "bottom" of the current coded value. See BitOffset() for | 
 |   // more details. | 
 |   uint8_t GetBottom(); | 
 |  | 
 |   // Gets the "range" of the current coded value. See BitOffset() for | 
 |   // more details. | 
 |   uint8_t GetRange(); | 
 |  | 
 |  private: | 
 |   // Reads the next bit from the coded stream. The probability of the bit to | 
 |   // be one is |probability| / 256. | 
 |   int ReadBit(int probability); | 
 |  | 
 |   // Fills more bits from |user_buffer_| to |value_|. We shall keep at least 8 | 
 |   // bits of the current |user_buffer_| in |value_|. | 
 |   void FillDecoder(); | 
 |  | 
 |   // Returns true iff we have ran out of bits. | 
 |   bool OutOfBuffer(); | 
 |  | 
 |   const uint8_t* user_buffer_; | 
 |   const uint8_t* user_buffer_start_; | 
 |   const uint8_t* user_buffer_end_; | 
 |   size_t value_; | 
 |   int count_; | 
 |   size_t range_; | 
 |  | 
 |   DISALLOW_COPY_AND_ASSIGN(Vp8BoolDecoder); | 
 | }; | 
 |  | 
 | }  // namespace media | 
 |  | 
 | #endif  // MEDIA_PARSERS_VP8_BOOL_DECODER_H_ |