| OLD | NEW |
| 1 // Copyright 2014 PDFium Authors. All rights reserved. | 1 // Copyright 2014 PDFium Authors. All rights reserved. |
| 2 // Use of this source code is governed by a BSD-style license that can be | 2 // Use of this source code is governed by a BSD-style license that can be |
| 3 // found in the LICENSE file. | 3 // found in the LICENSE file. |
| 4 | 4 |
| 5 // Original code copyright 2014 Foxit Software Inc. http://www.foxitsoftware.com | 5 // Original code copyright 2014 Foxit Software Inc. http://www.foxitsoftware.com |
| 6 | 6 |
| 7 #include "core/src/fxcodec/jbig2/JBig2_ArithIntDecoder.h" | 7 #include "core/src/fxcodec/jbig2/JBig2_ArithIntDecoder.h" |
| 8 | 8 |
| 9 #include <vector> |
| 10 |
| 9 #include "core/include/fxcrt/fx_basic.h" | 11 #include "core/include/fxcrt/fx_basic.h" |
| 10 | 12 |
| 11 namespace { | 13 namespace { |
| 12 | 14 |
| 13 int ShiftOr(int val, int bitwise_or_val) { | 15 int ShiftOr(int val, int bitwise_or_val) { |
| 14 return (val << 1) | bitwise_or_val; | 16 return (val << 1) | bitwise_or_val; |
| 15 } | 17 } |
| 16 | 18 |
| 17 const struct ArithIntDecodeData { | 19 const struct ArithIntDecodeData { |
| 18 int nNeedBits; | 20 int nNeedBits; |
| (...skipping 69 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 88 void CJBig2_ArithIaidDecoder::decode(CJBig2_ArithDecoder* pArithDecoder, | 90 void CJBig2_ArithIaidDecoder::decode(CJBig2_ArithDecoder* pArithDecoder, |
| 89 FX_DWORD* nResult) { | 91 FX_DWORD* nResult) { |
| 90 int PREV = 1; | 92 int PREV = 1; |
| 91 for (unsigned char i = 0; i < SBSYMCODELEN; ++i) { | 93 for (unsigned char i = 0; i < SBSYMCODELEN; ++i) { |
| 92 JBig2ArithCtx* pCX = &m_IAID[PREV]; | 94 JBig2ArithCtx* pCX = &m_IAID[PREV]; |
| 93 int D = pArithDecoder->DECODE(pCX); | 95 int D = pArithDecoder->DECODE(pCX); |
| 94 PREV = ShiftOr(PREV, D); | 96 PREV = ShiftOr(PREV, D); |
| 95 } | 97 } |
| 96 *nResult = PREV - (1 << SBSYMCODELEN); | 98 *nResult = PREV - (1 << SBSYMCODELEN); |
| 97 } | 99 } |
| OLD | NEW |