| // Copyright 2014 PDFium Authors. All rights reserved. |
| // Use of this source code is governed by a BSD-style license that can be |
| // found in the LICENSE file. |
| |
| // Original code copyright 2014 Foxit Software Inc. http://www.foxitsoftware.com |
| // Original code is licensed as follows: |
| /* |
| * Copyright 2007 ZXing authors |
| * |
| * Licensed under the Apache License, Version 2.0 (the "License"); |
| * you may not use this file except in compliance with the License. |
| * You may obtain a copy of the License at |
| * |
| * http://www.apache.org/licenses/LICENSE-2.0 |
| * |
| * Unless required by applicable law or agreed to in writing, software |
| * distributed under the License is distributed on an "AS IS" BASIS, |
| * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. |
| * See the License for the specific language governing permissions and |
| * limitations under the License. |
| */ |
| |
| #include "xfa/fxbarcode/common/BC_CommonBitMatrix.h" |
| #include "xfa/fxbarcode/qrcode/BC_QRCoderBitVector.h" |
| #include "xfa/fxbarcode/qrcode/BC_QRCoderECB.h" |
| #include "xfa/fxbarcode/qrcode/BC_QRCoderECBlocks.h" |
| #include "xfa/fxbarcode/qrcode/BC_QRCoderErrorCorrectionLevel.h" |
| #include "xfa/fxbarcode/qrcode/BC_QRCoderVersion.h" |
| #include "xfa/fxbarcode/utils.h" |
| |
| namespace { |
| |
| const uint8_t BITS_SET_IN_HALF_BYTE[] = {0, 1, 1, 2, 1, 2, 2, 3, |
| 1, 2, 2, 3, 2, 3, 3, 4}; |
| |
| int32_t NumBitsDiffering(int32_t a, int32_t b) { |
| a ^= b; |
| return BITS_SET_IN_HALF_BYTE[a & 0x0F] + |
| BITS_SET_IN_HALF_BYTE[(a >> 4) & 0x0F] + |
| BITS_SET_IN_HALF_BYTE[(a >> 8) & 0x0F] + |
| BITS_SET_IN_HALF_BYTE[(a >> 12) & 0x0F] + |
| BITS_SET_IN_HALF_BYTE[(a >> 16) & 0x0F] + |
| BITS_SET_IN_HALF_BYTE[(a >> 20) & 0x0F] + |
| BITS_SET_IN_HALF_BYTE[(a >> 24) & 0x0F] + |
| BITS_SET_IN_HALF_BYTE[(a >> 28) & 0x0F]; |
| } |
| |
| } // namespace |
| |
| const int32_t CBC_QRCoderVersion::VERSION_DECODE_INFO[] = { |
| 0x07C94, 0x085BC, 0x09A99, 0x0A4D3, 0x0BBF6, 0x0C762, 0x0D847, |
| 0x0E60D, 0x0F928, 0x10B78, 0x1145D, 0x12A17, 0x13532, 0x149A6, |
| 0x15683, 0x168C9, 0x177EC, 0x18EC4, 0x191E1, 0x1AFAB, 0x1B08E, |
| 0x1CC1A, 0x1D33F, 0x1ED75, 0x1F250, 0x209D5, 0x216F0, 0x228BA, |
| 0x2379F, 0x24B0B, 0x2542E, 0x26A64, 0x27541, 0x28C69}; |
| |
| CFX_ArrayTemplate<CBC_QRCoderVersion*>* CBC_QRCoderVersion::VERSION = nullptr; |
| |
| void CBC_QRCoderVersion::Initialize() { |
| VERSION = new CFX_ArrayTemplate<CBC_QRCoderVersion*>(); |
| } |
| void CBC_QRCoderVersion::Finalize() { |
| for (int32_t i = 0; i < VERSION->GetSize(); i++) |
| delete VERSION->GetAt(i); |
| |
| delete VERSION; |
| VERSION = nullptr; |
| } |
| CBC_QRCoderVersion::CBC_QRCoderVersion(int32_t versionNumber, |
| CBC_QRCoderECBlocks* ecBlocks1, |
| CBC_QRCoderECBlocks* ecBlocks2, |
| CBC_QRCoderECBlocks* ecBlocks3, |
| CBC_QRCoderECBlocks* ecBlocks4) { |
| m_versionNumber = versionNumber; |
| m_ecBlocksArray.Add(ecBlocks1); |
| m_ecBlocksArray.Add(ecBlocks2); |
| m_ecBlocksArray.Add(ecBlocks3); |
| m_ecBlocksArray.Add(ecBlocks4); |
| int32_t total = 0; |
| int32_t ecCodeWords = ecBlocks1->GetECCodeWordsPerBlock(); |
| CFX_ArrayTemplate<CBC_QRCoderECB*>* ecbArray = ecBlocks1->GetECBlocks(); |
| for (int32_t i = 0; i < ecbArray->GetSize(); i++) { |
| CBC_QRCoderECB* ecBlock = (*ecbArray)[i]; |
| total += ecBlock->GetCount() * (ecBlock->GetDataCodeWords() + ecCodeWords); |
| } |
| m_totalCodeWords = total; |
| switch (versionNumber) { |
| case 1: |
| break; |
| case 2: |
| m_alignmentPatternCenters.Add(6); |
| m_alignmentPatternCenters.Add(18); |
| break; |
| case 3: |
| m_alignmentPatternCenters.Add(6); |
| m_alignmentPatternCenters.Add(22); |
| break; |
| case 4: |
| m_alignmentPatternCenters.Add(6); |
| m_alignmentPatternCenters.Add(26); |
| break; |
| case 5: |
| m_alignmentPatternCenters.Add(6); |
| m_alignmentPatternCenters.Add(30); |
| break; |
| case 6: |
| m_alignmentPatternCenters.Add(6); |
| m_alignmentPatternCenters.Add(34); |
| break; |
| case 7: |
| m_alignmentPatternCenters.Add(6); |
| m_alignmentPatternCenters.Add(22); |
| m_alignmentPatternCenters.Add(38); |
| break; |
| case 8: |
| m_alignmentPatternCenters.Add(6); |
| m_alignmentPatternCenters.Add(24); |
| m_alignmentPatternCenters.Add(42); |
| break; |
| case 9: |
| m_alignmentPatternCenters.Add(6); |
| m_alignmentPatternCenters.Add(26); |
| m_alignmentPatternCenters.Add(46); |
| break; |
| case 10: |
| m_alignmentPatternCenters.Add(6); |
| m_alignmentPatternCenters.Add(28); |
| m_alignmentPatternCenters.Add(50); |
| break; |
| case 11: |
| m_alignmentPatternCenters.Add(6); |
| m_alignmentPatternCenters.Add(30); |
| m_alignmentPatternCenters.Add(54); |
| break; |
| case 12: |
| m_alignmentPatternCenters.Add(6); |
| m_alignmentPatternCenters.Add(32); |
| m_alignmentPatternCenters.Add(58); |
| break; |
| case 13: |
| m_alignmentPatternCenters.Add(6); |
| m_alignmentPatternCenters.Add(34); |
| m_alignmentPatternCenters.Add(62); |
| break; |
| case 14: |
| m_alignmentPatternCenters.Add(6); |
| m_alignmentPatternCenters.Add(26); |
| m_alignmentPatternCenters.Add(46); |
| m_alignmentPatternCenters.Add(66); |
| break; |
| case 15: |
| m_alignmentPatternCenters.Add(6); |
| m_alignmentPatternCenters.Add(26); |
| m_alignmentPatternCenters.Add(48); |
| m_alignmentPatternCenters.Add(70); |
| break; |
| case 16: |
| m_alignmentPatternCenters.Add(6); |
| m_alignmentPatternCenters.Add(26); |
| m_alignmentPatternCenters.Add(50); |
| m_alignmentPatternCenters.Add(74); |
| break; |
| case 17: |
| m_alignmentPatternCenters.Add(6); |
| m_alignmentPatternCenters.Add(30); |
| m_alignmentPatternCenters.Add(54); |
| m_alignmentPatternCenters.Add(78); |
| break; |
| case 18: |
| m_alignmentPatternCenters.Add(6); |
| m_alignmentPatternCenters.Add(30); |
| m_alignmentPatternCenters.Add(56); |
| m_alignmentPatternCenters.Add(82); |
| break; |
| case 19: |
| m_alignmentPatternCenters.Add(6); |
| m_alignmentPatternCenters.Add(30); |
| m_alignmentPatternCenters.Add(58); |
| m_alignmentPatternCenters.Add(86); |
| break; |
| case 20: |
| m_alignmentPatternCenters.Add(6); |
| m_alignmentPatternCenters.Add(34); |
| m_alignmentPatternCenters.Add(62); |
| m_alignmentPatternCenters.Add(90); |
| break; |
| case 21: |
| m_alignmentPatternCenters.Add(6); |
| m_alignmentPatternCenters.Add(28); |
| m_alignmentPatternCenters.Add(50); |
| m_alignmentPatternCenters.Add(72); |
| m_alignmentPatternCenters.Add(94); |
| break; |
| case 22: |
| m_alignmentPatternCenters.Add(6); |
| m_alignmentPatternCenters.Add(26); |
| m_alignmentPatternCenters.Add(50); |
| m_alignmentPatternCenters.Add(74); |
| m_alignmentPatternCenters.Add(98); |
| break; |
| case 23: |
| m_alignmentPatternCenters.Add(6); |
| m_alignmentPatternCenters.Add(30); |
| m_alignmentPatternCenters.Add(54); |
| m_alignmentPatternCenters.Add(74); |
| m_alignmentPatternCenters.Add(102); |
| break; |
| case 24: |
| m_alignmentPatternCenters.Add(6); |
| m_alignmentPatternCenters.Add(28); |
| m_alignmentPatternCenters.Add(54); |
| m_alignmentPatternCenters.Add(80); |
| m_alignmentPatternCenters.Add(106); |
| break; |
| case 25: |
| m_alignmentPatternCenters.Add(6); |
| m_alignmentPatternCenters.Add(32); |
| m_alignmentPatternCenters.Add(58); |
| m_alignmentPatternCenters.Add(84); |
| m_alignmentPatternCenters.Add(110); |
| break; |
| case 26: |
| m_alignmentPatternCenters.Add(6); |
| m_alignmentPatternCenters.Add(30); |
| m_alignmentPatternCenters.Add(58); |
| m_alignmentPatternCenters.Add(86); |
| m_alignmentPatternCenters.Add(114); |
| break; |
| case 27: |
| m_alignmentPatternCenters.Add(6); |
| m_alignmentPatternCenters.Add(34); |
| m_alignmentPatternCenters.Add(62); |
| m_alignmentPatternCenters.Add(90); |
| m_alignmentPatternCenters.Add(118); |
| break; |
| case 28: |
| m_alignmentPatternCenters.Add(6); |
| m_alignmentPatternCenters.Add(26); |
| m_alignmentPatternCenters.Add(50); |
| m_alignmentPatternCenters.Add(74); |
| m_alignmentPatternCenters.Add(98); |
| m_alignmentPatternCenters.Add(122); |
| break; |
| case 29: |
| m_alignmentPatternCenters.Add(6); |
| m_alignmentPatternCenters.Add(30); |
| m_alignmentPatternCenters.Add(54); |
| m_alignmentPatternCenters.Add(78); |
| m_alignmentPatternCenters.Add(102); |
| m_alignmentPatternCenters.Add(126); |
| break; |
| case 30: |
| m_alignmentPatternCenters.Add(6); |
| m_alignmentPatternCenters.Add(26); |
| m_alignmentPatternCenters.Add(52); |
| m_alignmentPatternCenters.Add(78); |
| m_alignmentPatternCenters.Add(104); |
| m_alignmentPatternCenters.Add(130); |
| break; |
| case 31: |
| m_alignmentPatternCenters.Add(6); |
| m_alignmentPatternCenters.Add(30); |
| m_alignmentPatternCenters.Add(56); |
| m_alignmentPatternCenters.Add(82); |
| m_alignmentPatternCenters.Add(108); |
| m_alignmentPatternCenters.Add(134); |
| break; |
| case 32: |
| m_alignmentPatternCenters.Add(6); |
| m_alignmentPatternCenters.Add(34); |
| m_alignmentPatternCenters.Add(60); |
| m_alignmentPatternCenters.Add(86); |
| m_alignmentPatternCenters.Add(112); |
| m_alignmentPatternCenters.Add(138); |
| break; |
| case 33: |
| m_alignmentPatternCenters.Add(6); |
| m_alignmentPatternCenters.Add(30); |
| m_alignmentPatternCenters.Add(58); |
| m_alignmentPatternCenters.Add(86); |
| m_alignmentPatternCenters.Add(114); |
| m_alignmentPatternCenters.Add(142); |
| break; |
| case 34: |
| m_alignmentPatternCenters.Add(6); |
| m_alignmentPatternCenters.Add(34); |
| m_alignmentPatternCenters.Add(62); |
| m_alignmentPatternCenters.Add(90); |
| m_alignmentPatternCenters.Add(118); |
| m_alignmentPatternCenters.Add(146); |
| break; |
| case 35: |
| m_alignmentPatternCenters.Add(6); |
| m_alignmentPatternCenters.Add(30); |
| m_alignmentPatternCenters.Add(54); |
| m_alignmentPatternCenters.Add(78); |
| m_alignmentPatternCenters.Add(102); |
| m_alignmentPatternCenters.Add(126); |
| m_alignmentPatternCenters.Add(150); |
| break; |
| case 36: |
| m_alignmentPatternCenters.Add(6); |
| m_alignmentPatternCenters.Add(24); |
| m_alignmentPatternCenters.Add(50); |
| m_alignmentPatternCenters.Add(76); |
| m_alignmentPatternCenters.Add(102); |
| m_alignmentPatternCenters.Add(128); |
| m_alignmentPatternCenters.Add(154); |
| break; |
| case 37: |
| m_alignmentPatternCenters.Add(6); |
| m_alignmentPatternCenters.Add(28); |
| m_alignmentPatternCenters.Add(54); |
| m_alignmentPatternCenters.Add(80); |
| m_alignmentPatternCenters.Add(106); |
| m_alignmentPatternCenters.Add(132); |
| m_alignmentPatternCenters.Add(158); |
| break; |
| case 38: |
| m_alignmentPatternCenters.Add(6); |
| m_alignmentPatternCenters.Add(32); |
| m_alignmentPatternCenters.Add(58); |
| m_alignmentPatternCenters.Add(84); |
| m_alignmentPatternCenters.Add(110); |
| m_alignmentPatternCenters.Add(136); |
| m_alignmentPatternCenters.Add(162); |
| break; |
| case 39: |
| m_alignmentPatternCenters.Add(6); |
| m_alignmentPatternCenters.Add(26); |
| m_alignmentPatternCenters.Add(54); |
| m_alignmentPatternCenters.Add(82); |
| m_alignmentPatternCenters.Add(110); |
| m_alignmentPatternCenters.Add(138); |
| m_alignmentPatternCenters.Add(166); |
| break; |
| case 40: |
| m_alignmentPatternCenters.Add(6); |
| m_alignmentPatternCenters.Add(30); |
| m_alignmentPatternCenters.Add(58); |
| m_alignmentPatternCenters.Add(86); |
| m_alignmentPatternCenters.Add(114); |
| m_alignmentPatternCenters.Add(142); |
| m_alignmentPatternCenters.Add(170); |
| break; |
| } |
| } |
| |
| CBC_QRCoderVersion::~CBC_QRCoderVersion() { |
| for (int32_t i = 0; i < m_ecBlocksArray.GetSize(); ++i) |
| delete m_ecBlocksArray[i]; |
| } |
| |
| int32_t CBC_QRCoderVersion::GetVersionNumber() { |
| return m_versionNumber; |
| } |
| CFX_Int32Array* CBC_QRCoderVersion::GetAlignmentPatternCenters() { |
| return &m_alignmentPatternCenters; |
| } |
| int32_t CBC_QRCoderVersion::GetTotalCodeWords() { |
| return m_totalCodeWords; |
| } |
| int32_t CBC_QRCoderVersion::GetDimensionForVersion() { |
| return 17 + 4 * m_versionNumber; |
| } |
| CBC_QRCoderECBlocks* CBC_QRCoderVersion::GetECBlocksForLevel( |
| CBC_QRCoderErrorCorrectionLevel* ecLevel) { |
| return m_ecBlocksArray[ecLevel->Ordinal()]; |
| } |
| CBC_QRCoderVersion* CBC_QRCoderVersion::GetProvisionalVersionForDimension( |
| int32_t dimension, |
| int32_t& e) { |
| if ((dimension % 4) != 1) { |
| e = BCExceptionRead; |
| BC_EXCEPTION_CHECK_ReturnValue(e, nullptr); |
| } |
| CBC_QRCoderVersion* qcv = GetVersionForNumber((dimension - 17) >> 2, e); |
| BC_EXCEPTION_CHECK_ReturnValue(e, nullptr); |
| return qcv; |
| } |
| CBC_QRCoderVersion* CBC_QRCoderVersion::DecodeVersionInformation( |
| int32_t versionBits, |
| int32_t& e) { |
| int32_t bestDifference = FXSYS_IntMax; |
| int32_t bestVersion = 0; |
| for (int32_t i = 0; i < 34; i++) { |
| int32_t targetVersion = VERSION_DECODE_INFO[i]; |
| if (targetVersion == versionBits) { |
| CBC_QRCoderVersion* qcv = GetVersionForNumber(i + 7, e); |
| BC_EXCEPTION_CHECK_ReturnValue(e, nullptr); |
| return qcv; |
| } |
| int32_t bitsDifference = NumBitsDiffering(versionBits, targetVersion); |
| if (bitsDifference < bestDifference) { |
| bestVersion = i + 7; |
| bestDifference = bitsDifference; |
| } |
| } |
| if (bestDifference <= 3) { |
| CBC_QRCoderVersion* qcv = GetVersionForNumber(bestVersion, e); |
| BC_EXCEPTION_CHECK_ReturnValue(e, nullptr); |
| return qcv; |
| } |
| return nullptr; |
| } |
| CBC_CommonBitMatrix* CBC_QRCoderVersion::BuildFunctionPattern(int32_t& e) { |
| int32_t dimension = GetDimensionForVersion(); |
| CBC_CommonBitMatrix* bitMatrix = new CBC_CommonBitMatrix(); |
| bitMatrix->Init(dimension); |
| bitMatrix->SetRegion(0, 0, 9, 9, e); |
| BC_EXCEPTION_CHECK_ReturnValue(e, nullptr); |
| bitMatrix->SetRegion(dimension - 8, 0, 8, 9, e); |
| BC_EXCEPTION_CHECK_ReturnValue(e, nullptr); |
| bitMatrix->SetRegion(0, dimension - 8, 9, 8, e); |
| BC_EXCEPTION_CHECK_ReturnValue(e, nullptr); |
| int32_t max = m_alignmentPatternCenters.GetSize(); |
| for (int32_t x = 0; x < max; x++) { |
| int32_t i = m_alignmentPatternCenters[x] - 2; |
| for (int32_t y = 0; y < max; y++) { |
| if ((x == 0 && (y == 0 || y == max - 1)) || (x == max - 1 && y == 0)) { |
| continue; |
| } |
| bitMatrix->SetRegion(m_alignmentPatternCenters[y] - 2, i, 5, 5, e); |
| BC_EXCEPTION_CHECK_ReturnValue(e, nullptr); |
| } |
| } |
| bitMatrix->SetRegion(6, 9, 1, dimension - 17, e); |
| BC_EXCEPTION_CHECK_ReturnValue(e, nullptr); |
| bitMatrix->SetRegion(9, 6, dimension - 17, 1, e); |
| BC_EXCEPTION_CHECK_ReturnValue(e, nullptr); |
| if (m_versionNumber > 6) { |
| bitMatrix->SetRegion(dimension - 11, 0, 3, 6, e); |
| BC_EXCEPTION_CHECK_ReturnValue(e, nullptr); |
| bitMatrix->SetRegion(0, dimension - 11, 6, 3, e); |
| BC_EXCEPTION_CHECK_ReturnValue(e, nullptr); |
| } |
| return bitMatrix; |
| } |
| CBC_QRCoderVersion* CBC_QRCoderVersion::GetVersionForNumber( |
| int32_t versionNumber, |
| int32_t& e) { |
| if (VERSION->GetSize() == 0) { |
| VERSION->Add(new CBC_QRCoderVersion( |
| 1, new CBC_QRCoderECBlocks(7, new CBC_QRCoderECB(1, 19)), |
| new CBC_QRCoderECBlocks(10, new CBC_QRCoderECB(1, 16)), |
| new CBC_QRCoderECBlocks(13, new CBC_QRCoderECB(1, 13)), |
| new CBC_QRCoderECBlocks(17, new CBC_QRCoderECB(1, 9)))); |
| VERSION->Add(new CBC_QRCoderVersion( |
| 2, new CBC_QRCoderECBlocks(10, new CBC_QRCoderECB(1, 34)), |
| new CBC_QRCoderECBlocks(16, new CBC_QRCoderECB(1, 28)), |
| new CBC_QRCoderECBlocks(22, new CBC_QRCoderECB(1, 22)), |
| new CBC_QRCoderECBlocks(28, new CBC_QRCoderECB(1, 16)))); |
| VERSION->Add(new CBC_QRCoderVersion( |
| 3, new CBC_QRCoderECBlocks(15, new CBC_QRCoderECB(1, 55)), |
| new CBC_QRCoderECBlocks(26, new CBC_QRCoderECB(1, 44)), |
| new CBC_QRCoderECBlocks(18, new CBC_QRCoderECB(2, 17)), |
| new CBC_QRCoderECBlocks(22, new CBC_QRCoderECB(2, 13)))); |
| VERSION->Add(new CBC_QRCoderVersion( |
| 4, new CBC_QRCoderECBlocks(20, new CBC_QRCoderECB(1, 80)), |
| new CBC_QRCoderECBlocks(18, new CBC_QRCoderECB(2, 32)), |
| new CBC_QRCoderECBlocks(26, new CBC_QRCoderECB(2, 24)), |
| new CBC_QRCoderECBlocks(16, new CBC_QRCoderECB(4, 9)))); |
| VERSION->Add(new CBC_QRCoderVersion( |
| 5, new CBC_QRCoderECBlocks(26, new CBC_QRCoderECB(1, 108)), |
| new CBC_QRCoderECBlocks(24, new CBC_QRCoderECB(2, 43)), |
| new CBC_QRCoderECBlocks(18, new CBC_QRCoderECB(2, 15), |
| new CBC_QRCoderECB(2, 16)), |
| new CBC_QRCoderECBlocks(22, new CBC_QRCoderECB(2, 11), |
| new CBC_QRCoderECB(2, 12)))); |
| VERSION->Add(new CBC_QRCoderVersion( |
| 6, new CBC_QRCoderECBlocks(18, new CBC_QRCoderECB(2, 68)), |
| new CBC_QRCoderECBlocks(16, new CBC_QRCoderECB(4, 27)), |
| new CBC_QRCoderECBlocks(24, new CBC_QRCoderECB(4, 19)), |
| new CBC_QRCoderECBlocks(28, new CBC_QRCoderECB(4, 15)))); |
| VERSION->Add(new CBC_QRCoderVersion( |
| 7, new CBC_QRCoderECBlocks(20, new CBC_QRCoderECB(2, 78)), |
| new CBC_QRCoderECBlocks(18, new CBC_QRCoderECB(4, 31)), |
| new CBC_QRCoderECBlocks(18, new CBC_QRCoderECB(2, 14), |
| new CBC_QRCoderECB(4, 15)), |
| new CBC_QRCoderECBlocks(26, new CBC_QRCoderECB(4, 13), |
| new CBC_QRCoderECB(1, 14)))); |
| VERSION->Add(new CBC_QRCoderVersion( |
| 8, new CBC_QRCoderECBlocks(24, new CBC_QRCoderECB(2, 97)), |
| new CBC_QRCoderECBlocks(22, new CBC_QRCoderECB(2, 38), |
| new CBC_QRCoderECB(2, 39)), |
| new CBC_QRCoderECBlocks(22, new CBC_QRCoderECB(4, 18), |
| new CBC_QRCoderECB(2, 19)), |
| new CBC_QRCoderECBlocks(26, new CBC_QRCoderECB(4, 14), |
| new CBC_QRCoderECB(2, 15)))); |
| VERSION->Add(new CBC_QRCoderVersion( |
| 9, new CBC_QRCoderECBlocks(30, new CBC_QRCoderECB(2, 116)), |
| new CBC_QRCoderECBlocks(22, new CBC_QRCoderECB(3, 36), |
| new CBC_QRCoderECB(2, 37)), |
| new CBC_QRCoderECBlocks(20, new CBC_QRCoderECB(4, 16), |
| new CBC_QRCoderECB(4, 17)), |
| new CBC_QRCoderECBlocks(24, new CBC_QRCoderECB(4, 12), |
| new CBC_QRCoderECB(4, 13)))); |
| VERSION->Add(new CBC_QRCoderVersion( |
| 10, new CBC_QRCoderECBlocks(18, new CBC_QRCoderECB(2, 68), |
| new CBC_QRCoderECB(2, 69)), |
| new CBC_QRCoderECBlocks(26, new CBC_QRCoderECB(4, 43), |
| new CBC_QRCoderECB(1, 44)), |
| new CBC_QRCoderECBlocks(24, new CBC_QRCoderECB(6, 19), |
| new CBC_QRCoderECB(2, 20)), |
| new CBC_QRCoderECBlocks(28, new CBC_QRCoderECB(6, 15), |
| new CBC_QRCoderECB(2, 16)))); |
| VERSION->Add(new CBC_QRCoderVersion( |
| 11, new CBC_QRCoderECBlocks(20, new CBC_QRCoderECB(4, 81)), |
| new CBC_QRCoderECBlocks(30, new CBC_QRCoderECB(1, 50), |
| new CBC_QRCoderECB(4, 51)), |
| new CBC_QRCoderECBlocks(28, new CBC_QRCoderECB(4, 22), |
| new CBC_QRCoderECB(4, 23)), |
| new CBC_QRCoderECBlocks(24, new CBC_QRCoderECB(3, 12), |
| new CBC_QRCoderECB(8, 13)))); |
| VERSION->Add(new CBC_QRCoderVersion( |
| 12, new CBC_QRCoderECBlocks(24, new CBC_QRCoderECB(2, 92), |
| new CBC_QRCoderECB(2, 93)), |
| new CBC_QRCoderECBlocks(22, new CBC_QRCoderECB(6, 36), |
| new CBC_QRCoderECB(2, 37)), |
| new CBC_QRCoderECBlocks(26, new CBC_QRCoderECB(4, 20), |
| new CBC_QRCoderECB(6, 21)), |
| new CBC_QRCoderECBlocks(28, new CBC_QRCoderECB(7, 14), |
| new CBC_QRCoderECB(4, 15)))); |
| VERSION->Add(new CBC_QRCoderVersion( |
| 13, new CBC_QRCoderECBlocks(26, new CBC_QRCoderECB(4, 107)), |
| new CBC_QRCoderECBlocks(22, new CBC_QRCoderECB(8, 37), |
| new CBC_QRCoderECB(1, 38)), |
| new CBC_QRCoderECBlocks(24, new CBC_QRCoderECB(8, 20), |
| new CBC_QRCoderECB(4, 21)), |
| new CBC_QRCoderECBlocks(22, new CBC_QRCoderECB(12, 11), |
| new CBC_QRCoderECB(4, 12)))); |
| VERSION->Add(new CBC_QRCoderVersion( |
| 14, new CBC_QRCoderECBlocks(30, new CBC_QRCoderECB(3, 115), |
| new CBC_QRCoderECB(1, 116)), |
| new CBC_QRCoderECBlocks(24, new CBC_QRCoderECB(4, 40), |
| new CBC_QRCoderECB(5, 41)), |
| new CBC_QRCoderECBlocks(20, new CBC_QRCoderECB(11, 16), |
| new CBC_QRCoderECB(5, 17)), |
| new CBC_QRCoderECBlocks(24, new CBC_QRCoderECB(11, 12), |
| new CBC_QRCoderECB(5, 13)))); |
| VERSION->Add(new CBC_QRCoderVersion( |
| 15, new CBC_QRCoderECBlocks(22, new CBC_QRCoderECB(5, 87), |
| new CBC_QRCoderECB(1, 88)), |
| new CBC_QRCoderECBlocks(24, new CBC_QRCoderECB(5, 41), |
| new CBC_QRCoderECB(5, 42)), |
| new CBC_QRCoderECBlocks(30, new CBC_QRCoderECB(5, 24), |
| new CBC_QRCoderECB(7, 25)), |
| new CBC_QRCoderECBlocks(24, new CBC_QRCoderECB(11, 12), |
| new CBC_QRCoderECB(7, 13)))); |
| VERSION->Add(new CBC_QRCoderVersion( |
| 16, new CBC_QRCoderECBlocks(24, new CBC_QRCoderECB(5, 98), |
| new CBC_QRCoderECB(1, 99)), |
| new CBC_QRCoderECBlocks(28, new CBC_QRCoderECB(7, 45), |
| new CBC_QRCoderECB(3, 46)), |
| new CBC_QRCoderECBlocks(24, new CBC_QRCoderECB(15, 19), |
| new CBC_QRCoderECB(2, 20)), |
| new CBC_QRCoderECBlocks(30, new CBC_QRCoderECB(3, 15), |
| new CBC_QRCoderECB(13, 16)))); |
| VERSION->Add(new CBC_QRCoderVersion( |
| 17, new CBC_QRCoderECBlocks(28, new CBC_QRCoderECB(1, 107), |
| new CBC_QRCoderECB(5, 108)), |
| new CBC_QRCoderECBlocks(28, new CBC_QRCoderECB(10, 46), |
| new CBC_QRCoderECB(1, 47)), |
| new CBC_QRCoderECBlocks(28, new CBC_QRCoderECB(1, 22), |
| new CBC_QRCoderECB(15, 23)), |
| new CBC_QRCoderECBlocks(28, new CBC_QRCoderECB(2, 14), |
| new CBC_QRCoderECB(17, 15)))); |
| VERSION->Add(new CBC_QRCoderVersion( |
| 18, new CBC_QRCoderECBlocks(30, new CBC_QRCoderECB(5, 120), |
| new CBC_QRCoderECB(1, 121)), |
| new CBC_QRCoderECBlocks(26, new CBC_QRCoderECB(9, 43), |
| new CBC_QRCoderECB(4, 44)), |
| new CBC_QRCoderECBlocks(28, new CBC_QRCoderECB(17, 22), |
| new CBC_QRCoderECB(1, 23)), |
| new CBC_QRCoderECBlocks(28, new CBC_QRCoderECB(2, 14), |
| new CBC_QRCoderECB(19, 15)))); |
| VERSION->Add(new CBC_QRCoderVersion( |
| 19, new CBC_QRCoderECBlocks(28, new CBC_QRCoderECB(3, 113), |
| new CBC_QRCoderECB(4, 114)), |
| new CBC_QRCoderECBlocks(26, new CBC_QRCoderECB(3, 44), |
| new CBC_QRCoderECB(11, 45)), |
| new CBC_QRCoderECBlocks(26, new CBC_QRCoderECB(17, 21), |
| new CBC_QRCoderECB(4, 22)), |
| new CBC_QRCoderECBlocks(26, new CBC_QRCoderECB(9, 13), |
| new CBC_QRCoderECB(16, 14)))); |
| VERSION->Add(new CBC_QRCoderVersion( |
| 20, new CBC_QRCoderECBlocks(28, new CBC_QRCoderECB(3, 107), |
| new CBC_QRCoderECB(5, 108)), |
| new CBC_QRCoderECBlocks(26, new CBC_QRCoderECB(3, 41), |
| new CBC_QRCoderECB(13, 42)), |
| new CBC_QRCoderECBlocks(30, new CBC_QRCoderECB(15, 24), |
| new CBC_QRCoderECB(5, 25)), |
| new CBC_QRCoderECBlocks(28, new CBC_QRCoderECB(15, 15), |
| new CBC_QRCoderECB(10, 16)))); |
| VERSION->Add(new CBC_QRCoderVersion( |
| 21, new CBC_QRCoderECBlocks(28, new CBC_QRCoderECB(4, 116), |
| new CBC_QRCoderECB(4, 117)), |
| new CBC_QRCoderECBlocks(26, new CBC_QRCoderECB(17, 42)), |
| new CBC_QRCoderECBlocks(28, new CBC_QRCoderECB(17, 22), |
| new CBC_QRCoderECB(6, 23)), |
| new CBC_QRCoderECBlocks(30, new CBC_QRCoderECB(19, 16), |
| new CBC_QRCoderECB(6, 17)))); |
| VERSION->Add(new CBC_QRCoderVersion( |
| 22, new CBC_QRCoderECBlocks(28, new CBC_QRCoderECB(2, 111), |
| new CBC_QRCoderECB(7, 112)), |
| new CBC_QRCoderECBlocks(28, new CBC_QRCoderECB(17, 46)), |
| new CBC_QRCoderECBlocks(30, new CBC_QRCoderECB(7, 24), |
| new CBC_QRCoderECB(16, 25)), |
| new CBC_QRCoderECBlocks(24, new CBC_QRCoderECB(34, 13)))); |
| VERSION->Add(new CBC_QRCoderVersion( |
| 23, new CBC_QRCoderECBlocks(30, new CBC_QRCoderECB(4, 121), |
| new CBC_QRCoderECB(5, 122)), |
| new CBC_QRCoderECBlocks(28, new CBC_QRCoderECB(4, 47), |
| new CBC_QRCoderECB(14, 48)), |
| new CBC_QRCoderECBlocks(30, new CBC_QRCoderECB(11, 24), |
| new CBC_QRCoderECB(14, 25)), |
| new CBC_QRCoderECBlocks(30, new CBC_QRCoderECB(16, 15), |
| new CBC_QRCoderECB(14, 16)))); |
| VERSION->Add(new CBC_QRCoderVersion( |
| 24, new CBC_QRCoderECBlocks(30, new CBC_QRCoderECB(6, 117), |
| new CBC_QRCoderECB(4, 118)), |
| new CBC_QRCoderECBlocks(28, new CBC_QRCoderECB(6, 45), |
| new CBC_QRCoderECB(14, 46)), |
| new CBC_QRCoderECBlocks(30, new CBC_QRCoderECB(11, 24), |
| new CBC_QRCoderECB(16, 25)), |
| new CBC_QRCoderECBlocks(30, new CBC_QRCoderECB(30, 16), |
| new CBC_QRCoderECB(2, 17)))); |
| VERSION->Add(new CBC_QRCoderVersion( |
| 25, new CBC_QRCoderECBlocks(26, new CBC_QRCoderECB(8, 106), |
| new CBC_QRCoderECB(4, 107)), |
| new CBC_QRCoderECBlocks(28, new CBC_QRCoderECB(8, 47), |
| new CBC_QRCoderECB(13, 48)), |
| new CBC_QRCoderECBlocks(30, new CBC_QRCoderECB(7, 24), |
| new CBC_QRCoderECB(22, 25)), |
| new CBC_QRCoderECBlocks(30, new CBC_QRCoderECB(22, 15), |
| new CBC_QRCoderECB(13, 16)))); |
| VERSION->Add(new CBC_QRCoderVersion( |
| 26, new CBC_QRCoderECBlocks(28, new CBC_QRCoderECB(10, 114), |
| new CBC_QRCoderECB(2, 115)), |
| new CBC_QRCoderECBlocks(28, new CBC_QRCoderECB(19, 46), |
| new CBC_QRCoderECB(4, 47)), |
| new CBC_QRCoderECBlocks(28, new CBC_QRCoderECB(28, 22), |
| new CBC_QRCoderECB(6, 23)), |
| new CBC_QRCoderECBlocks(30, new CBC_QRCoderECB(33, 16), |
| new CBC_QRCoderECB(4, 17)))); |
| VERSION->Add(new CBC_QRCoderVersion( |
| 27, new CBC_QRCoderECBlocks(30, new CBC_QRCoderECB(8, 122), |
| new CBC_QRCoderECB(4, 123)), |
| new CBC_QRCoderECBlocks(28, new CBC_QRCoderECB(22, 45), |
| new CBC_QRCoderECB(3, 46)), |
| new CBC_QRCoderECBlocks(30, new CBC_QRCoderECB(8, 23), |
| new CBC_QRCoderECB(26, 24)), |
| new CBC_QRCoderECBlocks(30, new CBC_QRCoderECB(12, 15), |
| new CBC_QRCoderECB(28, 16)))); |
| VERSION->Add(new CBC_QRCoderVersion( |
| 28, new CBC_QRCoderECBlocks(30, new CBC_QRCoderECB(3, 117), |
| new CBC_QRCoderECB(10, 118)), |
| new CBC_QRCoderECBlocks(28, new CBC_QRCoderECB(3, 45), |
| new CBC_QRCoderECB(23, 46)), |
| new CBC_QRCoderECBlocks(30, new CBC_QRCoderECB(4, 24), |
| new CBC_QRCoderECB(31, 25)), |
| new CBC_QRCoderECBlocks(30, new CBC_QRCoderECB(11, 15), |
| new CBC_QRCoderECB(31, 16)))); |
| VERSION->Add(new CBC_QRCoderVersion( |
| 29, new CBC_QRCoderECBlocks(30, new CBC_QRCoderECB(7, 116), |
| new CBC_QRCoderECB(7, 117)), |
| new CBC_QRCoderECBlocks(28, new CBC_QRCoderECB(21, 45), |
| new CBC_QRCoderECB(7, 46)), |
| new CBC_QRCoderECBlocks(30, new CBC_QRCoderECB(1, 23), |
| new CBC_QRCoderECB(37, 24)), |
| new CBC_QRCoderECBlocks(30, new CBC_QRCoderECB(19, 15), |
| new CBC_QRCoderECB(26, 16)))); |
| VERSION->Add(new CBC_QRCoderVersion( |
| 30, new CBC_QRCoderECBlocks(30, new CBC_QRCoderECB(5, 115), |
| new CBC_QRCoderECB(10, 116)), |
| new CBC_QRCoderECBlocks(28, new CBC_QRCoderECB(19, 47), |
| new CBC_QRCoderECB(10, 48)), |
| new CBC_QRCoderECBlocks(30, new CBC_QRCoderECB(15, 24), |
| new CBC_QRCoderECB(25, 25)), |
| new CBC_QRCoderECBlocks(30, new CBC_QRCoderECB(23, 15), |
| new CBC_QRCoderECB(25, 16)))); |
| VERSION->Add(new CBC_QRCoderVersion( |
| 31, new CBC_QRCoderECBlocks(30, new CBC_QRCoderECB(13, 115), |
| new CBC_QRCoderECB(3, 116)), |
| new CBC_QRCoderECBlocks(28, new CBC_QRCoderECB(2, 46), |
| new CBC_QRCoderECB(29, 47)), |
| new CBC_QRCoderECBlocks(30, new CBC_QRCoderECB(42, 24), |
| new CBC_QRCoderECB(1, 25)), |
| new CBC_QRCoderECBlocks(30, new CBC_QRCoderECB(23, 15), |
| new CBC_QRCoderECB(28, 16)))); |
| VERSION->Add(new CBC_QRCoderVersion( |
| 32, new CBC_QRCoderECBlocks(30, new CBC_QRCoderECB(17, 115)), |
| new CBC_QRCoderECBlocks(28, new CBC_QRCoderECB(10, 46), |
| new CBC_QRCoderECB(23, 47)), |
| new CBC_QRCoderECBlocks(30, new CBC_QRCoderECB(10, 24), |
| new CBC_QRCoderECB(35, 25)), |
| new CBC_QRCoderECBlocks(30, new CBC_QRCoderECB(19, 15), |
| new CBC_QRCoderECB(35, 16)))); |
| VERSION->Add(new CBC_QRCoderVersion( |
| 33, new CBC_QRCoderECBlocks(30, new CBC_QRCoderECB(17, 115), |
| new CBC_QRCoderECB(1, 116)), |
| new CBC_QRCoderECBlocks(28, new CBC_QRCoderECB(14, 46), |
| new CBC_QRCoderECB(21, 47)), |
| new CBC_QRCoderECBlocks(30, new CBC_QRCoderECB(29, 24), |
| new CBC_QRCoderECB(19, 25)), |
| new CBC_QRCoderECBlocks(30, new CBC_QRCoderECB(11, 15), |
| new CBC_QRCoderECB(46, 16)))); |
| VERSION->Add(new CBC_QRCoderVersion( |
| 34, new CBC_QRCoderECBlocks(30, new CBC_QRCoderECB(13, 115), |
| new CBC_QRCoderECB(6, 116)), |
| new CBC_QRCoderECBlocks(28, new CBC_QRCoderECB(14, 46), |
| new CBC_QRCoderECB(23, 47)), |
| new CBC_QRCoderECBlocks(30, new CBC_QRCoderECB(44, 24), |
| new CBC_QRCoderECB(7, 25)), |
| new CBC_QRCoderECBlocks(30, new CBC_QRCoderECB(59, 16), |
| new CBC_QRCoderECB(1, 17)))); |
| VERSION->Add(new CBC_QRCoderVersion( |
| 35, new CBC_QRCoderECBlocks(30, new CBC_QRCoderECB(12, 121), |
| new CBC_QRCoderECB(7, 122)), |
| new CBC_QRCoderECBlocks(28, new CBC_QRCoderECB(12, 47), |
| new CBC_QRCoderECB(26, 48)), |
| new CBC_QRCoderECBlocks(30, new CBC_QRCoderECB(39, 24), |
| new CBC_QRCoderECB(14, 25)), |
| new CBC_QRCoderECBlocks(30, new CBC_QRCoderECB(22, 15), |
| new CBC_QRCoderECB(41, 16)))); |
| VERSION->Add(new CBC_QRCoderVersion( |
| 36, new CBC_QRCoderECBlocks(30, new CBC_QRCoderECB(6, 121), |
| new CBC_QRCoderECB(14, 122)), |
| new CBC_QRCoderECBlocks(28, new CBC_QRCoderECB(6, 47), |
| new CBC_QRCoderECB(34, 48)), |
| new CBC_QRCoderECBlocks(30, new CBC_QRCoderECB(46, 24), |
| new CBC_QRCoderECB(10, 25)), |
| new CBC_QRCoderECBlocks(30, new CBC_QRCoderECB(2, 15), |
| new CBC_QRCoderECB(64, 16)))); |
| VERSION->Add(new CBC_QRCoderVersion( |
| 37, new CBC_QRCoderECBlocks(30, new CBC_QRCoderECB(17, 122), |
| new CBC_QRCoderECB(4, 123)), |
| new CBC_QRCoderECBlocks(28, new CBC_QRCoderECB(29, 46), |
| new CBC_QRCoderECB(14, 47)), |
| new CBC_QRCoderECBlocks(30, new CBC_QRCoderECB(49, 24), |
| new CBC_QRCoderECB(10, 25)), |
| new CBC_QRCoderECBlocks(30, new CBC_QRCoderECB(24, 15), |
| new CBC_QRCoderECB(46, 16)))); |
| VERSION->Add(new CBC_QRCoderVersion( |
| 38, new CBC_QRCoderECBlocks(30, new CBC_QRCoderECB(4, 122), |
| new CBC_QRCoderECB(18, 123)), |
| new CBC_QRCoderECBlocks(28, new CBC_QRCoderECB(13, 46), |
| new CBC_QRCoderECB(32, 47)), |
| new CBC_QRCoderECBlocks(30, new CBC_QRCoderECB(48, 24), |
| new CBC_QRCoderECB(14, 25)), |
| new CBC_QRCoderECBlocks(30, new CBC_QRCoderECB(42, 15), |
| new CBC_QRCoderECB(32, 16)))); |
| VERSION->Add(new CBC_QRCoderVersion( |
| 39, new CBC_QRCoderECBlocks(30, new CBC_QRCoderECB(20, 117), |
| new CBC_QRCoderECB(4, 118)), |
| new CBC_QRCoderECBlocks(28, new CBC_QRCoderECB(40, 47), |
| new CBC_QRCoderECB(7, 48)), |
| new CBC_QRCoderECBlocks(30, new CBC_QRCoderECB(43, 24), |
| new CBC_QRCoderECB(22, 25)), |
| new CBC_QRCoderECBlocks(30, new CBC_QRCoderECB(10, 15), |
| new CBC_QRCoderECB(67, 16)))); |
| VERSION->Add(new CBC_QRCoderVersion( |
| 40, new CBC_QRCoderECBlocks(30, new CBC_QRCoderECB(19, 118), |
| new CBC_QRCoderECB(6, 119)), |
| new CBC_QRCoderECBlocks(28, new CBC_QRCoderECB(18, 47), |
| new CBC_QRCoderECB(31, 48)), |
| new CBC_QRCoderECBlocks(30, new CBC_QRCoderECB(34, 24), |
| new CBC_QRCoderECB(34, 25)), |
| new CBC_QRCoderECBlocks(30, new CBC_QRCoderECB(20, 15), |
| new CBC_QRCoderECB(61, 16)))); |
| } |
| if (versionNumber < 1 || versionNumber > 40) { |
| e = BCExceptionIllegalArgument; |
| BC_EXCEPTION_CHECK_ReturnValue(e, nullptr); |
| } |
| return (*VERSION)[versionNumber - 1]; |
| } |
| |
| void CBC_QRCoderVersion::Destroy() { |
| for (int32_t i = 0; i < VERSION->GetSize(); i++) |
| delete (*VERSION)[i]; |
| VERSION->RemoveAll(); |
| } |