1 // Copyright 2014 PDFium Authors. All rights reserved.
2 // Use of this source code is governed by a BSD-style license that can be
3 // found in the LICENSE file.
4
5 // Original code copyright 2014 Foxit Software Inc. http://www.foxitsoftware.com
6 // Original code is licensed as follows:
7 /*
8 * Copyright 2007 ZXing authors
9 *
10 * Licensed under the Apache License, Version 2.0 (the "License");
11 * you may not use this file except in compliance with the License.
12 * You may obtain a copy of the License at
13 *
14 * http://www.apache.org/licenses/LICENSE-2.0
15 *
16 * Unless required by applicable law or agreed to in writing, software
17 * distributed under the License is distributed on an "AS IS" BASIS,
18 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
19 * See the License for the specific language governing permissions and
20 * limitations under the License.
21 */
22
23 #include "xfa/src/fxbarcode/barcode.h"
24 #include "BC_QRCoderECB.h"
25 #include "BC_QRCoderECBlocks.h"
CBC_QRCoderECBlocks(int32_t ecCodeWordsPerBlock,CBC_QRCoderECB * ecBlocks)26 CBC_QRCoderECBlocks::CBC_QRCoderECBlocks(int32_t ecCodeWordsPerBlock,
27 CBC_QRCoderECB* ecBlocks) {
28 m_ecCodeWordsPerBlock = ecCodeWordsPerBlock;
29 m_ecBlocks.Add(ecBlocks);
30 }
CBC_QRCoderECBlocks(int32_t ecCodeWordsPerBlock,CBC_QRCoderECB * ecBlocks1,CBC_QRCoderECB * ecBlocks2)31 CBC_QRCoderECBlocks::CBC_QRCoderECBlocks(int32_t ecCodeWordsPerBlock,
32 CBC_QRCoderECB* ecBlocks1,
33 CBC_QRCoderECB* ecBlocks2) {
34 m_ecCodeWordsPerBlock = ecCodeWordsPerBlock;
35 m_ecBlocks.Add(ecBlocks1);
36 m_ecBlocks.Add(ecBlocks2);
37 }
~CBC_QRCoderECBlocks()38 CBC_QRCoderECBlocks::~CBC_QRCoderECBlocks() {
39 for (int32_t i = 0; i < m_ecBlocks.GetSize(); i++) {
40 delete ((CBC_QRCoderECB*)(m_ecBlocks[i]));
41 }
42 m_ecBlocks.RemoveAll();
43 }
GetECCodeWordsPerBlock()44 int32_t CBC_QRCoderECBlocks::GetECCodeWordsPerBlock() {
45 return m_ecCodeWordsPerBlock;
46 }
GetNumBlocks()47 int32_t CBC_QRCoderECBlocks::GetNumBlocks() {
48 int32_t total = 0;
49 for (int32_t i = 0; i < m_ecBlocks.GetSize(); i++) {
50 total += ((CBC_QRCoderECB*)(m_ecBlocks[i]))->GetCount();
51 }
52 return total;
53 }
GetTotalECCodeWords()54 int32_t CBC_QRCoderECBlocks::GetTotalECCodeWords() {
55 return m_ecCodeWordsPerBlock * GetNumBlocks();
56 }
GetECBlocks()57 CFX_PtrArray* CBC_QRCoderECBlocks::GetECBlocks() {
58 return &m_ecBlocks;
59 }
60