#include "DMDataBlock.h"
#include "ByteArray.h"
#include "DMVersion.h"
#include "ZXAlgorithms.h"
#include <vector>
namespace ZXing::DataMatrix {
std::vector<DataBlock> GetDataBlocks(const ByteArray& rawCodewords, const Version& version, bool fix259)
{
auto& ecBlocks = version.ecBlocks;
const int numResultBlocks = ecBlocks.numBlocks();
std::vector<DataBlock> result;
result.reserve(numResultBlocks);
for (auto& ecBlock : ecBlocks.blocks)
for (int i = 0; i < ecBlock.count; i++)
result.push_back({ecBlock.dataCodewords, ByteArray(ecBlocks.codewordsPerBlock + ecBlock.dataCodewords)});
const int numCodewords = Size(result[0].codewords);
const int numDataCodewords = numCodewords - ecBlocks.codewordsPerBlock;
int rawCodewordsOffset = 0;
for (int i = 0; i < numDataCodewords - 1; i++)
for (int j = 0; j < numResultBlocks; j++)
result[j].codewords[i] = rawCodewords[rawCodewordsOffset++];
const bool size144x144 = version.symbolHeight == 144;
const int numLongerBlocks = size144x144 ? 8 : numResultBlocks;
for (int j = 0; j < numLongerBlocks; j++)
result[j].codewords[numDataCodewords - 1] = rawCodewords[rawCodewordsOffset++];
for (int i = numDataCodewords; i < numCodewords; i++) {
for (int j = 0; j < numResultBlocks; j++) {
int jOffset = size144x144 && fix259 ? (j + 8) % numResultBlocks : j;
int iOffset = size144x144 && jOffset > 7 ? i - 1 : i;
result[jOffset].codewords[iOffset] = rawCodewords[rawCodewordsOffset++];
}
}
if (rawCodewordsOffset != Size(rawCodewords))
return {};
return result;
}
}