| 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 // Original code is licensed as follows: | 6 // Original code is licensed as follows: |
| 7 /* | 7 /* |
| 8 * Copyright 2007 ZXing authors | 8 * Copyright 2007 ZXing authors |
| 9 * | 9 * |
| 10 * Licensed under the Apache License, Version 2.0 (the "License"); | 10 * Licensed under the Apache License, Version 2.0 (the "License"); |
| (...skipping 19 matching lines...) Expand all Loading... |
| 30 #include "xfa/src/fxbarcode/datamatrix/BC_DataMatrixVersion.h" | 30 #include "xfa/src/fxbarcode/datamatrix/BC_DataMatrixVersion.h" |
| 31 | 31 |
| 32 CBC_DataMatrixDecoder::CBC_DataMatrixDecoder() { | 32 CBC_DataMatrixDecoder::CBC_DataMatrixDecoder() { |
| 33 m_rsDecoder = NULL; | 33 m_rsDecoder = NULL; |
| 34 } | 34 } |
| 35 void CBC_DataMatrixDecoder::Init() { | 35 void CBC_DataMatrixDecoder::Init() { |
| 36 m_rsDecoder = | 36 m_rsDecoder = |
| 37 new CBC_ReedSolomonDecoder(CBC_ReedSolomonGF256::DataMatrixField); | 37 new CBC_ReedSolomonDecoder(CBC_ReedSolomonGF256::DataMatrixField); |
| 38 } | 38 } |
| 39 CBC_DataMatrixDecoder::~CBC_DataMatrixDecoder() { | 39 CBC_DataMatrixDecoder::~CBC_DataMatrixDecoder() { |
| 40 if (m_rsDecoder != NULL) { | 40 delete m_rsDecoder; |
| 41 delete m_rsDecoder; | |
| 42 } | |
| 43 m_rsDecoder = NULL; | |
| 44 } | 41 } |
| 45 CBC_CommonDecoderResult* CBC_DataMatrixDecoder::Decode( | 42 CBC_CommonDecoderResult* CBC_DataMatrixDecoder::Decode( |
| 46 CBC_CommonBitMatrix* bits, | 43 CBC_CommonBitMatrix* bits, |
| 47 int32_t& e) { | 44 int32_t& e) { |
| 48 CBC_DataMatrixBitMatrixParser parser; | 45 CBC_DataMatrixBitMatrixParser parser; |
| 49 parser.Init(bits, e); | 46 parser.Init(bits, e); |
| 50 BC_EXCEPTION_CHECK_ReturnValue(e, NULL); | 47 BC_EXCEPTION_CHECK_ReturnValue(e, NULL); |
| 51 CBC_DataMatrixVersion* version = parser.GetVersion(); | 48 CBC_DataMatrixVersion* version = parser.GetVersion(); |
| 52 CFX_ByteArray* byteTemp = parser.ReadCodewords(e); | 49 CFX_ByteArray* byteTemp = parser.ReadCodewords(e); |
| 53 BC_EXCEPTION_CHECK_ReturnValue(e, NULL); | 50 BC_EXCEPTION_CHECK_ReturnValue(e, NULL); |
| (...skipping 52 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 106 int32_t numECCodewords = codewordBytes.GetSize() - numDataCodewords; | 103 int32_t numECCodewords = codewordBytes.GetSize() - numDataCodewords; |
| 107 m_rsDecoder->Decode(&codewordsInts, numECCodewords, e); | 104 m_rsDecoder->Decode(&codewordsInts, numECCodewords, e); |
| 108 if (e != BCExceptionNO) { | 105 if (e != BCExceptionNO) { |
| 109 e = BCExceptionChecksumException; | 106 e = BCExceptionChecksumException; |
| 110 return; | 107 return; |
| 111 } | 108 } |
| 112 for (i = 0; i < numDataCodewords; i++) { | 109 for (i = 0; i < numDataCodewords; i++) { |
| 113 codewordBytes[i] = (uint8_t)codewordsInts[i]; | 110 codewordBytes[i] = (uint8_t)codewordsInts[i]; |
| 114 } | 111 } |
| 115 } | 112 } |
| OLD | NEW |