bitstream.cpp
上传用户:zhongxx05
上传日期:2007-06-06
资源大小:33641k
文件大小:4k
源码类别:

Symbian

开发平台:

C/C++

  1. /* ***** BEGIN LICENSE BLOCK ***** 
  2.  * Version: RCSL 1.0/RPSL 1.0 
  3.  *  
  4.  * Portions Copyright (c) 1995-2002 RealNetworks, Inc. All Rights Reserved. 
  5.  *      
  6.  * The contents of this file, and the files included with this file, are 
  7.  * subject to the current version of the RealNetworks Public Source License 
  8.  * Version 1.0 (the "RPSL") available at 
  9.  * http://www.helixcommunity.org/content/rpsl unless you have licensed 
  10.  * the file under the RealNetworks Community Source License Version 1.0 
  11.  * (the "RCSL") available at http://www.helixcommunity.org/content/rcsl, 
  12.  * in which case the RCSL will apply. You may also obtain the license terms 
  13.  * directly from RealNetworks.  You may not use this file except in 
  14.  * compliance with the RPSL or, if you have a valid RCSL with RealNetworks 
  15.  * applicable to this file, the RCSL.  Please see the applicable RPSL or 
  16.  * RCSL for the rights, obligations and limitations governing use of the 
  17.  * contents of the file.  
  18.  *  
  19.  * This file is part of the Helix DNA Technology. RealNetworks is the 
  20.  * developer of the Original Code and owns the copyrights in the portions 
  21.  * it created. 
  22.  *  
  23.  * This file, and the files included with this file, is distributed and made 
  24.  * available on an 'AS IS' basis, WITHOUT WARRANTY OF ANY KIND, EITHER 
  25.  * EXPRESS OR IMPLIED, AND REALNETWORKS HEREBY DISCLAIMS ALL SUCH WARRANTIES, 
  26.  * INCLUDING WITHOUT LIMITATION, ANY WARRANTIES OF MERCHANTABILITY, FITNESS 
  27.  * FOR A PARTICULAR PURPOSE, QUIET ENJOYMENT OR NON-INFRINGEMENT. 
  28.  * 
  29.  * Technology Compatibility Kit Test Suite(s) Location: 
  30.  *    http://www.helixcommunity.org/content/tck 
  31.  * 
  32.  * Contributor(s): 
  33.  *  
  34.  * ***** END LICENSE BLOCK ***** */ 
  35. #include "hlxclib/string.h"
  36. #include "hxassert.h"
  37. #include "bitstream.h"
  38. static const ULONG32 z_mask[] = { 0x00000000, 0x00000001,
  39.     0x00000003, 0x00000007,
  40.     0x0000000f, 0x0000001f,
  41.     0x0000003f, 0x0000007f,
  42.     0x000000ff, 0x000001ff,
  43.     0x000003ff, 0x000007ff,
  44.     0x00000fff, 0x00001fff,
  45.     0x00003fff, 0x00007fff,
  46.     0x0000ffff, 0x0001ffff,
  47.     0x0003ffff, 0x0007ffff,
  48.     0x000fffff, 0x001fffff,
  49.     0x003fffff, 0x007fffff,
  50.     0x00ffffff, 0x01ffffff,
  51.     0x03ffffff, 0x07ffffff,
  52.     0x0fffffff, 0x1fffffff,
  53.     0x3fffffff, 0x7fffffff,
  54.     0xffffffff};
  55. Bitstream::Bitstream() :
  56.     m_pBuf(0),
  57.     m_pCur(0),
  58.     m_bitBuf(0),
  59.     m_bitCount(0)
  60. {}
  61. void Bitstream::SetBuffer(const UINT8* pBuf)
  62. {
  63.     m_pBuf = pBuf;
  64.     m_pCur = m_pBuf;
  65. }
  66. ULONG32 Bitstream::GetBits(ULONG32 bitCount)
  67. {
  68.     HX_ASSERT(bitCount <= 32);
  69.     ULONG32 ret = PeekBits(bitCount);
  70.     if (bitCount <= m_bitCount)
  71. m_bitCount -= bitCount;
  72.     else
  73.     {
  74. m_bitBuf = *m_pCur++;
  75. m_bitCount = 8 - (bitCount - m_bitCount);
  76.     }
  77.     return ret;
  78. }
  79. void Bitstream::GetBits(ULONG32 bitCount, UINT8* pOut)
  80. {
  81.     for(;bitCount >= 8; bitCount -= 8)
  82. *pOut++ = (UINT8)GetBits(8);
  83.     if (bitCount)
  84. *pOut = (UINT8)(GetBits(bitCount) << (8 - bitCount));
  85. }
  86. ULONG32 Bitstream::PeekBits(ULONG32 bitCount)
  87. {
  88.     HX_ASSERT(m_pCur);
  89.     HX_ASSERT(bitCount <= 32);
  90.     ULONG32 ret = 0;
  91.     while (m_bitCount < 24)
  92.     {
  93. m_bitBuf = (m_bitBuf << 8) | (ULONG32) *m_pCur++;
  94. m_bitCount += 8;
  95.     }
  96.     if (bitCount <= m_bitCount)
  97.     {
  98. ULONG32 shift = m_bitCount - bitCount;
  99.     
  100. ret = (m_bitBuf >> shift) & z_mask[bitCount];
  101.     }
  102.     else
  103.     {
  104. ULONG32 needed = bitCount - m_bitCount;
  105. HX_ASSERT(needed <= 8);
  106. ret = (m_bitBuf & z_mask[m_bitCount]) << needed;
  107. ULONG32 shift = 8 - needed;
  108. ret |= (*m_pCur >> shift) & z_mask[needed];
  109.     }
  110.     return ret;
  111. }
  112. void Bitstream::FlushBits(ULONG32 bitCount)
  113. {
  114.     for(;bitCount >= 8; bitCount -= 8)
  115. GetBits(8);
  116.     GetBits(bitCount);
  117. }