| 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 2008 ZXing authors | 8 * Copyright 2008 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 238 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 249 e = BCExceptionNoSuchVersion; | 249 e = BCExceptionNoSuchVersion; |
| 250 BC_EXCEPTION_CHECK_ReturnValue(e, 0); | 250 BC_EXCEPTION_CHECK_ReturnValue(e, 0); |
| 251 } | 251 } |
| 252 } | 252 } |
| 253 return -1; | 253 return -1; |
| 254 } | 254 } |
| 255 | 255 |
| 256 void CBC_QRCoderEncoder::MergeString(CFX_ArrayTemplate<Make_Pair*>* result, | 256 void CBC_QRCoderEncoder::MergeString(CFX_ArrayTemplate<Make_Pair*>* result, |
| 257 int32_t versionNum, | 257 int32_t versionNum, |
| 258 int32_t& e) { | 258 int32_t& e) { |
| 259 Make_Pair* first = NULL; | 259 Make_Pair* first = nullptr; |
| 260 Make_Pair* second = NULL; | 260 Make_Pair* second = nullptr; |
| 261 size_t mergeNum = 0; | 261 size_t mergeNum = 0; |
| 262 int32_t i; | 262 int32_t i; |
| 263 for (i = 0; ((i < result->GetSize()) && (i + 1 < result->GetSize())); i++) { | 263 for (i = 0; ((i < result->GetSize()) && (i + 1 < result->GetSize())); i++) { |
| 264 first = (*result)[i]; | 264 first = (*result)[i]; |
| 265 second = (*result)[i + 1]; | 265 second = (*result)[i + 1]; |
| 266 if (first->m_mode == CBC_QRCoderMode::sALPHANUMERIC) { | 266 if (first->m_mode == CBC_QRCoderMode::sALPHANUMERIC) { |
| 267 int32_t tmp = GetSpanByVersion(CBC_QRCoderMode::sALPHANUMERIC, | 267 int32_t tmp = GetSpanByVersion(CBC_QRCoderMode::sALPHANUMERIC, |
| 268 CBC_QRCoderMode::sBYTE, versionNum, e); | 268 CBC_QRCoderMode::sBYTE, versionNum, e); |
| 269 BC_EXCEPTION_CHECK_ReturnVoid(e); | 269 BC_EXCEPTION_CHECK_ReturnVoid(e); |
| 270 if ((second->m_mode == CBC_QRCoderMode::sBYTE) && | 270 if ((second->m_mode == CBC_QRCoderMode::sBYTE) && |
| (...skipping 80 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 351 CBC_QRCoder* qrCode, | 351 CBC_QRCoder* qrCode, |
| 352 int32_t versionSpecify, | 352 int32_t versionSpecify, |
| 353 int32_t& e) { | 353 int32_t& e) { |
| 354 CFX_ByteString encoding = "utf8"; | 354 CFX_ByteString encoding = "utf8"; |
| 355 CBC_QRCoderMode* mode = CBC_QRCoderMode::sBYTE; | 355 CBC_QRCoderMode* mode = CBC_QRCoderMode::sBYTE; |
| 356 CFX_ArrayTemplate<Make_Pair*> splitResult; | 356 CFX_ArrayTemplate<Make_Pair*> splitResult; |
| 357 CBC_QRCoderBitVector dataBits; | 357 CBC_QRCoderBitVector dataBits; |
| 358 dataBits.Init(); | 358 dataBits.Init(); |
| 359 SplitString(content, &splitResult); | 359 SplitString(content, &splitResult); |
| 360 MergeString(&splitResult, versionSpecify, e); | 360 MergeString(&splitResult, versionSpecify, e); |
| 361 BC_EXCEPTION_CHECK_ReturnVoid(e) CBC_QRCoderMode* tempMode = NULL; | 361 BC_EXCEPTION_CHECK_ReturnVoid(e) CBC_QRCoderMode* tempMode = nullptr; |
| 362 for (int32_t i = 0; i < splitResult.GetSize(); i++) { | 362 for (int32_t i = 0; i < splitResult.GetSize(); i++) { |
| 363 AppendBytes(splitResult[i]->m_string, splitResult[i]->m_mode, &dataBits, | 363 AppendBytes(splitResult[i]->m_string, splitResult[i]->m_mode, &dataBits, |
| 364 encoding, e); | 364 encoding, e); |
| 365 if (e != BCExceptionNO) { | 365 if (e != BCExceptionNO) { |
| 366 for (int32_t y = 0; y < splitResult.GetSize(); y++) | 366 for (int32_t y = 0; y < splitResult.GetSize(); y++) |
| 367 delete splitResult[y]; | 367 delete splitResult[y]; |
| 368 return; | 368 return; |
| 369 } | 369 } |
| 370 } | 370 } |
| 371 int32_t numInputBytes = dataBits.sizeInBytes(); | 371 int32_t numInputBytes = dataBits.sizeInBytes(); |
| (...skipping 49 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 421 CBC_QRCoder* qrCode, | 421 CBC_QRCoder* qrCode, |
| 422 int32_t& e) { | 422 int32_t& e) { |
| 423 CFX_ByteString encoding = "utf8"; | 423 CFX_ByteString encoding = "utf8"; |
| 424 CBC_QRCoderMode* mode = CBC_QRCoderMode::sBYTE; | 424 CBC_QRCoderMode* mode = CBC_QRCoderMode::sBYTE; |
| 425 CFX_ArrayTemplate<Make_Pair*> splitResult; | 425 CFX_ArrayTemplate<Make_Pair*> splitResult; |
| 426 CBC_QRCoderBitVector dataBits; | 426 CBC_QRCoderBitVector dataBits; |
| 427 dataBits.Init(); | 427 dataBits.Init(); |
| 428 SplitString(content, &splitResult); | 428 SplitString(content, &splitResult); |
| 429 MergeString(&splitResult, 8, e); | 429 MergeString(&splitResult, 8, e); |
| 430 BC_EXCEPTION_CHECK_ReturnVoid(e); | 430 BC_EXCEPTION_CHECK_ReturnVoid(e); |
| 431 CBC_QRCoderMode* tempMode = NULL; | 431 CBC_QRCoderMode* tempMode = nullptr; |
| 432 for (int32_t i = 0; i < splitResult.GetSize(); i++) { | 432 for (int32_t i = 0; i < splitResult.GetSize(); i++) { |
| 433 AppendBytes(splitResult[i]->m_string, splitResult[i]->m_mode, &dataBits, | 433 AppendBytes(splitResult[i]->m_string, splitResult[i]->m_mode, &dataBits, |
| 434 encoding, e); | 434 encoding, e); |
| 435 if (e != BCExceptionNO) { | 435 if (e != BCExceptionNO) { |
| 436 for (int32_t l = 0; l < splitResult.GetSize(); l++) | 436 for (int32_t l = 0; l < splitResult.GetSize(); l++) |
| 437 delete splitResult[l]; | 437 delete splitResult[l]; |
| 438 return; | 438 return; |
| 439 } | 439 } |
| 440 } | 440 } |
| 441 int32_t numInputBytes = dataBits.sizeInBytes(); | 441 int32_t numInputBytes = dataBits.sizeInBytes(); |
| 442 InitQRCode(numInputBytes, ecLevel, mode, qrCode, e); | 442 InitQRCode(numInputBytes, ecLevel, mode, qrCode, e); |
| 443 BC_EXCEPTION_CHECK_ReturnVoid(e) CBC_QRCoderBitVector headerAndDataBits; | 443 BC_EXCEPTION_CHECK_ReturnVoid(e) CBC_QRCoderBitVector headerAndDataBits; |
| 444 headerAndDataBits.Init(); | 444 headerAndDataBits.Init(); |
| 445 tempMode = NULL; | 445 tempMode = nullptr; |
| 446 int32_t versionNum = qrCode->GetVersion(); | 446 int32_t versionNum = qrCode->GetVersion(); |
| 447 sign: | 447 sign: |
| 448 AppendDataModeLenghInfo(splitResult, headerAndDataBits, tempMode, qrCode, | 448 AppendDataModeLenghInfo(splitResult, headerAndDataBits, tempMode, qrCode, |
| 449 encoding, e); | 449 encoding, e); |
| 450 if (e != BCExceptionNO) { | 450 if (e != BCExceptionNO) { |
| 451 goto catchException; | 451 goto catchException; |
| 452 } | 452 } |
| 453 numInputBytes = headerAndDataBits.sizeInBytes(); | 453 numInputBytes = headerAndDataBits.sizeInBytes(); |
| 454 TerminateBits(qrCode->GetNumDataBytes(), &headerAndDataBits, e); | 454 TerminateBits(qrCode->GetNumDataBytes(), &headerAndDataBits, e); |
| 455 if (e != BCExceptionNO) { | 455 if (e != BCExceptionNO) { |
| (...skipping 471 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 927 int32_t& e) { | 927 int32_t& e) { |
| 928 int32_t numDataBytes = dataBytes->Size(); | 928 int32_t numDataBytes = dataBytes->Size(); |
| 929 CFX_Int32Array toEncode; | 929 CFX_Int32Array toEncode; |
| 930 toEncode.SetSize(numDataBytes + numEcBytesInBlock); | 930 toEncode.SetSize(numDataBytes + numEcBytesInBlock); |
| 931 for (int32_t i = 0; i < numDataBytes; i++) { | 931 for (int32_t i = 0; i < numDataBytes; i++) { |
| 932 toEncode[i] = (dataBytes->At(i)); | 932 toEncode[i] = (dataBytes->At(i)); |
| 933 } | 933 } |
| 934 CBC_ReedSolomonEncoder encode(CBC_ReedSolomonGF256::QRCodeFild); | 934 CBC_ReedSolomonEncoder encode(CBC_ReedSolomonGF256::QRCodeFild); |
| 935 encode.Init(); | 935 encode.Init(); |
| 936 encode.Encode(&toEncode, numEcBytesInBlock, e); | 936 encode.Encode(&toEncode, numEcBytesInBlock, e); |
| 937 BC_EXCEPTION_CHECK_ReturnValue(e, NULL); | 937 BC_EXCEPTION_CHECK_ReturnValue(e, nullptr); |
| 938 CBC_CommonByteArray* ecBytes = new CBC_CommonByteArray(numEcBytesInBlock); | 938 CBC_CommonByteArray* ecBytes = new CBC_CommonByteArray(numEcBytesInBlock); |
| 939 for (int32_t j = 0; j < numEcBytesInBlock; j++) { | 939 for (int32_t j = 0; j < numEcBytesInBlock; j++) { |
| 940 ecBytes->Set(j, toEncode[numDataBytes + j]); | 940 ecBytes->Set(j, toEncode[numDataBytes + j]); |
| 941 } | 941 } |
| 942 return ecBytes; | 942 return ecBytes; |
| 943 } | 943 } |
| OLD | NEW |