|
|
@ -90,8 +90,7 @@ QrCode QrCode::encodeSegments(const vector<QrSegment> &segs, const Ecc &ecl,
|
|
|
|
// Create the data bit string by concatenating all segments
|
|
|
|
// Create the data bit string by concatenating all segments
|
|
|
|
int dataCapacityBits = getNumDataCodewords(version, *newEcl) * 8;
|
|
|
|
int dataCapacityBits = getNumDataCodewords(version, *newEcl) * 8;
|
|
|
|
BitBuffer bb;
|
|
|
|
BitBuffer bb;
|
|
|
|
for (size_t i = 0; i < segs.size(); i++) {
|
|
|
|
for (const QrSegment &seg : segs) {
|
|
|
|
const QrSegment &seg(segs.at(i));
|
|
|
|
|
|
|
|
bb.appendBits(seg.mode.modeBits, 4);
|
|
|
|
bb.appendBits(seg.mode.modeBits, 4);
|
|
|
|
bb.appendBits(seg.numChars, seg.mode.numCharCountBits(version));
|
|
|
|
bb.appendBits(seg.numChars, seg.mode.numCharCountBits(version));
|
|
|
|
bb.appendData(seg);
|
|
|
|
bb.appendData(seg);
|
|
|
@ -596,8 +595,8 @@ QrCode::ReedSolomonGenerator::ReedSolomonGenerator(int degree) :
|
|
|
|
vector<uint8_t> QrCode::ReedSolomonGenerator::getRemainder(const vector<uint8_t> &data) const {
|
|
|
|
vector<uint8_t> QrCode::ReedSolomonGenerator::getRemainder(const vector<uint8_t> &data) const {
|
|
|
|
// Compute the remainder by performing polynomial division
|
|
|
|
// Compute the remainder by performing polynomial division
|
|
|
|
vector<uint8_t> result(coefficients.size());
|
|
|
|
vector<uint8_t> result(coefficients.size());
|
|
|
|
for (size_t i = 0; i < data.size(); i++) {
|
|
|
|
for (uint8_t b : data) {
|
|
|
|
uint8_t factor = data.at(i) ^ result.at(0);
|
|
|
|
uint8_t factor = b ^ result.at(0);
|
|
|
|
result.erase(result.begin());
|
|
|
|
result.erase(result.begin());
|
|
|
|
result.push_back(0);
|
|
|
|
result.push_back(0);
|
|
|
|
for (size_t j = 0; j < result.size(); j++)
|
|
|
|
for (size_t j = 0; j < result.size(); j++)
|
|
|
|