2022-07-14 16:01:30 +01:00
|
|
|
|
/* gridmtx.c - Grid Matrix */
|
|
|
|
|
/*
|
2009-09-29 09:45:46 +00:00
|
|
|
|
libzint - the open source barcode library
|
2024-02-06 13:01:35 +00:00
|
|
|
|
Copyright (C) 2009-2024 Robin Stuart <rstuart114@gmail.com>
|
2009-09-29 09:45:46 +00:00
|
|
|
|
|
2013-05-16 19:26:38 +02:00
|
|
|
|
Redistribution and use in source and binary forms, with or without
|
|
|
|
|
modification, are permitted provided that the following conditions
|
|
|
|
|
are met:
|
2009-09-29 09:45:46 +00:00
|
|
|
|
|
2016-02-20 09:38:03 +00:00
|
|
|
|
1. Redistributions of source code must retain the above copyright
|
|
|
|
|
notice, this list of conditions and the following disclaimer.
|
2013-05-16 19:26:38 +02:00
|
|
|
|
2. Redistributions in binary form must reproduce the above copyright
|
|
|
|
|
notice, this list of conditions and the following disclaimer in the
|
2016-02-20 09:38:03 +00:00
|
|
|
|
documentation and/or other materials provided with the distribution.
|
2013-05-16 19:26:38 +02:00
|
|
|
|
3. Neither the name of the project nor the names of its contributors
|
|
|
|
|
may be used to endorse or promote products derived from this software
|
2016-02-20 09:38:03 +00:00
|
|
|
|
without specific prior written permission.
|
2009-09-29 09:45:46 +00:00
|
|
|
|
|
2013-05-16 19:26:38 +02:00
|
|
|
|
THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" AND
|
|
|
|
|
ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
|
|
|
|
|
IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
|
|
|
|
|
ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR CONTRIBUTORS BE LIABLE
|
|
|
|
|
FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
|
|
|
|
|
DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
|
|
|
|
|
OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
|
|
|
|
|
HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
|
|
|
|
|
LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
|
2016-02-20 09:38:03 +00:00
|
|
|
|
OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
|
2013-05-16 19:26:38 +02:00
|
|
|
|
SUCH DAMAGE.
|
2016-02-20 09:38:03 +00:00
|
|
|
|
*/
|
2022-06-24 14:38:48 +01:00
|
|
|
|
/* SPDX-License-Identifier: BSD-3-Clause */
|
2009-09-29 09:45:46 +00:00
|
|
|
|
|
2019-12-08 16:15:34 +00:00
|
|
|
|
/* This file implements Grid Matrix as specified in
|
2009-09-29 09:45:46 +00:00
|
|
|
|
AIM Global Document Number AIMD014 Rev. 1.63 Revised 9 Dec 2008 */
|
|
|
|
|
|
|
|
|
|
#include <stdio.h>
|
|
|
|
|
#include "common.h"
|
|
|
|
|
#include "reedsol.h"
|
|
|
|
|
#include "gridmtx.h"
|
2021-01-11 18:11:41 +00:00
|
|
|
|
#include "eci.h"
|
2009-10-21 09:08:44 +00:00
|
|
|
|
|
2021-10-20 23:05:30 +01:00
|
|
|
|
static const char EUROPIUM[] = "0123456789ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz ";
|
|
|
|
|
static const char EUROPIUM_UPR[] = "ABCDEFGHIJKLMNOPQRSTUVWXYZ ";
|
|
|
|
|
static const char EUROPIUM_LWR[] = "abcdefghijklmnopqrstuvwxyz ";
|
|
|
|
|
|
Add multiple segments support for AZTEC, CODEONE, DATAMATRIX, DOTCODE,
GRIDMATRIX, HANXIN, MAXICODE, MICROPDF417, PDF417, QRCODE, RMQR, ULTRA
RMQR: fix ECI encoding (wrong bit length for indicator)
MICROQR: check versions M1 and M2 for allowed characters so as to give
better error messages
DOTCODE: some small optimizations
common.c: add is_chr(), segs_length(), segs_cpy()
CODEONE/CODE128/DOTCODE/GRIDMATRIX/HANXIN/MAXICODE/QRCODE/ULTRA: add
namespace prefixes to static funcs/data
includes: use Z_ prefix, unuse double underscore prefixes (guard defines)
manual.txt: compress some tables using double/treble column sets
2022-05-09 19:50:50 +01:00
|
|
|
|
/* gm_define_mode() stuff */
|
2019-12-08 16:15:34 +00:00
|
|
|
|
|
2019-12-04 13:45:01 +00:00
|
|
|
|
/* Bits multiplied by this for costs, so as to be whole integer divisible by 2 and 3 */
|
|
|
|
|
#define GM_MULT 6
|
2016-02-20 09:38:03 +00:00
|
|
|
|
|
Add multiple segments support for AZTEC, CODEONE, DATAMATRIX, DOTCODE,
GRIDMATRIX, HANXIN, MAXICODE, MICROPDF417, PDF417, QRCODE, RMQR, ULTRA
RMQR: fix ECI encoding (wrong bit length for indicator)
MICROQR: check versions M1 and M2 for allowed characters so as to give
better error messages
DOTCODE: some small optimizations
common.c: add is_chr(), segs_length(), segs_cpy()
CODEONE/CODE128/DOTCODE/GRIDMATRIX/HANXIN/MAXICODE/QRCODE/ULTRA: add
namespace prefixes to static funcs/data
includes: use Z_ prefix, unuse double underscore prefixes (guard defines)
manual.txt: compress some tables using double/treble column sets
2022-05-09 19:50:50 +01:00
|
|
|
|
/* Non-digit numeral set, excluding EOL (carriage return/linefeed) */
|
|
|
|
|
static const char gm_numeral_nondigits[] = " +-.,";
|
2016-02-20 09:38:03 +00:00
|
|
|
|
|
2020-11-27 12:54:44 +00:00
|
|
|
|
/* Whether in numeral or not. If in numeral, *p_numeral_end is set to position after numeral,
|
|
|
|
|
* and *p_numeral_cost is set to per-numeral cost */
|
Add multiple segments support for AZTEC, CODEONE, DATAMATRIX, DOTCODE,
GRIDMATRIX, HANXIN, MAXICODE, MICROPDF417, PDF417, QRCODE, RMQR, ULTRA
RMQR: fix ECI encoding (wrong bit length for indicator)
MICROQR: check versions M1 and M2 for allowed characters so as to give
better error messages
DOTCODE: some small optimizations
common.c: add is_chr(), segs_length(), segs_cpy()
CODEONE/CODE128/DOTCODE/GRIDMATRIX/HANXIN/MAXICODE/QRCODE/ULTRA: add
namespace prefixes to static funcs/data
includes: use Z_ prefix, unuse double underscore prefixes (guard defines)
manual.txt: compress some tables using double/treble column sets
2022-05-09 19:50:50 +01:00
|
|
|
|
static int gm_in_numeral(const unsigned int ddata[], const int length, const int in_posn,
|
2020-11-27 12:54:44 +00:00
|
|
|
|
unsigned int *p_numeral_end, unsigned int *p_numeral_cost) {
|
|
|
|
|
int i, digit_cnt, nondigit, nondigit_posn;
|
2016-02-20 09:38:03 +00:00
|
|
|
|
|
2020-11-27 12:54:44 +00:00
|
|
|
|
if (in_posn < (int) *p_numeral_end) {
|
2019-12-04 13:45:01 +00:00
|
|
|
|
return 1;
|
|
|
|
|
}
|
2016-02-20 09:38:03 +00:00
|
|
|
|
|
2019-12-04 13:45:01 +00:00
|
|
|
|
/* Attempt to calculate the average 'cost' of using numeric mode in number of bits (times GM_MULT) */
|
|
|
|
|
/* Also ensures that numeric mode is not selected when it cannot be used: for example in
|
|
|
|
|
a string which has "2.2.0" (cannot have more than one non-numeric character for each
|
|
|
|
|
block of three numeric characters) */
|
2021-06-19 13:11:23 +01:00
|
|
|
|
for (i = in_posn, digit_cnt = 0, nondigit = 0, nondigit_posn = 0; i < length && i < in_posn + 4 && digit_cnt < 3;
|
|
|
|
|
i++) {
|
2022-06-24 14:38:48 +01:00
|
|
|
|
if (z_isdigit(ddata[i])) {
|
2019-12-04 13:45:01 +00:00
|
|
|
|
digit_cnt++;
|
Add multiple segments support for AZTEC, CODEONE, DATAMATRIX, DOTCODE,
GRIDMATRIX, HANXIN, MAXICODE, MICROPDF417, PDF417, QRCODE, RMQR, ULTRA
RMQR: fix ECI encoding (wrong bit length for indicator)
MICROQR: check versions M1 and M2 for allowed characters so as to give
better error messages
DOTCODE: some small optimizations
common.c: add is_chr(), segs_length(), segs_cpy()
CODEONE/CODE128/DOTCODE/GRIDMATRIX/HANXIN/MAXICODE/QRCODE/ULTRA: add
namespace prefixes to static funcs/data
includes: use Z_ prefix, unuse double underscore prefixes (guard defines)
manual.txt: compress some tables using double/treble column sets
2022-05-09 19:50:50 +01:00
|
|
|
|
} else if (posn(gm_numeral_nondigits, (const char) ddata[i]) != -1) {
|
2019-12-04 13:45:01 +00:00
|
|
|
|
if (nondigit) {
|
|
|
|
|
break;
|
2016-02-20 09:38:03 +00:00
|
|
|
|
}
|
2019-12-04 13:45:01 +00:00
|
|
|
|
nondigit = 1;
|
|
|
|
|
nondigit_posn = i;
|
Add multiple segments support for AZTEC, CODEONE, DATAMATRIX, DOTCODE,
GRIDMATRIX, HANXIN, MAXICODE, MICROPDF417, PDF417, QRCODE, RMQR, ULTRA
RMQR: fix ECI encoding (wrong bit length for indicator)
MICROQR: check versions M1 and M2 for allowed characters so as to give
better error messages
DOTCODE: some small optimizations
common.c: add is_chr(), segs_length(), segs_cpy()
CODEONE/CODE128/DOTCODE/GRIDMATRIX/HANXIN/MAXICODE/QRCODE/ULTRA: add
namespace prefixes to static funcs/data
includes: use Z_ prefix, unuse double underscore prefixes (guard defines)
manual.txt: compress some tables using double/treble column sets
2022-05-09 19:50:50 +01:00
|
|
|
|
} else if (i < length - 1 && ddata[i] == 13 && ddata[i + 1] == 10) {
|
2019-12-04 13:45:01 +00:00
|
|
|
|
if (nondigit) {
|
|
|
|
|
break;
|
|
|
|
|
}
|
|
|
|
|
i++;
|
|
|
|
|
nondigit = 2;
|
|
|
|
|
nondigit_posn = i;
|
|
|
|
|
} else {
|
|
|
|
|
break;
|
2016-02-20 09:38:03 +00:00
|
|
|
|
}
|
|
|
|
|
}
|
2019-12-04 13:45:01 +00:00
|
|
|
|
if (digit_cnt == 0) { /* Must have at least one digit */
|
2019-12-08 16:15:34 +00:00
|
|
|
|
*p_numeral_end = 0;
|
2019-12-04 13:45:01 +00:00
|
|
|
|
return 0;
|
2016-02-20 09:38:03 +00:00
|
|
|
|
}
|
2019-12-04 13:45:01 +00:00
|
|
|
|
if (nondigit && nondigit_posn == i - 1) { /* Non-digit can't be at end */
|
|
|
|
|
nondigit = 0;
|
2016-02-20 09:38:03 +00:00
|
|
|
|
}
|
2020-11-27 12:54:44 +00:00
|
|
|
|
*p_numeral_end = in_posn + digit_cnt + nondigit;
|
2019-12-04 13:45:01 +00:00
|
|
|
|
/* Calculate per-numeral cost where 120 == (10 + 10) * GM_MULT, 60 == 10 * GM_MULT */
|
|
|
|
|
if (digit_cnt == 3) {
|
|
|
|
|
*p_numeral_cost = nondigit == 2 ? 24 /* (120 / 5) */ : nondigit == 1 ? 30 /* (120 / 4) */ : 20 /* (60 / 3) */;
|
|
|
|
|
} else if (digit_cnt == 2) {
|
|
|
|
|
*p_numeral_cost = nondigit == 2 ? 30 /* (120 / 4) */ : nondigit == 1 ? 40 /* (120 / 3) */ : 30 /* (60 / 2) */;
|
|
|
|
|
} else {
|
|
|
|
|
*p_numeral_cost = nondigit == 2 ? 40 /* (120 / 3) */ : nondigit == 1 ? 60 /* (120 / 2) */ : 60 /* (60 / 1) */;
|
2016-02-20 09:38:03 +00:00
|
|
|
|
}
|
2019-12-04 13:45:01 +00:00
|
|
|
|
return 1;
|
|
|
|
|
}
|
2016-02-20 09:38:03 +00:00
|
|
|
|
|
2019-12-04 13:45:01 +00:00
|
|
|
|
/* Encoding modes */
|
|
|
|
|
#define GM_CHINESE 'H'
|
|
|
|
|
#define GM_NUMBER 'N'
|
|
|
|
|
#define GM_LOWER 'L'
|
|
|
|
|
#define GM_UPPER 'U'
|
|
|
|
|
#define GM_MIXED 'M'
|
|
|
|
|
#define GM_BYTE 'B'
|
|
|
|
|
/* Note Control is a submode of Lower, Upper and Mixed modes */
|
|
|
|
|
|
|
|
|
|
/* Indexes into mode_types array */
|
|
|
|
|
#define GM_H 0 /* Chinese (Hanzi) */
|
|
|
|
|
#define GM_N 1 /* Numeral */
|
|
|
|
|
#define GM_L 2 /* Lower case */
|
|
|
|
|
#define GM_U 3 /* Upper case */
|
|
|
|
|
#define GM_M 4 /* Mixed */
|
|
|
|
|
#define GM_B 5 /* Byte */
|
|
|
|
|
|
|
|
|
|
#define GM_NUM_MODES 6
|
|
|
|
|
|
2020-11-27 12:54:44 +00:00
|
|
|
|
/* Calculate optimized encoding modes. Adapted from Project Nayuki */
|
|
|
|
|
/* Copyright (c) Project Nayuki. (MIT License) See qr.c for detailed notice */
|
Add multiple segments support for AZTEC, CODEONE, DATAMATRIX, DOTCODE,
GRIDMATRIX, HANXIN, MAXICODE, MICROPDF417, PDF417, QRCODE, RMQR, ULTRA
RMQR: fix ECI encoding (wrong bit length for indicator)
MICROQR: check versions M1 and M2 for allowed characters so as to give
better error messages
DOTCODE: some small optimizations
common.c: add is_chr(), segs_length(), segs_cpy()
CODEONE/CODE128/DOTCODE/GRIDMATRIX/HANXIN/MAXICODE/QRCODE/ULTRA: add
namespace prefixes to static funcs/data
includes: use Z_ prefix, unuse double underscore prefixes (guard defines)
manual.txt: compress some tables using double/treble column sets
2022-05-09 19:50:50 +01:00
|
|
|
|
static void gm_define_mode(char *mode, const unsigned int ddata[], const int length, const int debug_print) {
|
2020-11-27 12:54:44 +00:00
|
|
|
|
/* Must be in same order as GM_H etc */
|
|
|
|
|
static const char mode_types[] = { GM_CHINESE, GM_NUMBER, GM_LOWER, GM_UPPER, GM_MIXED, GM_BYTE, '\0' };
|
2019-12-04 13:45:01 +00:00
|
|
|
|
|
2020-11-27 12:54:44 +00:00
|
|
|
|
/* Initial mode costs */
|
2021-10-30 22:00:31 +01:00
|
|
|
|
static const unsigned int head_costs[GM_NUM_MODES] = {
|
2020-11-27 12:54:44 +00:00
|
|
|
|
/* H N (+pad prefix) L U M B (+byte count) */
|
|
|
|
|
4 * GM_MULT, (4 + 2) * GM_MULT, 4 * GM_MULT, 4 * GM_MULT, 4 * GM_MULT, (4 + 9) * GM_MULT
|
|
|
|
|
};
|
2019-12-04 13:45:01 +00:00
|
|
|
|
|
2020-11-27 12:54:44 +00:00
|
|
|
|
/* Cost of switching modes from k to j - see AIMD014 Rev. 1.63 Table 9 – Type conversion codes */
|
2019-12-19 00:37:55 +00:00
|
|
|
|
static const unsigned int switch_costs[GM_NUM_MODES][GM_NUM_MODES] = {
|
2019-12-08 16:15:34 +00:00
|
|
|
|
/* H N L U M B */
|
|
|
|
|
/*H*/ { 0, (13 + 2) * GM_MULT, 13 * GM_MULT, 13 * GM_MULT, 13 * GM_MULT, (13 + 9) * GM_MULT },
|
|
|
|
|
/*N*/ { 10 * GM_MULT, 0, 10 * GM_MULT, 10 * GM_MULT, 10 * GM_MULT, (10 + 9) * GM_MULT },
|
|
|
|
|
/*L*/ { 5 * GM_MULT, (5 + 2) * GM_MULT, 0, 5 * GM_MULT, 7 * GM_MULT, (7 + 9) * GM_MULT },
|
|
|
|
|
/*U*/ { 5 * GM_MULT, (5 + 2) * GM_MULT, 5 * GM_MULT, 0, 7 * GM_MULT, (7 + 9) * GM_MULT },
|
|
|
|
|
/*M*/ { 10 * GM_MULT, (10 + 2) * GM_MULT, 10 * GM_MULT, 10 * GM_MULT, 0, (10 + 9) * GM_MULT },
|
|
|
|
|
/*B*/ { 4 * GM_MULT, (4 + 2) * GM_MULT, 4 * GM_MULT, 4 * GM_MULT, 4 * GM_MULT, 0 },
|
2019-12-04 13:45:01 +00:00
|
|
|
|
};
|
|
|
|
|
|
2020-11-27 12:54:44 +00:00
|
|
|
|
/* Final end-of-data cost - see AIMD014 Rev. 1.63 Table 9 – Type conversion codes */
|
2019-12-19 00:37:55 +00:00
|
|
|
|
static const unsigned int eod_costs[GM_NUM_MODES] = {
|
2019-12-04 13:45:01 +00:00
|
|
|
|
/* H N L U M B */
|
|
|
|
|
13 * GM_MULT, 10 * GM_MULT, 5 * GM_MULT, 5 * GM_MULT, 10 * GM_MULT, 4 * GM_MULT
|
|
|
|
|
};
|
|
|
|
|
|
2020-11-27 12:54:44 +00:00
|
|
|
|
unsigned int numeral_end = 0, numeral_cost = 0, byte_count = 0; /* State */
|
2019-12-08 16:15:34 +00:00
|
|
|
|
int double_byte, space, numeric, lower, upper, control, double_digit, eol;
|
2020-11-27 12:54:44 +00:00
|
|
|
|
|
2024-02-06 13:01:35 +00:00
|
|
|
|
int i, j, k;
|
2020-11-27 12:54:44 +00:00
|
|
|
|
unsigned int min_cost;
|
|
|
|
|
char cur_mode;
|
|
|
|
|
unsigned int prev_costs[GM_NUM_MODES];
|
|
|
|
|
unsigned int cur_costs[GM_NUM_MODES];
|
2024-02-06 13:01:35 +00:00
|
|
|
|
char (*char_modes)[GM_NUM_MODES] = (char (*)[GM_NUM_MODES]) z_alloca(GM_NUM_MODES * length);
|
2020-11-27 12:54:44 +00:00
|
|
|
|
|
2024-02-06 13:01:35 +00:00
|
|
|
|
/* char_modes[i][j] represents the mode to encode the code point at index i such that the final segment
|
|
|
|
|
ends in mode_types[j] and the total number of bits is minimized over all possible choices */
|
2020-11-27 12:54:44 +00:00
|
|
|
|
memset(char_modes, 0, length * GM_NUM_MODES);
|
|
|
|
|
|
|
|
|
|
/* At the beginning of each iteration of the loop below, prev_costs[j] is the minimum number of 1/6 (1/XX_MULT)
|
|
|
|
|
* bits needed to encode the entire string prefix of length i, and end in mode_types[j] */
|
|
|
|
|
memcpy(prev_costs, head_costs, GM_NUM_MODES * sizeof(unsigned int));
|
|
|
|
|
|
|
|
|
|
/* Calculate costs using dynamic programming */
|
2024-02-06 13:01:35 +00:00
|
|
|
|
for (i = 0; i < length; i++) {
|
2020-11-27 12:54:44 +00:00
|
|
|
|
memset(cur_costs, 0, GM_NUM_MODES * sizeof(unsigned int));
|
|
|
|
|
|
|
|
|
|
space = numeric = lower = upper = control = double_digit = eol = 0;
|
|
|
|
|
|
Add multiple segments support for AZTEC, CODEONE, DATAMATRIX, DOTCODE,
GRIDMATRIX, HANXIN, MAXICODE, MICROPDF417, PDF417, QRCODE, RMQR, ULTRA
RMQR: fix ECI encoding (wrong bit length for indicator)
MICROQR: check versions M1 and M2 for allowed characters so as to give
better error messages
DOTCODE: some small optimizations
common.c: add is_chr(), segs_length(), segs_cpy()
CODEONE/CODE128/DOTCODE/GRIDMATRIX/HANXIN/MAXICODE/QRCODE/ULTRA: add
namespace prefixes to static funcs/data
includes: use Z_ prefix, unuse double underscore prefixes (guard defines)
manual.txt: compress some tables using double/treble column sets
2022-05-09 19:50:50 +01:00
|
|
|
|
double_byte = ddata[i] > 0xFF;
|
2020-11-27 12:54:44 +00:00
|
|
|
|
if (!double_byte) {
|
Add multiple segments support for AZTEC, CODEONE, DATAMATRIX, DOTCODE,
GRIDMATRIX, HANXIN, MAXICODE, MICROPDF417, PDF417, QRCODE, RMQR, ULTRA
RMQR: fix ECI encoding (wrong bit length for indicator)
MICROQR: check versions M1 and M2 for allowed characters so as to give
better error messages
DOTCODE: some small optimizations
common.c: add is_chr(), segs_length(), segs_cpy()
CODEONE/CODE128/DOTCODE/GRIDMATRIX/HANXIN/MAXICODE/QRCODE/ULTRA: add
namespace prefixes to static funcs/data
includes: use Z_ prefix, unuse double underscore prefixes (guard defines)
manual.txt: compress some tables using double/treble column sets
2022-05-09 19:50:50 +01:00
|
|
|
|
space = ddata[i] == ' ';
|
2020-11-27 12:54:44 +00:00
|
|
|
|
if (!space) {
|
2022-06-24 14:38:48 +01:00
|
|
|
|
numeric = z_isdigit(ddata[i]);
|
2020-11-27 12:54:44 +00:00
|
|
|
|
if (!numeric) {
|
2022-06-24 14:38:48 +01:00
|
|
|
|
lower = z_islower(ddata[i]);
|
2020-11-27 12:54:44 +00:00
|
|
|
|
if (!lower) {
|
2022-06-24 14:38:48 +01:00
|
|
|
|
upper = z_isupper(ddata[i]);
|
2020-11-27 12:54:44 +00:00
|
|
|
|
if (!upper) {
|
Add multiple segments support for AZTEC, CODEONE, DATAMATRIX, DOTCODE,
GRIDMATRIX, HANXIN, MAXICODE, MICROPDF417, PDF417, QRCODE, RMQR, ULTRA
RMQR: fix ECI encoding (wrong bit length for indicator)
MICROQR: check versions M1 and M2 for allowed characters so as to give
better error messages
DOTCODE: some small optimizations
common.c: add is_chr(), segs_length(), segs_cpy()
CODEONE/CODE128/DOTCODE/GRIDMATRIX/HANXIN/MAXICODE/QRCODE/ULTRA: add
namespace prefixes to static funcs/data
includes: use Z_ prefix, unuse double underscore prefixes (guard defines)
manual.txt: compress some tables using double/treble column sets
2022-05-09 19:50:50 +01:00
|
|
|
|
control = ddata[i] < 0x7F; /* Exclude DEL */
|
2020-11-27 12:54:44 +00:00
|
|
|
|
if (control && i + 1 < length) {
|
Add multiple segments support for AZTEC, CODEONE, DATAMATRIX, DOTCODE,
GRIDMATRIX, HANXIN, MAXICODE, MICROPDF417, PDF417, QRCODE, RMQR, ULTRA
RMQR: fix ECI encoding (wrong bit length for indicator)
MICROQR: check versions M1 and M2 for allowed characters so as to give
better error messages
DOTCODE: some small optimizations
common.c: add is_chr(), segs_length(), segs_cpy()
CODEONE/CODE128/DOTCODE/GRIDMATRIX/HANXIN/MAXICODE/QRCODE/ULTRA: add
namespace prefixes to static funcs/data
includes: use Z_ prefix, unuse double underscore prefixes (guard defines)
manual.txt: compress some tables using double/treble column sets
2022-05-09 19:50:50 +01:00
|
|
|
|
eol = ddata[i] == 13 && ddata[i + 1] == 10;
|
2020-11-27 12:54:44 +00:00
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
} else if (i + 1 < length) {
|
2022-06-24 14:38:48 +01:00
|
|
|
|
double_digit = z_isdigit(ddata[i + 1]);
|
2020-11-27 12:54:44 +00:00
|
|
|
|
}
|
|
|
|
|
}
|
2016-02-20 09:38:03 +00:00
|
|
|
|
}
|
|
|
|
|
|
2020-11-27 12:54:44 +00:00
|
|
|
|
/* Hanzi mode can encode anything */
|
|
|
|
|
cur_costs[GM_H] = prev_costs[GM_H] + (double_digit || eol ? 39 : 78); /* (6.5 : 13) * GM_MULT */
|
2024-02-06 13:01:35 +00:00
|
|
|
|
char_modes[i][GM_H] = GM_CHINESE;
|
2016-02-20 09:38:03 +00:00
|
|
|
|
|
2020-11-27 12:54:44 +00:00
|
|
|
|
/* Byte mode can encode anything */
|
|
|
|
|
if (byte_count == 512 || (double_byte && byte_count == 511)) {
|
|
|
|
|
cur_costs[GM_B] = head_costs[GM_B];
|
|
|
|
|
if (double_byte && byte_count == 511) {
|
|
|
|
|
cur_costs[GM_B] += 48; /* 8 * GM_MULT */
|
|
|
|
|
double_byte = 0; /* Splitting double-byte so mark as single */
|
|
|
|
|
}
|
|
|
|
|
byte_count = 0;
|
2016-02-20 09:38:03 +00:00
|
|
|
|
}
|
2020-11-27 12:54:44 +00:00
|
|
|
|
cur_costs[GM_B] += prev_costs[GM_B] + (double_byte ? 96 : 48); /* (16 : 8) * GM_MULT */
|
2024-02-06 13:01:35 +00:00
|
|
|
|
char_modes[i][GM_B] = GM_BYTE;
|
2020-11-27 12:54:44 +00:00
|
|
|
|
byte_count += double_byte ? 2 : 1;
|
|
|
|
|
|
Add multiple segments support for AZTEC, CODEONE, DATAMATRIX, DOTCODE,
GRIDMATRIX, HANXIN, MAXICODE, MICROPDF417, PDF417, QRCODE, RMQR, ULTRA
RMQR: fix ECI encoding (wrong bit length for indicator)
MICROQR: check versions M1 and M2 for allowed characters so as to give
better error messages
DOTCODE: some small optimizations
common.c: add is_chr(), segs_length(), segs_cpy()
CODEONE/CODE128/DOTCODE/GRIDMATRIX/HANXIN/MAXICODE/QRCODE/ULTRA: add
namespace prefixes to static funcs/data
includes: use Z_ prefix, unuse double underscore prefixes (guard defines)
manual.txt: compress some tables using double/treble column sets
2022-05-09 19:50:50 +01:00
|
|
|
|
if (gm_in_numeral(ddata, length, i, &numeral_end, &numeral_cost)) {
|
2020-11-27 12:54:44 +00:00
|
|
|
|
cur_costs[GM_N] = prev_costs[GM_N] + numeral_cost;
|
2024-02-06 13:01:35 +00:00
|
|
|
|
char_modes[i][GM_N] = GM_NUMBER;
|
2016-02-20 09:38:03 +00:00
|
|
|
|
}
|
2020-11-27 12:54:44 +00:00
|
|
|
|
|
|
|
|
|
if (control) {
|
|
|
|
|
cur_costs[GM_L] = prev_costs[GM_L] + 78; /* (7 + 6) * GM_MULT */
|
2024-02-06 13:01:35 +00:00
|
|
|
|
char_modes[i][GM_L] = GM_LOWER;
|
2020-11-27 12:54:44 +00:00
|
|
|
|
cur_costs[GM_U] = prev_costs[GM_U] + 78; /* (7 + 6) * GM_MULT */
|
2024-02-06 13:01:35 +00:00
|
|
|
|
char_modes[i][GM_U] = GM_UPPER;
|
2020-11-27 12:54:44 +00:00
|
|
|
|
cur_costs[GM_M] = prev_costs[GM_M] + 96; /* (10 + 6) * GM_MULT */
|
2024-02-06 13:01:35 +00:00
|
|
|
|
char_modes[i][GM_M] = GM_MIXED;
|
2020-11-27 12:54:44 +00:00
|
|
|
|
} else {
|
|
|
|
|
if (lower || space) {
|
|
|
|
|
cur_costs[GM_L] = prev_costs[GM_L] + 30; /* 5 * GM_MULT */
|
2024-02-06 13:01:35 +00:00
|
|
|
|
char_modes[i][GM_L] = GM_LOWER;
|
2020-11-27 12:54:44 +00:00
|
|
|
|
}
|
|
|
|
|
if (upper || space) {
|
|
|
|
|
cur_costs[GM_U] = prev_costs[GM_U] + 30; /* 5 * GM_MULT */
|
2024-02-06 13:01:35 +00:00
|
|
|
|
char_modes[i][GM_U] = GM_UPPER;
|
2020-11-27 12:54:44 +00:00
|
|
|
|
}
|
|
|
|
|
if (numeric || lower || upper || space) {
|
|
|
|
|
cur_costs[GM_M] = prev_costs[GM_M] + 36; /* 6 * GM_MULT */
|
2024-02-06 13:01:35 +00:00
|
|
|
|
char_modes[i][GM_M] = GM_MIXED;
|
2020-11-27 12:54:44 +00:00
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
if (i == length - 1) { /* Add end of data costs if last character */
|
|
|
|
|
for (j = 0; j < GM_NUM_MODES; j++) {
|
2024-02-06 13:01:35 +00:00
|
|
|
|
if (char_modes[i][j]) {
|
2020-11-27 12:54:44 +00:00
|
|
|
|
cur_costs[j] += eod_costs[j];
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/* Start new segment at the end to switch modes */
|
|
|
|
|
for (j = 0; j < GM_NUM_MODES; j++) { /* To mode */
|
|
|
|
|
for (k = 0; k < GM_NUM_MODES; k++) { /* From mode */
|
2024-02-06 13:01:35 +00:00
|
|
|
|
if (j != k && char_modes[i][k]) {
|
2021-10-30 22:00:31 +01:00
|
|
|
|
const unsigned int new_cost = cur_costs[k] + switch_costs[k][j];
|
2024-02-06 13:01:35 +00:00
|
|
|
|
if (!char_modes[i][j] || new_cost < cur_costs[j]) {
|
2020-11-27 12:54:44 +00:00
|
|
|
|
cur_costs[j] = new_cost;
|
2024-02-06 13:01:35 +00:00
|
|
|
|
char_modes[i][j] = mode_types[k];
|
2020-11-27 12:54:44 +00:00
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|
2016-02-20 09:38:03 +00:00
|
|
|
|
}
|
2020-11-27 12:54:44 +00:00
|
|
|
|
|
|
|
|
|
memcpy(prev_costs, cur_costs, GM_NUM_MODES * sizeof(unsigned int));
|
2016-02-20 09:38:03 +00:00
|
|
|
|
}
|
|
|
|
|
|
2020-11-27 12:54:44 +00:00
|
|
|
|
/* Find optimal ending mode */
|
|
|
|
|
min_cost = prev_costs[0];
|
|
|
|
|
cur_mode = mode_types[0];
|
|
|
|
|
for (i = 1; i < GM_NUM_MODES; i++) {
|
|
|
|
|
if (prev_costs[i] < min_cost) {
|
|
|
|
|
min_cost = prev_costs[i];
|
|
|
|
|
cur_mode = mode_types[i];
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/* Get optimal mode for each code point by tracing backwards */
|
2024-02-06 13:01:35 +00:00
|
|
|
|
for (i = length - 1; i >= 0; i--) {
|
2021-10-20 23:05:30 +01:00
|
|
|
|
j = posn(mode_types, cur_mode);
|
2024-02-06 13:01:35 +00:00
|
|
|
|
cur_mode = char_modes[i][j];
|
2020-11-27 12:54:44 +00:00
|
|
|
|
mode[i] = cur_mode;
|
|
|
|
|
}
|
2016-02-20 09:38:03 +00:00
|
|
|
|
|
Add multiple segments support for AZTEC, CODEONE, DATAMATRIX, DOTCODE,
GRIDMATRIX, HANXIN, MAXICODE, MICROPDF417, PDF417, QRCODE, RMQR, ULTRA
RMQR: fix ECI encoding (wrong bit length for indicator)
MICROQR: check versions M1 and M2 for allowed characters so as to give
better error messages
DOTCODE: some small optimizations
common.c: add is_chr(), segs_length(), segs_cpy()
CODEONE/CODE128/DOTCODE/GRIDMATRIX/HANXIN/MAXICODE/QRCODE/ULTRA: add
namespace prefixes to static funcs/data
includes: use Z_ prefix, unuse double underscore prefixes (guard defines)
manual.txt: compress some tables using double/treble column sets
2022-05-09 19:50:50 +01:00
|
|
|
|
if (debug_print) {
|
2020-11-27 12:54:44 +00:00
|
|
|
|
printf(" Mode: %.*s\n", length, mode);
|
|
|
|
|
}
|
2009-10-21 09:08:44 +00:00
|
|
|
|
}
|
|
|
|
|
|
2016-02-20 09:38:03 +00:00
|
|
|
|
/* Add the length indicator for byte encoded blocks */
|
Add multiple segments support for AZTEC, CODEONE, DATAMATRIX, DOTCODE,
GRIDMATRIX, HANXIN, MAXICODE, MICROPDF417, PDF417, QRCODE, RMQR, ULTRA
RMQR: fix ECI encoding (wrong bit length for indicator)
MICROQR: check versions M1 and M2 for allowed characters so as to give
better error messages
DOTCODE: some small optimizations
common.c: add is_chr(), segs_length(), segs_cpy()
CODEONE/CODE128/DOTCODE/GRIDMATRIX/HANXIN/MAXICODE/QRCODE/ULTRA: add
namespace prefixes to static funcs/data
includes: use Z_ prefix, unuse double underscore prefixes (guard defines)
manual.txt: compress some tables using double/treble column sets
2022-05-09 19:50:50 +01:00
|
|
|
|
static void gm_add_byte_count(char binary[], const int byte_count_posn, const int byte_count) {
|
2020-04-06 21:26:13 +01:00
|
|
|
|
/* AIMD014 6.3.7: "Let L be the number of bytes of input data to be encoded in the 8-bit binary data set.
|
|
|
|
|
* First output (L-1) as a 9-bit binary prefix to record the number of bytes..." */
|
2019-12-04 13:45:01 +00:00
|
|
|
|
bin_append_posn(byte_count - 1, 9, binary, byte_count_posn);
|
2009-10-21 09:08:44 +00:00
|
|
|
|
}
|
|
|
|
|
|
2016-02-20 09:38:03 +00:00
|
|
|
|
/* Add a control character to the data stream */
|
Add multiple segments support for AZTEC, CODEONE, DATAMATRIX, DOTCODE,
GRIDMATRIX, HANXIN, MAXICODE, MICROPDF417, PDF417, QRCODE, RMQR, ULTRA
RMQR: fix ECI encoding (wrong bit length for indicator)
MICROQR: check versions M1 and M2 for allowed characters so as to give
better error messages
DOTCODE: some small optimizations
common.c: add is_chr(), segs_length(), segs_cpy()
CODEONE/CODE128/DOTCODE/GRIDMATRIX/HANXIN/MAXICODE/QRCODE/ULTRA: add
namespace prefixes to static funcs/data
includes: use Z_ prefix, unuse double underscore prefixes (guard defines)
manual.txt: compress some tables using double/treble column sets
2022-05-09 19:50:50 +01:00
|
|
|
|
static int gm_add_shift_char(char binary[], int bp, int shifty, const int debug_print) {
|
2019-11-28 19:15:29 +00:00
|
|
|
|
int i;
|
2016-02-20 09:38:03 +00:00
|
|
|
|
int glyph = 0;
|
|
|
|
|
|
2020-11-27 12:54:44 +00:00
|
|
|
|
if (shifty < 32) {
|
|
|
|
|
glyph = shifty;
|
|
|
|
|
} else {
|
|
|
|
|
for (i = 32; i < 64; i++) {
|
2021-10-20 23:05:30 +01:00
|
|
|
|
if (gm_shift_set[i] == shifty) {
|
2020-11-27 12:54:44 +00:00
|
|
|
|
glyph = i;
|
|
|
|
|
break;
|
|
|
|
|
}
|
2016-02-20 09:38:03 +00:00
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
Add multiple segments support for AZTEC, CODEONE, DATAMATRIX, DOTCODE,
GRIDMATRIX, HANXIN, MAXICODE, MICROPDF417, PDF417, QRCODE, RMQR, ULTRA
RMQR: fix ECI encoding (wrong bit length for indicator)
MICROQR: check versions M1 and M2 for allowed characters so as to give
better error messages
DOTCODE: some small optimizations
common.c: add is_chr(), segs_length(), segs_cpy()
CODEONE/CODE128/DOTCODE/GRIDMATRIX/HANXIN/MAXICODE/QRCODE/ULTRA: add
namespace prefixes to static funcs/data
includes: use Z_ prefix, unuse double underscore prefixes (guard defines)
manual.txt: compress some tables using double/treble column sets
2022-05-09 19:50:50 +01:00
|
|
|
|
if (debug_print) {
|
2016-02-20 09:38:03 +00:00
|
|
|
|
printf("SHIFT [%d] ", glyph);
|
|
|
|
|
}
|
|
|
|
|
|
2020-11-27 12:54:44 +00:00
|
|
|
|
bp = bin_append_posn(glyph, 6, binary, bp);
|
|
|
|
|
|
|
|
|
|
return bp;
|
2009-10-21 09:08:44 +00:00
|
|
|
|
}
|
|
|
|
|
|
Add multiple segments support for AZTEC, CODEONE, DATAMATRIX, DOTCODE,
GRIDMATRIX, HANXIN, MAXICODE, MICROPDF417, PDF417, QRCODE, RMQR, ULTRA
RMQR: fix ECI encoding (wrong bit length for indicator)
MICROQR: check versions M1 and M2 for allowed characters so as to give
better error messages
DOTCODE: some small optimizations
common.c: add is_chr(), segs_length(), segs_cpy()
CODEONE/CODE128/DOTCODE/GRIDMATRIX/HANXIN/MAXICODE/QRCODE/ULTRA: add
namespace prefixes to static funcs/data
includes: use Z_ prefix, unuse double underscore prefixes (guard defines)
manual.txt: compress some tables using double/treble column sets
2022-05-09 19:50:50 +01:00
|
|
|
|
static int gm_encode(unsigned int ddata[], const int length, char binary[], const int eci, int *p_bp,
|
|
|
|
|
const int debug_print) {
|
2016-02-20 09:38:03 +00:00
|
|
|
|
/* Create a binary stream representation of the input data.
|
|
|
|
|
7 sets are defined - Chinese characters, Numerals, Lower case letters, Upper case letters,
|
|
|
|
|
Mixed numerals and latters, Control characters and 8-bit binary data */
|
Add multiple segments support for AZTEC, CODEONE, DATAMATRIX, DOTCODE,
GRIDMATRIX, HANXIN, MAXICODE, MICROPDF417, PDF417, QRCODE, RMQR, ULTRA
RMQR: fix ECI encoding (wrong bit length for indicator)
MICROQR: check versions M1 and M2 for allowed characters so as to give
better error messages
DOTCODE: some small optimizations
common.c: add is_chr(), segs_length(), segs_cpy()
CODEONE/CODE128/DOTCODE/GRIDMATRIX/HANXIN/MAXICODE/QRCODE/ULTRA: add
namespace prefixes to static funcs/data
includes: use Z_ prefix, unuse double underscore prefixes (guard defines)
manual.txt: compress some tables using double/treble column sets
2022-05-09 19:50:50 +01:00
|
|
|
|
int sp = 0;
|
|
|
|
|
int current_mode = 0;
|
|
|
|
|
int last_mode;
|
2019-12-04 13:45:01 +00:00
|
|
|
|
unsigned int glyph = 0;
|
2016-02-20 09:38:03 +00:00
|
|
|
|
int c1, c2, done;
|
|
|
|
|
int p = 0, ppos;
|
|
|
|
|
int numbuf[3], punt = 0;
|
Add multiple segments support for AZTEC, CODEONE, DATAMATRIX, DOTCODE,
GRIDMATRIX, HANXIN, MAXICODE, MICROPDF417, PDF417, QRCODE, RMQR, ULTRA
RMQR: fix ECI encoding (wrong bit length for indicator)
MICROQR: check versions M1 and M2 for allowed characters so as to give
better error messages
DOTCODE: some small optimizations
common.c: add is_chr(), segs_length(), segs_cpy()
CODEONE/CODE128/DOTCODE/GRIDMATRIX/HANXIN/MAXICODE/QRCODE/ULTRA: add
namespace prefixes to static funcs/data
includes: use Z_ prefix, unuse double underscore prefixes (guard defines)
manual.txt: compress some tables using double/treble column sets
2022-05-09 19:50:50 +01:00
|
|
|
|
int number_pad_posn = 0;
|
|
|
|
|
int byte_count_posn = 0;
|
2017-04-11 10:05:38 +01:00
|
|
|
|
int byte_count = 0;
|
2017-05-14 08:15:08 +01:00
|
|
|
|
int shift;
|
Add multiple segments support for AZTEC, CODEONE, DATAMATRIX, DOTCODE,
GRIDMATRIX, HANXIN, MAXICODE, MICROPDF417, PDF417, QRCODE, RMQR, ULTRA
RMQR: fix ECI encoding (wrong bit length for indicator)
MICROQR: check versions M1 and M2 for allowed characters so as to give
better error messages
DOTCODE: some small optimizations
common.c: add is_chr(), segs_length(), segs_cpy()
CODEONE/CODE128/DOTCODE/GRIDMATRIX/HANXIN/MAXICODE/QRCODE/ULTRA: add
namespace prefixes to static funcs/data
includes: use Z_ prefix, unuse double underscore prefixes (guard defines)
manual.txt: compress some tables using double/treble column sets
2022-05-09 19:50:50 +01:00
|
|
|
|
int bp = *p_bp;
|
2022-07-14 16:01:30 +01:00
|
|
|
|
char *mode = (char *) z_alloca(length);
|
2016-02-20 09:38:03 +00:00
|
|
|
|
|
2019-10-06 17:39:54 +01:00
|
|
|
|
if (eci != 0) {
|
2017-06-18 13:00:22 +01:00
|
|
|
|
/* ECI assignment according to Table 8 */
|
2020-11-27 12:54:44 +00:00
|
|
|
|
bp = bin_append_posn(12, 4, binary, bp); /* ECI */
|
2017-06-18 13:00:22 +01:00
|
|
|
|
if (eci <= 1023) {
|
2020-11-27 12:54:44 +00:00
|
|
|
|
bp = bin_append_posn(eci, 11, binary, bp);
|
|
|
|
|
} else if (eci <= 32767) {
|
|
|
|
|
bp = bin_append_posn(2, 2, binary, bp);
|
|
|
|
|
bp = bin_append_posn(eci, 15, binary, bp);
|
|
|
|
|
} else {
|
|
|
|
|
bp = bin_append_posn(3, 2, binary, bp);
|
|
|
|
|
bp = bin_append_posn(eci, 20, binary, bp);
|
2017-06-18 13:00:22 +01:00
|
|
|
|
}
|
2016-08-16 12:43:41 +01:00
|
|
|
|
}
|
2016-02-20 09:38:03 +00:00
|
|
|
|
|
Add multiple segments support for AZTEC, CODEONE, DATAMATRIX, DOTCODE,
GRIDMATRIX, HANXIN, MAXICODE, MICROPDF417, PDF417, QRCODE, RMQR, ULTRA
RMQR: fix ECI encoding (wrong bit length for indicator)
MICROQR: check versions M1 and M2 for allowed characters so as to give
better error messages
DOTCODE: some small optimizations
common.c: add is_chr(), segs_length(), segs_cpy()
CODEONE/CODE128/DOTCODE/GRIDMATRIX/HANXIN/MAXICODE/QRCODE/ULTRA: add
namespace prefixes to static funcs/data
includes: use Z_ prefix, unuse double underscore prefixes (guard defines)
manual.txt: compress some tables using double/treble column sets
2022-05-09 19:50:50 +01:00
|
|
|
|
gm_define_mode(mode, ddata, length, debug_print);
|
2019-12-04 13:45:01 +00:00
|
|
|
|
|
2016-02-20 09:38:03 +00:00
|
|
|
|
do {
|
2021-10-30 22:00:31 +01:00
|
|
|
|
const int next_mode = mode[sp];
|
2016-02-20 09:38:03 +00:00
|
|
|
|
|
|
|
|
|
if (next_mode != current_mode) {
|
|
|
|
|
switch (current_mode) {
|
|
|
|
|
case 0:
|
|
|
|
|
switch (next_mode) {
|
2020-11-27 12:54:44 +00:00
|
|
|
|
case GM_CHINESE: bp = bin_append_posn(1, 4, binary, bp);
|
2016-02-20 09:38:03 +00:00
|
|
|
|
break;
|
2020-11-27 12:54:44 +00:00
|
|
|
|
case GM_NUMBER: bp = bin_append_posn(2, 4, binary, bp);
|
2016-02-20 09:38:03 +00:00
|
|
|
|
break;
|
2020-11-27 12:54:44 +00:00
|
|
|
|
case GM_LOWER: bp = bin_append_posn(3, 4, binary, bp);
|
2016-02-20 09:38:03 +00:00
|
|
|
|
break;
|
2020-11-27 12:54:44 +00:00
|
|
|
|
case GM_UPPER: bp = bin_append_posn(4, 4, binary, bp);
|
2016-02-20 09:38:03 +00:00
|
|
|
|
break;
|
2020-11-27 12:54:44 +00:00
|
|
|
|
case GM_MIXED: bp = bin_append_posn(5, 4, binary, bp);
|
2016-02-20 09:38:03 +00:00
|
|
|
|
break;
|
2020-11-27 12:54:44 +00:00
|
|
|
|
case GM_BYTE: bp = bin_append_posn(6, 4, binary, bp);
|
2016-02-20 09:38:03 +00:00
|
|
|
|
break;
|
|
|
|
|
}
|
|
|
|
|
break;
|
|
|
|
|
case GM_CHINESE:
|
|
|
|
|
switch (next_mode) {
|
2020-11-27 12:54:44 +00:00
|
|
|
|
case GM_NUMBER: bp = bin_append_posn(8161, 13, binary, bp);
|
2017-05-14 08:15:08 +01:00
|
|
|
|
break;
|
2020-11-27 12:54:44 +00:00
|
|
|
|
case GM_LOWER: bp = bin_append_posn(8162, 13, binary, bp);
|
2017-05-14 08:15:08 +01:00
|
|
|
|
break;
|
2020-11-27 12:54:44 +00:00
|
|
|
|
case GM_UPPER: bp = bin_append_posn(8163, 13, binary, bp);
|
2017-05-14 08:15:08 +01:00
|
|
|
|
break;
|
2020-11-27 12:54:44 +00:00
|
|
|
|
case GM_MIXED: bp = bin_append_posn(8164, 13, binary, bp);
|
2017-05-14 08:15:08 +01:00
|
|
|
|
break;
|
2020-11-27 12:54:44 +00:00
|
|
|
|
case GM_BYTE: bp = bin_append_posn(8165, 13, binary, bp);
|
2017-05-14 08:15:08 +01:00
|
|
|
|
break;
|
2016-02-20 09:38:03 +00:00
|
|
|
|
}
|
|
|
|
|
break;
|
|
|
|
|
case GM_NUMBER:
|
|
|
|
|
/* add numeric block padding value */
|
|
|
|
|
switch (p) {
|
|
|
|
|
case 1: binary[number_pad_posn] = '1';
|
|
|
|
|
binary[number_pad_posn + 1] = '0';
|
2022-07-14 16:01:30 +01:00
|
|
|
|
break; /* 2 pad digits */
|
2016-02-20 09:38:03 +00:00
|
|
|
|
case 2: binary[number_pad_posn] = '0';
|
|
|
|
|
binary[number_pad_posn + 1] = '1';
|
2022-07-14 16:01:30 +01:00
|
|
|
|
break; /* 1 pad digits */
|
2016-02-20 09:38:03 +00:00
|
|
|
|
case 3: binary[number_pad_posn] = '0';
|
|
|
|
|
binary[number_pad_posn + 1] = '0';
|
2022-07-14 16:01:30 +01:00
|
|
|
|
break; /* 0 pad digits */
|
2016-02-20 09:38:03 +00:00
|
|
|
|
}
|
|
|
|
|
switch (next_mode) {
|
2020-11-27 12:54:44 +00:00
|
|
|
|
case GM_CHINESE: bp = bin_append_posn(1019, 10, binary, bp);
|
2017-05-14 08:15:08 +01:00
|
|
|
|
break;
|
2020-11-27 12:54:44 +00:00
|
|
|
|
case GM_LOWER: bp = bin_append_posn(1020, 10, binary, bp);
|
2017-05-14 08:15:08 +01:00
|
|
|
|
break;
|
2020-11-27 12:54:44 +00:00
|
|
|
|
case GM_UPPER: bp = bin_append_posn(1021, 10, binary, bp);
|
2017-05-14 08:15:08 +01:00
|
|
|
|
break;
|
2020-11-27 12:54:44 +00:00
|
|
|
|
case GM_MIXED: bp = bin_append_posn(1022, 10, binary, bp);
|
2017-05-14 08:15:08 +01:00
|
|
|
|
break;
|
2020-11-27 12:54:44 +00:00
|
|
|
|
case GM_BYTE: bp = bin_append_posn(1023, 10, binary, bp);
|
2017-05-14 08:15:08 +01:00
|
|
|
|
break;
|
2016-02-20 09:38:03 +00:00
|
|
|
|
}
|
|
|
|
|
break;
|
|
|
|
|
case GM_LOWER:
|
|
|
|
|
case GM_UPPER:
|
|
|
|
|
switch (next_mode) {
|
2020-11-27 12:54:44 +00:00
|
|
|
|
case GM_CHINESE: bp = bin_append_posn(28, 5, binary, bp);
|
2017-05-14 08:15:08 +01:00
|
|
|
|
break;
|
2020-11-27 12:54:44 +00:00
|
|
|
|
case GM_NUMBER: bp = bin_append_posn(29, 5, binary, bp);
|
2017-05-14 08:15:08 +01:00
|
|
|
|
break;
|
2016-02-20 09:38:03 +00:00
|
|
|
|
case GM_LOWER:
|
2020-11-27 12:54:44 +00:00
|
|
|
|
case GM_UPPER: bp = bin_append_posn(30, 5, binary, bp);
|
2017-05-14 08:15:08 +01:00
|
|
|
|
break;
|
2020-11-27 12:54:44 +00:00
|
|
|
|
case GM_MIXED: bp = bin_append_posn(124, 7, binary, bp);
|
2017-05-14 08:15:08 +01:00
|
|
|
|
break;
|
2020-11-27 12:54:44 +00:00
|
|
|
|
case GM_BYTE: bp = bin_append_posn(126, 7, binary, bp);
|
2017-05-14 08:15:08 +01:00
|
|
|
|
break;
|
2016-02-20 09:38:03 +00:00
|
|
|
|
}
|
|
|
|
|
break;
|
|
|
|
|
case GM_MIXED:
|
|
|
|
|
switch (next_mode) {
|
2020-11-27 12:54:44 +00:00
|
|
|
|
case GM_CHINESE: bp = bin_append_posn(1009, 10, binary, bp);
|
2017-05-14 08:15:08 +01:00
|
|
|
|
break;
|
2020-11-27 12:54:44 +00:00
|
|
|
|
case GM_NUMBER: bp = bin_append_posn(1010, 10, binary, bp);
|
2017-05-14 08:15:08 +01:00
|
|
|
|
break;
|
2020-11-27 12:54:44 +00:00
|
|
|
|
case GM_LOWER: bp = bin_append_posn(1011, 10, binary, bp);
|
2017-05-14 08:15:08 +01:00
|
|
|
|
break;
|
2020-11-27 12:54:44 +00:00
|
|
|
|
case GM_UPPER: bp = bin_append_posn(1012, 10, binary, bp);
|
2017-05-14 08:15:08 +01:00
|
|
|
|
break;
|
2020-11-27 12:54:44 +00:00
|
|
|
|
case GM_BYTE: bp = bin_append_posn(1015, 10, binary, bp);
|
2017-05-14 08:15:08 +01:00
|
|
|
|
break;
|
2016-02-20 09:38:03 +00:00
|
|
|
|
}
|
|
|
|
|
break;
|
|
|
|
|
case GM_BYTE:
|
|
|
|
|
/* add byte block length indicator */
|
Add multiple segments support for AZTEC, CODEONE, DATAMATRIX, DOTCODE,
GRIDMATRIX, HANXIN, MAXICODE, MICROPDF417, PDF417, QRCODE, RMQR, ULTRA
RMQR: fix ECI encoding (wrong bit length for indicator)
MICROQR: check versions M1 and M2 for allowed characters so as to give
better error messages
DOTCODE: some small optimizations
common.c: add is_chr(), segs_length(), segs_cpy()
CODEONE/CODE128/DOTCODE/GRIDMATRIX/HANXIN/MAXICODE/QRCODE/ULTRA: add
namespace prefixes to static funcs/data
includes: use Z_ prefix, unuse double underscore prefixes (guard defines)
manual.txt: compress some tables using double/treble column sets
2022-05-09 19:50:50 +01:00
|
|
|
|
gm_add_byte_count(binary, byte_count_posn, byte_count);
|
2016-02-20 09:38:03 +00:00
|
|
|
|
byte_count = 0;
|
|
|
|
|
switch (next_mode) {
|
2020-11-27 12:54:44 +00:00
|
|
|
|
case GM_CHINESE: bp = bin_append_posn(1, 4, binary, bp);
|
2017-05-14 08:15:08 +01:00
|
|
|
|
break;
|
2020-11-27 12:54:44 +00:00
|
|
|
|
case GM_NUMBER: bp = bin_append_posn(2, 4, binary, bp);
|
2017-05-14 08:15:08 +01:00
|
|
|
|
break;
|
2020-11-27 12:54:44 +00:00
|
|
|
|
case GM_LOWER: bp = bin_append_posn(3, 4, binary, bp);
|
2017-05-14 08:15:08 +01:00
|
|
|
|
break;
|
2020-11-27 12:54:44 +00:00
|
|
|
|
case GM_UPPER: bp = bin_append_posn(4, 4, binary, bp);
|
2017-05-14 08:15:08 +01:00
|
|
|
|
break;
|
2020-11-27 12:54:44 +00:00
|
|
|
|
case GM_MIXED: bp = bin_append_posn(5, 4, binary, bp);
|
2017-05-14 08:15:08 +01:00
|
|
|
|
break;
|
2016-02-20 09:38:03 +00:00
|
|
|
|
}
|
|
|
|
|
break;
|
|
|
|
|
}
|
Add multiple segments support for AZTEC, CODEONE, DATAMATRIX, DOTCODE,
GRIDMATRIX, HANXIN, MAXICODE, MICROPDF417, PDF417, QRCODE, RMQR, ULTRA
RMQR: fix ECI encoding (wrong bit length for indicator)
MICROQR: check versions M1 and M2 for allowed characters so as to give
better error messages
DOTCODE: some small optimizations
common.c: add is_chr(), segs_length(), segs_cpy()
CODEONE/CODE128/DOTCODE/GRIDMATRIX/HANXIN/MAXICODE/QRCODE/ULTRA: add
namespace prefixes to static funcs/data
includes: use Z_ prefix, unuse double underscore prefixes (guard defines)
manual.txt: compress some tables using double/treble column sets
2022-05-09 19:50:50 +01:00
|
|
|
|
if (debug_print) {
|
2016-02-20 09:38:03 +00:00
|
|
|
|
switch (next_mode) {
|
2023-06-12 01:25:55 +01:00
|
|
|
|
case GM_CHINESE: fputs("CHIN ", stdout);
|
2016-02-20 09:38:03 +00:00
|
|
|
|
break;
|
2023-06-12 01:25:55 +01:00
|
|
|
|
case GM_NUMBER: fputs("NUMB ", stdout);
|
2016-02-20 09:38:03 +00:00
|
|
|
|
break;
|
2023-06-12 01:25:55 +01:00
|
|
|
|
case GM_LOWER: fputs("LOWR ", stdout);
|
2016-02-20 09:38:03 +00:00
|
|
|
|
break;
|
2023-06-12 01:25:55 +01:00
|
|
|
|
case GM_UPPER: fputs("UPPR ", stdout);
|
2016-02-20 09:38:03 +00:00
|
|
|
|
break;
|
2023-06-12 01:25:55 +01:00
|
|
|
|
case GM_MIXED: fputs("MIXD ", stdout);
|
2016-02-20 09:38:03 +00:00
|
|
|
|
break;
|
2023-06-12 01:25:55 +01:00
|
|
|
|
case GM_BYTE: fputs("BYTE ", stdout);
|
2016-02-20 09:38:03 +00:00
|
|
|
|
break;
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
last_mode = current_mode;
|
|
|
|
|
current_mode = next_mode;
|
|
|
|
|
|
|
|
|
|
switch (current_mode) {
|
|
|
|
|
case GM_CHINESE:
|
|
|
|
|
done = 0;
|
Add multiple segments support for AZTEC, CODEONE, DATAMATRIX, DOTCODE,
GRIDMATRIX, HANXIN, MAXICODE, MICROPDF417, PDF417, QRCODE, RMQR, ULTRA
RMQR: fix ECI encoding (wrong bit length for indicator)
MICROQR: check versions M1 and M2 for allowed characters so as to give
better error messages
DOTCODE: some small optimizations
common.c: add is_chr(), segs_length(), segs_cpy()
CODEONE/CODE128/DOTCODE/GRIDMATRIX/HANXIN/MAXICODE/QRCODE/ULTRA: add
namespace prefixes to static funcs/data
includes: use Z_ prefix, unuse double underscore prefixes (guard defines)
manual.txt: compress some tables using double/treble column sets
2022-05-09 19:50:50 +01:00
|
|
|
|
if (ddata[sp] > 0xff) {
|
2016-02-20 09:38:03 +00:00
|
|
|
|
/* GB2312 character */
|
Add multiple segments support for AZTEC, CODEONE, DATAMATRIX, DOTCODE,
GRIDMATRIX, HANXIN, MAXICODE, MICROPDF417, PDF417, QRCODE, RMQR, ULTRA
RMQR: fix ECI encoding (wrong bit length for indicator)
MICROQR: check versions M1 and M2 for allowed characters so as to give
better error messages
DOTCODE: some small optimizations
common.c: add is_chr(), segs_length(), segs_cpy()
CODEONE/CODE128/DOTCODE/GRIDMATRIX/HANXIN/MAXICODE/QRCODE/ULTRA: add
namespace prefixes to static funcs/data
includes: use Z_ prefix, unuse double underscore prefixes (guard defines)
manual.txt: compress some tables using double/treble column sets
2022-05-09 19:50:50 +01:00
|
|
|
|
c1 = (ddata[sp] & 0xff00) >> 8;
|
|
|
|
|
c2 = ddata[sp] & 0xff;
|
2016-02-20 09:38:03 +00:00
|
|
|
|
|
2019-11-28 19:15:29 +00:00
|
|
|
|
if ((c1 >= 0xa1) && (c1 <= 0xa9)) {
|
2016-02-20 09:38:03 +00:00
|
|
|
|
glyph = (0x60 * (c1 - 0xa1)) + (c2 - 0xa0);
|
2019-11-28 19:15:29 +00:00
|
|
|
|
} else if ((c1 >= 0xb0) && (c1 <= 0xf7)) {
|
2016-02-20 09:38:03 +00:00
|
|
|
|
glyph = (0x60 * (c1 - 0xb0 + 9)) + (c2 - 0xa0);
|
|
|
|
|
}
|
2019-11-28 19:15:29 +00:00
|
|
|
|
done = 1; /* GB 2312 always within above ranges */
|
2022-05-19 10:17:51 +01:00
|
|
|
|
/* Note not using the unallocated glyphs 7776 to 8191 mentioned in AIMD014 section 6.3.1.2 */
|
2016-02-20 09:38:03 +00:00
|
|
|
|
}
|
|
|
|
|
if (!(done)) {
|
|
|
|
|
if (sp != (length - 1)) {
|
Add multiple segments support for AZTEC, CODEONE, DATAMATRIX, DOTCODE,
GRIDMATRIX, HANXIN, MAXICODE, MICROPDF417, PDF417, QRCODE, RMQR, ULTRA
RMQR: fix ECI encoding (wrong bit length for indicator)
MICROQR: check versions M1 and M2 for allowed characters so as to give
better error messages
DOTCODE: some small optimizations
common.c: add is_chr(), segs_length(), segs_cpy()
CODEONE/CODE128/DOTCODE/GRIDMATRIX/HANXIN/MAXICODE/QRCODE/ULTRA: add
namespace prefixes to static funcs/data
includes: use Z_ prefix, unuse double underscore prefixes (guard defines)
manual.txt: compress some tables using double/treble column sets
2022-05-09 19:50:50 +01:00
|
|
|
|
if ((ddata[sp] == 13) && (ddata[sp + 1] == 10)) {
|
2016-02-20 09:38:03 +00:00
|
|
|
|
/* End of Line */
|
|
|
|
|
glyph = 7776;
|
|
|
|
|
sp++;
|
2019-11-28 19:15:29 +00:00
|
|
|
|
done = 1;
|
2016-02-20 09:38:03 +00:00
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
if (!(done)) {
|
|
|
|
|
if (sp != (length - 1)) {
|
2022-06-24 14:38:48 +01:00
|
|
|
|
if (z_isdigit(ddata[sp]) && z_isdigit(ddata[sp + 1])) {
|
2016-02-20 09:38:03 +00:00
|
|
|
|
/* Two digits */
|
Add multiple segments support for AZTEC, CODEONE, DATAMATRIX, DOTCODE,
GRIDMATRIX, HANXIN, MAXICODE, MICROPDF417, PDF417, QRCODE, RMQR, ULTRA
RMQR: fix ECI encoding (wrong bit length for indicator)
MICROQR: check versions M1 and M2 for allowed characters so as to give
better error messages
DOTCODE: some small optimizations
common.c: add is_chr(), segs_length(), segs_cpy()
CODEONE/CODE128/DOTCODE/GRIDMATRIX/HANXIN/MAXICODE/QRCODE/ULTRA: add
namespace prefixes to static funcs/data
includes: use Z_ prefix, unuse double underscore prefixes (guard defines)
manual.txt: compress some tables using double/treble column sets
2022-05-09 19:50:50 +01:00
|
|
|
|
glyph = 8033 + (10 * (ddata[sp] - '0')) + (ddata[sp + 1] - '0');
|
2016-02-20 09:38:03 +00:00
|
|
|
|
sp++;
|
2019-11-28 19:15:29 +00:00
|
|
|
|
done = 1;
|
2016-02-20 09:38:03 +00:00
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
if (!(done)) {
|
|
|
|
|
/* Byte value */
|
Add multiple segments support for AZTEC, CODEONE, DATAMATRIX, DOTCODE,
GRIDMATRIX, HANXIN, MAXICODE, MICROPDF417, PDF417, QRCODE, RMQR, ULTRA
RMQR: fix ECI encoding (wrong bit length for indicator)
MICROQR: check versions M1 and M2 for allowed characters so as to give
better error messages
DOTCODE: some small optimizations
common.c: add is_chr(), segs_length(), segs_cpy()
CODEONE/CODE128/DOTCODE/GRIDMATRIX/HANXIN/MAXICODE/QRCODE/ULTRA: add
namespace prefixes to static funcs/data
includes: use Z_ prefix, unuse double underscore prefixes (guard defines)
manual.txt: compress some tables using double/treble column sets
2022-05-09 19:50:50 +01:00
|
|
|
|
glyph = 7777 + ddata[sp];
|
2016-02-20 09:38:03 +00:00
|
|
|
|
}
|
|
|
|
|
|
Add multiple segments support for AZTEC, CODEONE, DATAMATRIX, DOTCODE,
GRIDMATRIX, HANXIN, MAXICODE, MICROPDF417, PDF417, QRCODE, RMQR, ULTRA
RMQR: fix ECI encoding (wrong bit length for indicator)
MICROQR: check versions M1 and M2 for allowed characters so as to give
better error messages
DOTCODE: some small optimizations
common.c: add is_chr(), segs_length(), segs_cpy()
CODEONE/CODE128/DOTCODE/GRIDMATRIX/HANXIN/MAXICODE/QRCODE/ULTRA: add
namespace prefixes to static funcs/data
includes: use Z_ prefix, unuse double underscore prefixes (guard defines)
manual.txt: compress some tables using double/treble column sets
2022-05-09 19:50:50 +01:00
|
|
|
|
if (debug_print) {
|
2021-07-07 13:58:04 +01:00
|
|
|
|
printf("[%d] ", (int) glyph);
|
2016-02-20 09:38:03 +00:00
|
|
|
|
}
|
|
|
|
|
|
2020-11-27 12:54:44 +00:00
|
|
|
|
bp = bin_append_posn(glyph, 13, binary, bp);
|
2016-02-20 09:38:03 +00:00
|
|
|
|
sp++;
|
|
|
|
|
break;
|
|
|
|
|
|
|
|
|
|
case GM_NUMBER:
|
|
|
|
|
if (last_mode != current_mode) {
|
|
|
|
|
/* Reserve a space for numeric digit padding value (2 bits) */
|
2020-11-27 12:54:44 +00:00
|
|
|
|
number_pad_posn = bp;
|
|
|
|
|
bp = bin_append_posn(0, 2, binary, bp);
|
2016-02-20 09:38:03 +00:00
|
|
|
|
}
|
|
|
|
|
p = 0;
|
|
|
|
|
ppos = -1;
|
|
|
|
|
|
|
|
|
|
/* Numeric compression can also include certain combinations of
|
|
|
|
|
non-numeric character */
|
|
|
|
|
|
|
|
|
|
numbuf[0] = '0';
|
|
|
|
|
numbuf[1] = '0';
|
|
|
|
|
numbuf[2] = '0';
|
|
|
|
|
do {
|
2022-06-24 14:38:48 +01:00
|
|
|
|
if (z_isdigit(ddata[sp])) {
|
Add multiple segments support for AZTEC, CODEONE, DATAMATRIX, DOTCODE,
GRIDMATRIX, HANXIN, MAXICODE, MICROPDF417, PDF417, QRCODE, RMQR, ULTRA
RMQR: fix ECI encoding (wrong bit length for indicator)
MICROQR: check versions M1 and M2 for allowed characters so as to give
better error messages
DOTCODE: some small optimizations
common.c: add is_chr(), segs_length(), segs_cpy()
CODEONE/CODE128/DOTCODE/GRIDMATRIX/HANXIN/MAXICODE/QRCODE/ULTRA: add
namespace prefixes to static funcs/data
includes: use Z_ prefix, unuse double underscore prefixes (guard defines)
manual.txt: compress some tables using double/treble column sets
2022-05-09 19:50:50 +01:00
|
|
|
|
numbuf[p] = ddata[sp];
|
2016-02-20 09:38:03 +00:00
|
|
|
|
p++;
|
Add multiple segments support for AZTEC, CODEONE, DATAMATRIX, DOTCODE,
GRIDMATRIX, HANXIN, MAXICODE, MICROPDF417, PDF417, QRCODE, RMQR, ULTRA
RMQR: fix ECI encoding (wrong bit length for indicator)
MICROQR: check versions M1 and M2 for allowed characters so as to give
better error messages
DOTCODE: some small optimizations
common.c: add is_chr(), segs_length(), segs_cpy()
CODEONE/CODE128/DOTCODE/GRIDMATRIX/HANXIN/MAXICODE/QRCODE/ULTRA: add
namespace prefixes to static funcs/data
includes: use Z_ prefix, unuse double underscore prefixes (guard defines)
manual.txt: compress some tables using double/treble column sets
2022-05-09 19:50:50 +01:00
|
|
|
|
} else if (posn(gm_numeral_nondigits, (const char) ddata[sp]) != -1) {
|
2019-12-04 13:45:01 +00:00
|
|
|
|
if (ppos != -1) {
|
|
|
|
|
break;
|
|
|
|
|
}
|
Add multiple segments support for AZTEC, CODEONE, DATAMATRIX, DOTCODE,
GRIDMATRIX, HANXIN, MAXICODE, MICROPDF417, PDF417, QRCODE, RMQR, ULTRA
RMQR: fix ECI encoding (wrong bit length for indicator)
MICROQR: check versions M1 and M2 for allowed characters so as to give
better error messages
DOTCODE: some small optimizations
common.c: add is_chr(), segs_length(), segs_cpy()
CODEONE/CODE128/DOTCODE/GRIDMATRIX/HANXIN/MAXICODE/QRCODE/ULTRA: add
namespace prefixes to static funcs/data
includes: use Z_ prefix, unuse double underscore prefixes (guard defines)
manual.txt: compress some tables using double/treble column sets
2022-05-09 19:50:50 +01:00
|
|
|
|
punt = ddata[sp];
|
2019-12-04 13:45:01 +00:00
|
|
|
|
ppos = p;
|
Add multiple segments support for AZTEC, CODEONE, DATAMATRIX, DOTCODE,
GRIDMATRIX, HANXIN, MAXICODE, MICROPDF417, PDF417, QRCODE, RMQR, ULTRA
RMQR: fix ECI encoding (wrong bit length for indicator)
MICROQR: check versions M1 and M2 for allowed characters so as to give
better error messages
DOTCODE: some small optimizations
common.c: add is_chr(), segs_length(), segs_cpy()
CODEONE/CODE128/DOTCODE/GRIDMATRIX/HANXIN/MAXICODE/QRCODE/ULTRA: add
namespace prefixes to static funcs/data
includes: use Z_ prefix, unuse double underscore prefixes (guard defines)
manual.txt: compress some tables using double/treble column sets
2022-05-09 19:50:50 +01:00
|
|
|
|
} else if (sp < (length - 1) && (ddata[sp] == 13) && (ddata[sp + 1] == 10)) {
|
2019-12-04 13:45:01 +00:00
|
|
|
|
/* <end of line> */
|
|
|
|
|
if (ppos != -1) {
|
2016-02-20 09:38:03 +00:00
|
|
|
|
break;
|
|
|
|
|
}
|
Add multiple segments support for AZTEC, CODEONE, DATAMATRIX, DOTCODE,
GRIDMATRIX, HANXIN, MAXICODE, MICROPDF417, PDF417, QRCODE, RMQR, ULTRA
RMQR: fix ECI encoding (wrong bit length for indicator)
MICROQR: check versions M1 and M2 for allowed characters so as to give
better error messages
DOTCODE: some small optimizations
common.c: add is_chr(), segs_length(), segs_cpy()
CODEONE/CODE128/DOTCODE/GRIDMATRIX/HANXIN/MAXICODE/QRCODE/ULTRA: add
namespace prefixes to static funcs/data
includes: use Z_ prefix, unuse double underscore prefixes (guard defines)
manual.txt: compress some tables using double/treble column sets
2022-05-09 19:50:50 +01:00
|
|
|
|
punt = ddata[sp];
|
2019-12-04 13:45:01 +00:00
|
|
|
|
sp++;
|
|
|
|
|
ppos = p;
|
|
|
|
|
} else {
|
|
|
|
|
break;
|
2016-02-20 09:38:03 +00:00
|
|
|
|
}
|
2019-12-04 13:45:01 +00:00
|
|
|
|
sp++;
|
|
|
|
|
} while ((p < 3) && (sp < length) && mode[sp] == GM_NUMBER);
|
2016-02-20 09:38:03 +00:00
|
|
|
|
|
|
|
|
|
if (ppos != -1) {
|
|
|
|
|
switch (punt) {
|
|
|
|
|
case ' ': glyph = 0;
|
|
|
|
|
break;
|
|
|
|
|
case '+': glyph = 3;
|
|
|
|
|
break;
|
|
|
|
|
case '-': glyph = 6;
|
|
|
|
|
break;
|
|
|
|
|
case '.': glyph = 9;
|
|
|
|
|
break;
|
|
|
|
|
case ',': glyph = 12;
|
|
|
|
|
break;
|
2019-12-04 13:45:01 +00:00
|
|
|
|
case 13: glyph = 15;
|
2016-02-20 09:38:03 +00:00
|
|
|
|
break;
|
|
|
|
|
}
|
|
|
|
|
glyph += ppos;
|
|
|
|
|
glyph += 1000;
|
|
|
|
|
|
Add multiple segments support for AZTEC, CODEONE, DATAMATRIX, DOTCODE,
GRIDMATRIX, HANXIN, MAXICODE, MICROPDF417, PDF417, QRCODE, RMQR, ULTRA
RMQR: fix ECI encoding (wrong bit length for indicator)
MICROQR: check versions M1 and M2 for allowed characters so as to give
better error messages
DOTCODE: some small optimizations
common.c: add is_chr(), segs_length(), segs_cpy()
CODEONE/CODE128/DOTCODE/GRIDMATRIX/HANXIN/MAXICODE/QRCODE/ULTRA: add
namespace prefixes to static funcs/data
includes: use Z_ prefix, unuse double underscore prefixes (guard defines)
manual.txt: compress some tables using double/treble column sets
2022-05-09 19:50:50 +01:00
|
|
|
|
if (debug_print) {
|
2021-07-07 13:58:04 +01:00
|
|
|
|
printf("[%d] ", (int) glyph);
|
2016-02-20 09:38:03 +00:00
|
|
|
|
}
|
|
|
|
|
|
2020-11-27 12:54:44 +00:00
|
|
|
|
bp = bin_append_posn(glyph, 10, binary, bp);
|
2016-02-20 09:38:03 +00:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
glyph = (100 * (numbuf[0] - '0')) + (10 * (numbuf[1] - '0')) + (numbuf[2] - '0');
|
Add multiple segments support for AZTEC, CODEONE, DATAMATRIX, DOTCODE,
GRIDMATRIX, HANXIN, MAXICODE, MICROPDF417, PDF417, QRCODE, RMQR, ULTRA
RMQR: fix ECI encoding (wrong bit length for indicator)
MICROQR: check versions M1 and M2 for allowed characters so as to give
better error messages
DOTCODE: some small optimizations
common.c: add is_chr(), segs_length(), segs_cpy()
CODEONE/CODE128/DOTCODE/GRIDMATRIX/HANXIN/MAXICODE/QRCODE/ULTRA: add
namespace prefixes to static funcs/data
includes: use Z_ prefix, unuse double underscore prefixes (guard defines)
manual.txt: compress some tables using double/treble column sets
2022-05-09 19:50:50 +01:00
|
|
|
|
if (debug_print) {
|
2021-07-07 13:58:04 +01:00
|
|
|
|
printf("[%d] ", (int) glyph);
|
2016-02-20 09:38:03 +00:00
|
|
|
|
}
|
|
|
|
|
|
2020-11-27 12:54:44 +00:00
|
|
|
|
bp = bin_append_posn(glyph, 10, binary, bp);
|
2016-02-20 09:38:03 +00:00
|
|
|
|
break;
|
|
|
|
|
|
|
|
|
|
case GM_BYTE:
|
|
|
|
|
if (last_mode != current_mode) {
|
|
|
|
|
/* Reserve space for byte block length indicator (9 bits) */
|
2020-11-27 12:54:44 +00:00
|
|
|
|
byte_count_posn = bp;
|
|
|
|
|
bp = bin_append_posn(0, 9, binary, bp);
|
2016-02-20 09:38:03 +00:00
|
|
|
|
}
|
Add multiple segments support for AZTEC, CODEONE, DATAMATRIX, DOTCODE,
GRIDMATRIX, HANXIN, MAXICODE, MICROPDF417, PDF417, QRCODE, RMQR, ULTRA
RMQR: fix ECI encoding (wrong bit length for indicator)
MICROQR: check versions M1 and M2 for allowed characters so as to give
better error messages
DOTCODE: some small optimizations
common.c: add is_chr(), segs_length(), segs_cpy()
CODEONE/CODE128/DOTCODE/GRIDMATRIX/HANXIN/MAXICODE/QRCODE/ULTRA: add
namespace prefixes to static funcs/data
includes: use Z_ prefix, unuse double underscore prefixes (guard defines)
manual.txt: compress some tables using double/treble column sets
2022-05-09 19:50:50 +01:00
|
|
|
|
glyph = ddata[sp];
|
2019-12-04 13:45:01 +00:00
|
|
|
|
if (byte_count == 512 || (glyph > 0xFF && byte_count == 511)) {
|
2016-02-20 09:38:03 +00:00
|
|
|
|
/* Maximum byte block size is 512 bytes. If longer is needed then start a new block */
|
2019-12-04 13:45:01 +00:00
|
|
|
|
if (glyph > 0xFF && byte_count == 511) { /* Split double-byte */
|
2020-11-27 12:54:44 +00:00
|
|
|
|
bp = bin_append_posn(glyph >> 8, 8, binary, bp);
|
2019-12-04 13:45:01 +00:00
|
|
|
|
glyph &= 0xFF;
|
|
|
|
|
byte_count++;
|
|
|
|
|
}
|
Add multiple segments support for AZTEC, CODEONE, DATAMATRIX, DOTCODE,
GRIDMATRIX, HANXIN, MAXICODE, MICROPDF417, PDF417, QRCODE, RMQR, ULTRA
RMQR: fix ECI encoding (wrong bit length for indicator)
MICROQR: check versions M1 and M2 for allowed characters so as to give
better error messages
DOTCODE: some small optimizations
common.c: add is_chr(), segs_length(), segs_cpy()
CODEONE/CODE128/DOTCODE/GRIDMATRIX/HANXIN/MAXICODE/QRCODE/ULTRA: add
namespace prefixes to static funcs/data
includes: use Z_ prefix, unuse double underscore prefixes (guard defines)
manual.txt: compress some tables using double/treble column sets
2022-05-09 19:50:50 +01:00
|
|
|
|
gm_add_byte_count(binary, byte_count_posn, byte_count);
|
2020-11-27 12:54:44 +00:00
|
|
|
|
bp = bin_append_posn(7, 4, binary, bp);
|
|
|
|
|
byte_count_posn = bp;
|
|
|
|
|
bp = bin_append_posn(0, 9, binary, bp);
|
2016-02-20 09:38:03 +00:00
|
|
|
|
byte_count = 0;
|
|
|
|
|
}
|
|
|
|
|
|
Add multiple segments support for AZTEC, CODEONE, DATAMATRIX, DOTCODE,
GRIDMATRIX, HANXIN, MAXICODE, MICROPDF417, PDF417, QRCODE, RMQR, ULTRA
RMQR: fix ECI encoding (wrong bit length for indicator)
MICROQR: check versions M1 and M2 for allowed characters so as to give
better error messages
DOTCODE: some small optimizations
common.c: add is_chr(), segs_length(), segs_cpy()
CODEONE/CODE128/DOTCODE/GRIDMATRIX/HANXIN/MAXICODE/QRCODE/ULTRA: add
namespace prefixes to static funcs/data
includes: use Z_ prefix, unuse double underscore prefixes (guard defines)
manual.txt: compress some tables using double/treble column sets
2022-05-09 19:50:50 +01:00
|
|
|
|
if (debug_print) {
|
2021-07-07 13:58:04 +01:00
|
|
|
|
printf("[%d] ", (int) glyph);
|
2016-02-20 09:38:03 +00:00
|
|
|
|
}
|
2020-11-27 12:54:44 +00:00
|
|
|
|
bp = bin_append_posn(glyph, glyph > 0xFF ? 16 : 8, binary, bp);
|
2016-02-20 09:38:03 +00:00
|
|
|
|
sp++;
|
|
|
|
|
byte_count++;
|
2019-12-04 13:45:01 +00:00
|
|
|
|
if (glyph > 0xFF) {
|
|
|
|
|
byte_count++;
|
|
|
|
|
}
|
2016-02-20 09:38:03 +00:00
|
|
|
|
break;
|
|
|
|
|
|
|
|
|
|
case GM_MIXED:
|
|
|
|
|
shift = 1;
|
2022-06-24 14:38:48 +01:00
|
|
|
|
if (z_isdigit(ddata[sp])) {
|
2016-02-20 09:38:03 +00:00
|
|
|
|
shift = 0;
|
2022-06-24 14:38:48 +01:00
|
|
|
|
} else if (z_isupper(ddata[sp])) {
|
2016-02-20 09:38:03 +00:00
|
|
|
|
shift = 0;
|
2022-06-24 14:38:48 +01:00
|
|
|
|
} else if (z_islower(ddata[sp])) {
|
2016-02-20 09:38:03 +00:00
|
|
|
|
shift = 0;
|
Add multiple segments support for AZTEC, CODEONE, DATAMATRIX, DOTCODE,
GRIDMATRIX, HANXIN, MAXICODE, MICROPDF417, PDF417, QRCODE, RMQR, ULTRA
RMQR: fix ECI encoding (wrong bit length for indicator)
MICROQR: check versions M1 and M2 for allowed characters so as to give
better error messages
DOTCODE: some small optimizations
common.c: add is_chr(), segs_length(), segs_cpy()
CODEONE/CODE128/DOTCODE/GRIDMATRIX/HANXIN/MAXICODE/QRCODE/ULTRA: add
namespace prefixes to static funcs/data
includes: use Z_ prefix, unuse double underscore prefixes (guard defines)
manual.txt: compress some tables using double/treble column sets
2022-05-09 19:50:50 +01:00
|
|
|
|
} else if (ddata[sp] == ' ') {
|
2016-02-20 09:38:03 +00:00
|
|
|
|
shift = 0;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
if (shift == 0) {
|
|
|
|
|
/* Mixed Mode character */
|
Add multiple segments support for AZTEC, CODEONE, DATAMATRIX, DOTCODE,
GRIDMATRIX, HANXIN, MAXICODE, MICROPDF417, PDF417, QRCODE, RMQR, ULTRA
RMQR: fix ECI encoding (wrong bit length for indicator)
MICROQR: check versions M1 and M2 for allowed characters so as to give
better error messages
DOTCODE: some small optimizations
common.c: add is_chr(), segs_length(), segs_cpy()
CODEONE/CODE128/DOTCODE/GRIDMATRIX/HANXIN/MAXICODE/QRCODE/ULTRA: add
namespace prefixes to static funcs/data
includes: use Z_ prefix, unuse double underscore prefixes (guard defines)
manual.txt: compress some tables using double/treble column sets
2022-05-09 19:50:50 +01:00
|
|
|
|
glyph = posn(EUROPIUM, (const char) ddata[sp]);
|
|
|
|
|
if (debug_print) {
|
2021-07-07 13:58:04 +01:00
|
|
|
|
printf("[%d] ", (int) glyph);
|
2016-02-20 09:38:03 +00:00
|
|
|
|
}
|
|
|
|
|
|
2020-11-27 12:54:44 +00:00
|
|
|
|
bp = bin_append_posn(glyph, 6, binary, bp);
|
2016-02-20 09:38:03 +00:00
|
|
|
|
} else {
|
|
|
|
|
/* Shift Mode character */
|
2020-11-27 12:54:44 +00:00
|
|
|
|
bp = bin_append_posn(1014, 10, binary, bp); /* shift indicator */
|
Add multiple segments support for AZTEC, CODEONE, DATAMATRIX, DOTCODE,
GRIDMATRIX, HANXIN, MAXICODE, MICROPDF417, PDF417, QRCODE, RMQR, ULTRA
RMQR: fix ECI encoding (wrong bit length for indicator)
MICROQR: check versions M1 and M2 for allowed characters so as to give
better error messages
DOTCODE: some small optimizations
common.c: add is_chr(), segs_length(), segs_cpy()
CODEONE/CODE128/DOTCODE/GRIDMATRIX/HANXIN/MAXICODE/QRCODE/ULTRA: add
namespace prefixes to static funcs/data
includes: use Z_ prefix, unuse double underscore prefixes (guard defines)
manual.txt: compress some tables using double/treble column sets
2022-05-09 19:50:50 +01:00
|
|
|
|
bp = gm_add_shift_char(binary, bp, ddata[sp], debug_print);
|
2016-02-20 09:38:03 +00:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
sp++;
|
|
|
|
|
break;
|
|
|
|
|
|
|
|
|
|
case GM_UPPER:
|
|
|
|
|
shift = 1;
|
2022-06-24 14:38:48 +01:00
|
|
|
|
if (z_isupper(ddata[sp])) {
|
2016-02-20 09:38:03 +00:00
|
|
|
|
shift = 0;
|
Add multiple segments support for AZTEC, CODEONE, DATAMATRIX, DOTCODE,
GRIDMATRIX, HANXIN, MAXICODE, MICROPDF417, PDF417, QRCODE, RMQR, ULTRA
RMQR: fix ECI encoding (wrong bit length for indicator)
MICROQR: check versions M1 and M2 for allowed characters so as to give
better error messages
DOTCODE: some small optimizations
common.c: add is_chr(), segs_length(), segs_cpy()
CODEONE/CODE128/DOTCODE/GRIDMATRIX/HANXIN/MAXICODE/QRCODE/ULTRA: add
namespace prefixes to static funcs/data
includes: use Z_ prefix, unuse double underscore prefixes (guard defines)
manual.txt: compress some tables using double/treble column sets
2022-05-09 19:50:50 +01:00
|
|
|
|
} else if (ddata[sp] == ' ') {
|
2016-02-20 09:38:03 +00:00
|
|
|
|
shift = 0;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
if (shift == 0) {
|
|
|
|
|
/* Upper Case character */
|
Add multiple segments support for AZTEC, CODEONE, DATAMATRIX, DOTCODE,
GRIDMATRIX, HANXIN, MAXICODE, MICROPDF417, PDF417, QRCODE, RMQR, ULTRA
RMQR: fix ECI encoding (wrong bit length for indicator)
MICROQR: check versions M1 and M2 for allowed characters so as to give
better error messages
DOTCODE: some small optimizations
common.c: add is_chr(), segs_length(), segs_cpy()
CODEONE/CODE128/DOTCODE/GRIDMATRIX/HANXIN/MAXICODE/QRCODE/ULTRA: add
namespace prefixes to static funcs/data
includes: use Z_ prefix, unuse double underscore prefixes (guard defines)
manual.txt: compress some tables using double/treble column sets
2022-05-09 19:50:50 +01:00
|
|
|
|
glyph = posn(EUROPIUM_UPR, (const char) ddata[sp]);
|
|
|
|
|
if (debug_print) {
|
2021-07-07 13:58:04 +01:00
|
|
|
|
printf("[%d] ", (int) glyph);
|
2016-02-20 09:38:03 +00:00
|
|
|
|
}
|
|
|
|
|
|
2020-11-27 12:54:44 +00:00
|
|
|
|
bp = bin_append_posn(glyph, 5, binary, bp);
|
2016-02-20 09:38:03 +00:00
|
|
|
|
} else {
|
|
|
|
|
/* Shift Mode character */
|
2020-11-27 12:54:44 +00:00
|
|
|
|
bp = bin_append_posn(125, 7, binary, bp); /* shift indicator */
|
Add multiple segments support for AZTEC, CODEONE, DATAMATRIX, DOTCODE,
GRIDMATRIX, HANXIN, MAXICODE, MICROPDF417, PDF417, QRCODE, RMQR, ULTRA
RMQR: fix ECI encoding (wrong bit length for indicator)
MICROQR: check versions M1 and M2 for allowed characters so as to give
better error messages
DOTCODE: some small optimizations
common.c: add is_chr(), segs_length(), segs_cpy()
CODEONE/CODE128/DOTCODE/GRIDMATRIX/HANXIN/MAXICODE/QRCODE/ULTRA: add
namespace prefixes to static funcs/data
includes: use Z_ prefix, unuse double underscore prefixes (guard defines)
manual.txt: compress some tables using double/treble column sets
2022-05-09 19:50:50 +01:00
|
|
|
|
bp = gm_add_shift_char(binary, bp, ddata[sp], debug_print);
|
2016-02-20 09:38:03 +00:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
sp++;
|
|
|
|
|
break;
|
|
|
|
|
|
|
|
|
|
case GM_LOWER:
|
|
|
|
|
shift = 1;
|
2022-06-24 14:38:48 +01:00
|
|
|
|
if (z_islower(ddata[sp])) {
|
2016-02-20 09:38:03 +00:00
|
|
|
|
shift = 0;
|
Add multiple segments support for AZTEC, CODEONE, DATAMATRIX, DOTCODE,
GRIDMATRIX, HANXIN, MAXICODE, MICROPDF417, PDF417, QRCODE, RMQR, ULTRA
RMQR: fix ECI encoding (wrong bit length for indicator)
MICROQR: check versions M1 and M2 for allowed characters so as to give
better error messages
DOTCODE: some small optimizations
common.c: add is_chr(), segs_length(), segs_cpy()
CODEONE/CODE128/DOTCODE/GRIDMATRIX/HANXIN/MAXICODE/QRCODE/ULTRA: add
namespace prefixes to static funcs/data
includes: use Z_ prefix, unuse double underscore prefixes (guard defines)
manual.txt: compress some tables using double/treble column sets
2022-05-09 19:50:50 +01:00
|
|
|
|
} else if (ddata[sp] == ' ') {
|
2016-02-20 09:38:03 +00:00
|
|
|
|
shift = 0;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
if (shift == 0) {
|
|
|
|
|
/* Lower Case character */
|
Add multiple segments support for AZTEC, CODEONE, DATAMATRIX, DOTCODE,
GRIDMATRIX, HANXIN, MAXICODE, MICROPDF417, PDF417, QRCODE, RMQR, ULTRA
RMQR: fix ECI encoding (wrong bit length for indicator)
MICROQR: check versions M1 and M2 for allowed characters so as to give
better error messages
DOTCODE: some small optimizations
common.c: add is_chr(), segs_length(), segs_cpy()
CODEONE/CODE128/DOTCODE/GRIDMATRIX/HANXIN/MAXICODE/QRCODE/ULTRA: add
namespace prefixes to static funcs/data
includes: use Z_ prefix, unuse double underscore prefixes (guard defines)
manual.txt: compress some tables using double/treble column sets
2022-05-09 19:50:50 +01:00
|
|
|
|
glyph = posn(EUROPIUM_LWR, (const char) ddata[sp]);
|
|
|
|
|
if (debug_print) {
|
2021-07-07 13:58:04 +01:00
|
|
|
|
printf("[%d] ", (int) glyph);
|
2016-02-20 09:38:03 +00:00
|
|
|
|
}
|
2017-10-23 21:37:52 +02:00
|
|
|
|
|
2020-11-27 12:54:44 +00:00
|
|
|
|
bp = bin_append_posn(glyph, 5, binary, bp);
|
2016-02-20 09:38:03 +00:00
|
|
|
|
} else {
|
|
|
|
|
/* Shift Mode character */
|
2020-11-27 12:54:44 +00:00
|
|
|
|
bp = bin_append_posn(125, 7, binary, bp); /* shift indicator */
|
Add multiple segments support for AZTEC, CODEONE, DATAMATRIX, DOTCODE,
GRIDMATRIX, HANXIN, MAXICODE, MICROPDF417, PDF417, QRCODE, RMQR, ULTRA
RMQR: fix ECI encoding (wrong bit length for indicator)
MICROQR: check versions M1 and M2 for allowed characters so as to give
better error messages
DOTCODE: some small optimizations
common.c: add is_chr(), segs_length(), segs_cpy()
CODEONE/CODE128/DOTCODE/GRIDMATRIX/HANXIN/MAXICODE/QRCODE/ULTRA: add
namespace prefixes to static funcs/data
includes: use Z_ prefix, unuse double underscore prefixes (guard defines)
manual.txt: compress some tables using double/treble column sets
2022-05-09 19:50:50 +01:00
|
|
|
|
bp = gm_add_shift_char(binary, bp, ddata[sp], debug_print);
|
2016-02-20 09:38:03 +00:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
sp++;
|
|
|
|
|
break;
|
|
|
|
|
}
|
2020-11-27 12:54:44 +00:00
|
|
|
|
if (bp > 9191) {
|
2016-02-20 09:38:03 +00:00
|
|
|
|
return ZINT_ERROR_TOO_LONG;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
} while (sp < length);
|
|
|
|
|
|
|
|
|
|
if (current_mode == GM_NUMBER) {
|
|
|
|
|
/* add numeric block padding value */
|
|
|
|
|
switch (p) {
|
|
|
|
|
case 1: binary[number_pad_posn] = '1';
|
|
|
|
|
binary[number_pad_posn + 1] = '0';
|
2022-07-14 16:01:30 +01:00
|
|
|
|
break; /* 2 pad digits */
|
2016-02-20 09:38:03 +00:00
|
|
|
|
case 2: binary[number_pad_posn] = '0';
|
|
|
|
|
binary[number_pad_posn + 1] = '1';
|
2022-07-14 16:01:30 +01:00
|
|
|
|
break; /* 1 pad digit */
|
2016-02-20 09:38:03 +00:00
|
|
|
|
case 3: binary[number_pad_posn] = '0';
|
|
|
|
|
binary[number_pad_posn + 1] = '0';
|
2022-07-14 16:01:30 +01:00
|
|
|
|
break; /* 0 pad digits */
|
2016-02-20 09:38:03 +00:00
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
if (current_mode == GM_BYTE) {
|
|
|
|
|
/* Add byte block length indicator */
|
Add multiple segments support for AZTEC, CODEONE, DATAMATRIX, DOTCODE,
GRIDMATRIX, HANXIN, MAXICODE, MICROPDF417, PDF417, QRCODE, RMQR, ULTRA
RMQR: fix ECI encoding (wrong bit length for indicator)
MICROQR: check versions M1 and M2 for allowed characters so as to give
better error messages
DOTCODE: some small optimizations
common.c: add is_chr(), segs_length(), segs_cpy()
CODEONE/CODE128/DOTCODE/GRIDMATRIX/HANXIN/MAXICODE/QRCODE/ULTRA: add
namespace prefixes to static funcs/data
includes: use Z_ prefix, unuse double underscore prefixes (guard defines)
manual.txt: compress some tables using double/treble column sets
2022-05-09 19:50:50 +01:00
|
|
|
|
gm_add_byte_count(binary, byte_count_posn, byte_count);
|
2016-02-20 09:38:03 +00:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/* Add "end of data" character */
|
|
|
|
|
switch (current_mode) {
|
2020-11-27 12:54:44 +00:00
|
|
|
|
case GM_CHINESE: bp = bin_append_posn(8160, 13, binary, bp);
|
2017-05-14 08:15:08 +01:00
|
|
|
|
break;
|
2020-11-27 12:54:44 +00:00
|
|
|
|
case GM_NUMBER: bp = bin_append_posn(1018, 10, binary, bp);
|
2017-05-14 08:15:08 +01:00
|
|
|
|
break;
|
2016-02-20 09:38:03 +00:00
|
|
|
|
case GM_LOWER:
|
2020-11-27 12:54:44 +00:00
|
|
|
|
case GM_UPPER: bp = bin_append_posn(27, 5, binary, bp);
|
2017-05-14 08:15:08 +01:00
|
|
|
|
break;
|
2020-11-27 12:54:44 +00:00
|
|
|
|
case GM_MIXED: bp = bin_append_posn(1008, 10, binary, bp);
|
2017-05-14 08:15:08 +01:00
|
|
|
|
break;
|
2020-11-27 12:54:44 +00:00
|
|
|
|
case GM_BYTE: bp = bin_append_posn(0, 4, binary, bp);
|
2017-05-14 08:15:08 +01:00
|
|
|
|
break;
|
2016-02-20 09:38:03 +00:00
|
|
|
|
}
|
|
|
|
|
|
Add multiple segments support for AZTEC, CODEONE, DATAMATRIX, DOTCODE,
GRIDMATRIX, HANXIN, MAXICODE, MICROPDF417, PDF417, QRCODE, RMQR, ULTRA
RMQR: fix ECI encoding (wrong bit length for indicator)
MICROQR: check versions M1 and M2 for allowed characters so as to give
better error messages
DOTCODE: some small optimizations
common.c: add is_chr(), segs_length(), segs_cpy()
CODEONE/CODE128/DOTCODE/GRIDMATRIX/HANXIN/MAXICODE/QRCODE/ULTRA: add
namespace prefixes to static funcs/data
includes: use Z_ prefix, unuse double underscore prefixes (guard defines)
manual.txt: compress some tables using double/treble column sets
2022-05-09 19:50:50 +01:00
|
|
|
|
if (bp > 9191) {
|
|
|
|
|
return ZINT_ERROR_TOO_LONG;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
*p_bp = bp;
|
|
|
|
|
|
|
|
|
|
if (debug_print) {
|
|
|
|
|
printf("\nBinary (%d): %.*s\n", bp, bp, binary);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
return 0;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
static int gm_encode_segs(unsigned int ddata[], const struct zint_seg segs[], const int seg_count, char binary[],
|
|
|
|
|
const int reader, const struct zint_structapp *p_structapp, int *p_bin_len, const int debug_print) {
|
|
|
|
|
int i;
|
|
|
|
|
unsigned int *dd = ddata;
|
|
|
|
|
int bp = 0;
|
|
|
|
|
int p;
|
|
|
|
|
|
|
|
|
|
if (reader && (!p_structapp || p_structapp->index == 1)) { /* Appears only in 1st symbol if Structured Append */
|
|
|
|
|
bp = bin_append_posn(10, 4, binary, bp); /* FNC3 - Reader Initialisation */
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
if (p_structapp) {
|
|
|
|
|
bp = bin_append_posn(9, 4, binary, bp); /* FNC2 - Structured Append */
|
|
|
|
|
bp = bin_append_posn(to_int((const unsigned char *) p_structapp->id, (int) strlen(p_structapp->id)), 8,
|
|
|
|
|
binary, bp); /* File signature */
|
|
|
|
|
bp = bin_append_posn(p_structapp->count - 1, 4, binary, bp);
|
|
|
|
|
bp = bin_append_posn(p_structapp->index - 1, 4, binary, bp);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
for (i = 0; i < seg_count; i++) {
|
|
|
|
|
int error_number = gm_encode(dd, segs[i].length, binary, segs[i].eci, &bp, debug_print);
|
|
|
|
|
if (error_number != 0) {
|
|
|
|
|
return error_number;
|
|
|
|
|
}
|
|
|
|
|
dd += segs[i].length;
|
|
|
|
|
}
|
|
|
|
|
|
2016-02-20 09:38:03 +00:00
|
|
|
|
/* Add padding bits if required */
|
2020-11-27 12:54:44 +00:00
|
|
|
|
p = 7 - (bp % 7);
|
2019-11-28 19:15:29 +00:00
|
|
|
|
if (p % 7) {
|
2020-11-27 12:54:44 +00:00
|
|
|
|
bp = bin_append_posn(0, p, binary, bp);
|
2016-02-20 09:38:03 +00:00
|
|
|
|
}
|
Add multiple segments support for AZTEC, CODEONE, DATAMATRIX, DOTCODE,
GRIDMATRIX, HANXIN, MAXICODE, MICROPDF417, PDF417, QRCODE, RMQR, ULTRA
RMQR: fix ECI encoding (wrong bit length for indicator)
MICROQR: check versions M1 and M2 for allowed characters so as to give
better error messages
DOTCODE: some small optimizations
common.c: add is_chr(), segs_length(), segs_cpy()
CODEONE/CODE128/DOTCODE/GRIDMATRIX/HANXIN/MAXICODE/QRCODE/ULTRA: add
namespace prefixes to static funcs/data
includes: use Z_ prefix, unuse double underscore prefixes (guard defines)
manual.txt: compress some tables using double/treble column sets
2022-05-09 19:50:50 +01:00
|
|
|
|
/* Note bit-padding can't tip `bp` over max 9191 (1313 * 7) */
|
2016-02-20 09:38:03 +00:00
|
|
|
|
|
Add multiple segments support for AZTEC, CODEONE, DATAMATRIX, DOTCODE,
GRIDMATRIX, HANXIN, MAXICODE, MICROPDF417, PDF417, QRCODE, RMQR, ULTRA
RMQR: fix ECI encoding (wrong bit length for indicator)
MICROQR: check versions M1 and M2 for allowed characters so as to give
better error messages
DOTCODE: some small optimizations
common.c: add is_chr(), segs_length(), segs_cpy()
CODEONE/CODE128/DOTCODE/GRIDMATRIX/HANXIN/MAXICODE/QRCODE/ULTRA: add
namespace prefixes to static funcs/data
includes: use Z_ prefix, unuse double underscore prefixes (guard defines)
manual.txt: compress some tables using double/treble column sets
2022-05-09 19:50:50 +01:00
|
|
|
|
if (debug_print) {
|
|
|
|
|
printf("\nBinary (%d): %.*s\n", bp, bp, binary);
|
2016-02-20 09:38:03 +00:00
|
|
|
|
}
|
2020-11-27 12:54:44 +00:00
|
|
|
|
|
Add multiple segments support for AZTEC, CODEONE, DATAMATRIX, DOTCODE,
GRIDMATRIX, HANXIN, MAXICODE, MICROPDF417, PDF417, QRCODE, RMQR, ULTRA
RMQR: fix ECI encoding (wrong bit length for indicator)
MICROQR: check versions M1 and M2 for allowed characters so as to give
better error messages
DOTCODE: some small optimizations
common.c: add is_chr(), segs_length(), segs_cpy()
CODEONE/CODE128/DOTCODE/GRIDMATRIX/HANXIN/MAXICODE/QRCODE/ULTRA: add
namespace prefixes to static funcs/data
includes: use Z_ prefix, unuse double underscore prefixes (guard defines)
manual.txt: compress some tables using double/treble column sets
2022-05-09 19:50:50 +01:00
|
|
|
|
*p_bin_len = bp;
|
2020-11-27 12:54:44 +00:00
|
|
|
|
|
2016-02-20 09:38:03 +00:00
|
|
|
|
return 0;
|
2009-10-21 09:08:44 +00:00
|
|
|
|
}
|
|
|
|
|
|
2020-11-27 12:54:44 +00:00
|
|
|
|
static void gm_add_ecc(const char binary[], const int data_posn, const int layers, const int ecc_level,
|
|
|
|
|
unsigned char word[]) {
|
2016-02-23 19:21:48 +00:00
|
|
|
|
int data_cw, i, j, wp, p;
|
2016-02-20 09:38:03 +00:00
|
|
|
|
int n1, b1, n2, b2, e1, b3, e2;
|
2017-09-10 12:03:09 -03:00
|
|
|
|
int block_size, ecc_size;
|
2019-12-16 17:31:52 +00:00
|
|
|
|
unsigned char data[1320], block[130];
|
2016-02-20 09:38:03 +00:00
|
|
|
|
unsigned char data_block[115], ecc_block[70];
|
2020-11-27 12:54:44 +00:00
|
|
|
|
rs_t rs;
|
2016-02-20 09:38:03 +00:00
|
|
|
|
|
|
|
|
|
data_cw = gm_data_codewords[((layers - 1) * 5) + (ecc_level - 1)];
|
|
|
|
|
|
|
|
|
|
for (i = 0; i < 1320; i++) {
|
|
|
|
|
data[i] = 0;
|
|
|
|
|
}
|
|
|
|
|
|
2019-11-28 19:15:29 +00:00
|
|
|
|
/* Convert from binary stream to 7-bit codewords */
|
2020-11-27 12:54:44 +00:00
|
|
|
|
for (i = 0; i < data_posn; i++) {
|
2016-02-23 19:21:48 +00:00
|
|
|
|
for (p = 0; p < 7; p++) {
|
2016-02-20 09:38:03 +00:00
|
|
|
|
if (binary[i * 7 + p] == '1') {
|
|
|
|
|
data[i] += (0x40 >> p);
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/* Add padding codewords */
|
|
|
|
|
data[data_posn] = 0x00;
|
2020-11-27 12:54:44 +00:00
|
|
|
|
for (i = (data_posn + 1); i < data_cw; i++) {
|
2016-02-20 09:38:03 +00:00
|
|
|
|
if (i & 1) {
|
|
|
|
|
data[i] = 0x7e;
|
|
|
|
|
} else {
|
|
|
|
|
data[i] = 0x00;
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/* Get block sizes */
|
|
|
|
|
n1 = gm_n1[(layers - 1)];
|
|
|
|
|
b1 = gm_b1[(layers - 1)];
|
|
|
|
|
n2 = n1 - 1;
|
|
|
|
|
b2 = gm_b2[(layers - 1)];
|
|
|
|
|
e1 = gm_ebeb[((layers - 1) * 20) + ((ecc_level - 1) * 4)];
|
|
|
|
|
b3 = gm_ebeb[((layers - 1) * 20) + ((ecc_level - 1) * 4) + 1];
|
|
|
|
|
e2 = gm_ebeb[((layers - 1) * 20) + ((ecc_level - 1) * 4) + 2];
|
|
|
|
|
|
2020-11-27 12:54:44 +00:00
|
|
|
|
rs_init_gf(&rs, 0x89);
|
|
|
|
|
|
2016-02-20 09:38:03 +00:00
|
|
|
|
/* Split the data into blocks */
|
|
|
|
|
wp = 0;
|
|
|
|
|
for (i = 0; i < (b1 + b2); i++) {
|
2017-10-23 21:34:31 +02:00
|
|
|
|
int data_size;
|
2016-02-20 09:38:03 +00:00
|
|
|
|
if (i < b1) {
|
|
|
|
|
block_size = n1;
|
|
|
|
|
} else {
|
|
|
|
|
block_size = n2;
|
|
|
|
|
}
|
|
|
|
|
if (i < b3) {
|
|
|
|
|
ecc_size = e1;
|
|
|
|
|
} else {
|
|
|
|
|
ecc_size = e2;
|
|
|
|
|
}
|
2017-10-16 19:26:54 +02:00
|
|
|
|
data_size = block_size - ecc_size;
|
2016-02-20 09:38:03 +00:00
|
|
|
|
|
|
|
|
|
/* printf("block %d/%d: data %d / ecc %d\n", i + 1, (b1 + b2), data_size, ecc_size);*/
|
|
|
|
|
|
|
|
|
|
for (j = 0; j < data_size; j++) {
|
|
|
|
|
data_block[j] = data[wp];
|
|
|
|
|
wp++;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/* Calculate ECC data for this block */
|
2020-11-27 12:54:44 +00:00
|
|
|
|
rs_init_code(&rs, ecc_size, 1);
|
|
|
|
|
rs_encode(&rs, data_size, data_block, ecc_block);
|
2016-02-20 09:38:03 +00:00
|
|
|
|
|
|
|
|
|
/* Correct error correction data but in reverse order */
|
|
|
|
|
for (j = 0; j < data_size; j++) {
|
|
|
|
|
block[j] = data_block[j];
|
|
|
|
|
}
|
|
|
|
|
for (j = 0; j < ecc_size; j++) {
|
|
|
|
|
block[(j + data_size)] = ecc_block[ecc_size - j - 1];
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
for (j = 0; j < n2; j++) {
|
|
|
|
|
word[((b1 + b2) * j) + i] = block[j];
|
|
|
|
|
}
|
|
|
|
|
if (block_size == n1) {
|
|
|
|
|
word[((b1 + b2) * (n1 - 1)) + i] = block[(n1 - 1)];
|
|
|
|
|
}
|
|
|
|
|
}
|
2009-10-21 09:08:44 +00:00
|
|
|
|
}
|
|
|
|
|
|
Add multiple segments support for AZTEC, CODEONE, DATAMATRIX, DOTCODE,
GRIDMATRIX, HANXIN, MAXICODE, MICROPDF417, PDF417, QRCODE, RMQR, ULTRA
RMQR: fix ECI encoding (wrong bit length for indicator)
MICROQR: check versions M1 and M2 for allowed characters so as to give
better error messages
DOTCODE: some small optimizations
common.c: add is_chr(), segs_length(), segs_cpy()
CODEONE/CODE128/DOTCODE/GRIDMATRIX/HANXIN/MAXICODE/QRCODE/ULTRA: add
namespace prefixes to static funcs/data
includes: use Z_ prefix, unuse double underscore prefixes (guard defines)
manual.txt: compress some tables using double/treble column sets
2022-05-09 19:50:50 +01:00
|
|
|
|
static void gm_place_macromodule(char grid[], int x, int y, int word1, int word2, int size) {
|
2016-02-20 09:38:03 +00:00
|
|
|
|
int i, j;
|
|
|
|
|
|
|
|
|
|
i = (x * 6) + 1;
|
|
|
|
|
j = (y * 6) + 1;
|
|
|
|
|
|
|
|
|
|
if (word2 & 0x40) {
|
|
|
|
|
grid[(j * size) + i + 2] = '1';
|
|
|
|
|
}
|
|
|
|
|
if (word2 & 0x20) {
|
|
|
|
|
grid[(j * size) + i + 3] = '1';
|
|
|
|
|
}
|
|
|
|
|
if (word2 & 0x10) {
|
|
|
|
|
grid[((j + 1) * size) + i] = '1';
|
|
|
|
|
}
|
|
|
|
|
if (word2 & 0x08) {
|
|
|
|
|
grid[((j + 1) * size) + i + 1] = '1';
|
|
|
|
|
}
|
|
|
|
|
if (word2 & 0x04) {
|
|
|
|
|
grid[((j + 1) * size) + i + 2] = '1';
|
|
|
|
|
}
|
|
|
|
|
if (word2 & 0x02) {
|
|
|
|
|
grid[((j + 1) * size) + i + 3] = '1';
|
|
|
|
|
}
|
|
|
|
|
if (word2 & 0x01) {
|
|
|
|
|
grid[((j + 2) * size) + i] = '1';
|
|
|
|
|
}
|
|
|
|
|
if (word1 & 0x40) {
|
|
|
|
|
grid[((j + 2) * size) + i + 1] = '1';
|
|
|
|
|
}
|
|
|
|
|
if (word1 & 0x20) {
|
|
|
|
|
grid[((j + 2) * size) + i + 2] = '1';
|
|
|
|
|
}
|
|
|
|
|
if (word1 & 0x10) {
|
|
|
|
|
grid[((j + 2) * size) + i + 3] = '1';
|
|
|
|
|
}
|
|
|
|
|
if (word1 & 0x08) {
|
|
|
|
|
grid[((j + 3) * size) + i] = '1';
|
|
|
|
|
}
|
|
|
|
|
if (word1 & 0x04) {
|
|
|
|
|
grid[((j + 3) * size) + i + 1] = '1';
|
|
|
|
|
}
|
|
|
|
|
if (word1 & 0x02) {
|
|
|
|
|
grid[((j + 3) * size) + i + 2] = '1';
|
|
|
|
|
}
|
|
|
|
|
if (word1 & 0x01) {
|
|
|
|
|
grid[((j + 3) * size) + i + 3] = '1';
|
|
|
|
|
}
|
2009-10-21 09:08:44 +00:00
|
|
|
|
}
|
|
|
|
|
|
Add multiple segments support for AZTEC, CODEONE, DATAMATRIX, DOTCODE,
GRIDMATRIX, HANXIN, MAXICODE, MICROPDF417, PDF417, QRCODE, RMQR, ULTRA
RMQR: fix ECI encoding (wrong bit length for indicator)
MICROQR: check versions M1 and M2 for allowed characters so as to give
better error messages
DOTCODE: some small optimizations
common.c: add is_chr(), segs_length(), segs_cpy()
CODEONE/CODE128/DOTCODE/GRIDMATRIX/HANXIN/MAXICODE/QRCODE/ULTRA: add
namespace prefixes to static funcs/data
includes: use Z_ prefix, unuse double underscore prefixes (guard defines)
manual.txt: compress some tables using double/treble column sets
2022-05-09 19:50:50 +01:00
|
|
|
|
static void gm_place_data_in_grid(unsigned char word[], char grid[], int modules, int size) {
|
2016-02-20 09:38:03 +00:00
|
|
|
|
int x, y, macromodule, offset;
|
|
|
|
|
|
|
|
|
|
offset = 13 - ((modules - 1) / 2);
|
|
|
|
|
for (y = 0; y < modules; y++) {
|
|
|
|
|
for (x = 0; x < modules; x++) {
|
|
|
|
|
macromodule = gm_macro_matrix[((y + offset) * 27) + (x + offset)];
|
Add multiple segments support for AZTEC, CODEONE, DATAMATRIX, DOTCODE,
GRIDMATRIX, HANXIN, MAXICODE, MICROPDF417, PDF417, QRCODE, RMQR, ULTRA
RMQR: fix ECI encoding (wrong bit length for indicator)
MICROQR: check versions M1 and M2 for allowed characters so as to give
better error messages
DOTCODE: some small optimizations
common.c: add is_chr(), segs_length(), segs_cpy()
CODEONE/CODE128/DOTCODE/GRIDMATRIX/HANXIN/MAXICODE/QRCODE/ULTRA: add
namespace prefixes to static funcs/data
includes: use Z_ prefix, unuse double underscore prefixes (guard defines)
manual.txt: compress some tables using double/treble column sets
2022-05-09 19:50:50 +01:00
|
|
|
|
gm_place_macromodule(grid, x, y, word[macromodule * 2], word[(macromodule * 2) + 1], size);
|
2016-02-20 09:38:03 +00:00
|
|
|
|
}
|
|
|
|
|
}
|
2009-10-21 09:08:44 +00:00
|
|
|
|
}
|
|
|
|
|
|
2016-02-20 09:38:03 +00:00
|
|
|
|
/* Place the layer ID into each macromodule */
|
Add multiple segments support for AZTEC, CODEONE, DATAMATRIX, DOTCODE,
GRIDMATRIX, HANXIN, MAXICODE, MICROPDF417, PDF417, QRCODE, RMQR, ULTRA
RMQR: fix ECI encoding (wrong bit length for indicator)
MICROQR: check versions M1 and M2 for allowed characters so as to give
better error messages
DOTCODE: some small optimizations
common.c: add is_chr(), segs_length(), segs_cpy()
CODEONE/CODE128/DOTCODE/GRIDMATRIX/HANXIN/MAXICODE/QRCODE/ULTRA: add
namespace prefixes to static funcs/data
includes: use Z_ prefix, unuse double underscore prefixes (guard defines)
manual.txt: compress some tables using double/treble column sets
2022-05-09 19:50:50 +01:00
|
|
|
|
static void gm_place_layer_id(char *grid, int size, int layers, int modules, int ecc_level) {
|
2016-02-20 09:38:03 +00:00
|
|
|
|
int i, j, layer, start, stop;
|
2022-07-14 16:01:30 +01:00
|
|
|
|
int *layerid = (int *) z_alloca(sizeof(int) * (layers + 1));
|
|
|
|
|
int *id = (int *) z_alloca(sizeof(int) * (modules * modules));
|
2009-10-21 09:08:44 +00:00
|
|
|
|
|
2016-02-20 09:38:03 +00:00
|
|
|
|
/* Calculate Layer IDs */
|
|
|
|
|
for (i = 0; i <= layers; i++) {
|
|
|
|
|
if (ecc_level == 1) {
|
|
|
|
|
layerid[i] = 3 - (i % 4);
|
|
|
|
|
} else {
|
|
|
|
|
layerid[i] = (i + 5 - ecc_level) % 4;
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
for (i = 0; i < modules; i++) {
|
|
|
|
|
for (j = 0; j < modules; j++) {
|
|
|
|
|
id[(i * modules) + j] = 0;
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/* Calculate which value goes in each macromodule */
|
|
|
|
|
start = modules / 2;
|
|
|
|
|
stop = modules / 2;
|
|
|
|
|
for (layer = 0; layer <= layers; layer++) {
|
|
|
|
|
for (i = start; i <= stop; i++) {
|
|
|
|
|
id[(start * modules) + i] = layerid[layer];
|
|
|
|
|
id[(i * modules) + start] = layerid[layer];
|
|
|
|
|
id[((modules - start - 1) * modules) + i] = layerid[layer];
|
|
|
|
|
id[(i * modules) + (modules - start - 1)] = layerid[layer];
|
|
|
|
|
}
|
|
|
|
|
start--;
|
|
|
|
|
stop++;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/* Place the data in the grid */
|
|
|
|
|
for (i = 0; i < modules; i++) {
|
|
|
|
|
for (j = 0; j < modules; j++) {
|
|
|
|
|
if (id[(i * modules) + j] & 0x02) {
|
|
|
|
|
grid[(((i * 6) + 1) * size) + (j * 6) + 1] = '1';
|
|
|
|
|
}
|
|
|
|
|
if (id[(i * modules) + j] & 0x01) {
|
|
|
|
|
grid[(((i * 6) + 1) * size) + (j * 6) + 2] = '1';
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|
2009-10-21 09:08:44 +00:00
|
|
|
|
}
|
2009-09-29 09:45:46 +00:00
|
|
|
|
|
Add multiple segments support for AZTEC, CODEONE, DATAMATRIX, DOTCODE,
GRIDMATRIX, HANXIN, MAXICODE, MICROPDF417, PDF417, QRCODE, RMQR, ULTRA
RMQR: fix ECI encoding (wrong bit length for indicator)
MICROQR: check versions M1 and M2 for allowed characters so as to give
better error messages
DOTCODE: some small optimizations
common.c: add is_chr(), segs_length(), segs_cpy()
CODEONE/CODE128/DOTCODE/GRIDMATRIX/HANXIN/MAXICODE/QRCODE/ULTRA: add
namespace prefixes to static funcs/data
includes: use Z_ prefix, unuse double underscore prefixes (guard defines)
manual.txt: compress some tables using double/treble column sets
2022-05-09 19:50:50 +01:00
|
|
|
|
INTERNAL int gridmatrix(struct zint_symbol *symbol, struct zint_seg segs[], const int seg_count) {
|
2022-04-10 11:12:18 +01:00
|
|
|
|
int warn_number = 0;
|
2017-09-10 12:03:09 -03:00
|
|
|
|
int size, modules, error_number;
|
2016-02-20 09:38:03 +00:00
|
|
|
|
int auto_layers, min_layers, layers, auto_ecc_level, min_ecc_level, ecc_level;
|
2017-09-10 12:03:09 -03:00
|
|
|
|
int x, y, i;
|
2020-04-02 14:41:13 +01:00
|
|
|
|
int full_multibyte;
|
2016-02-20 09:38:03 +00:00
|
|
|
|
char binary[9300];
|
|
|
|
|
int data_cw, input_latch = 0;
|
2020-11-27 12:54:44 +00:00
|
|
|
|
unsigned char word[1460] = {0};
|
2019-12-16 17:31:52 +00:00
|
|
|
|
int data_max, reader = 0;
|
Add Structured Append support for AZTEC, CODEONE, DATAMATRIX, DOTCODE,
GRIDMATRIX, MAXICODE, MICROPDF417, PDF417, QRCODE, ULTRA
DOTCODE: use pre-calculated generator poly coeffs in Reed-Solomon for
performance improvement
PDF417/MICROPDF417: use common routine pdf417_initial()
GUI: code lines <= 118, shorthand widget_obj(),
shorten calling upcean_addon_gap(), upcean_guard_descent()
various backend: var name debug -> debug_print
2021-09-28 21:42:44 +01:00
|
|
|
|
const struct zint_structapp *p_structapp = NULL;
|
2020-11-27 12:54:44 +00:00
|
|
|
|
int size_squared;
|
|
|
|
|
int bin_len;
|
Add multiple segments support for AZTEC, CODEONE, DATAMATRIX, DOTCODE,
GRIDMATRIX, HANXIN, MAXICODE, MICROPDF417, PDF417, QRCODE, RMQR, ULTRA
RMQR: fix ECI encoding (wrong bit length for indicator)
MICROQR: check versions M1 and M2 for allowed characters so as to give
better error messages
DOTCODE: some small optimizations
common.c: add is_chr(), segs_length(), segs_cpy()
CODEONE/CODE128/DOTCODE/GRIDMATRIX/HANXIN/MAXICODE/QRCODE/ULTRA: add
namespace prefixes to static funcs/data
includes: use Z_ prefix, unuse double underscore prefixes (guard defines)
manual.txt: compress some tables using double/treble column sets
2022-05-09 19:50:50 +01:00
|
|
|
|
const int debug_print = symbol->debug & ZINT_DEBUG_PRINT;
|
|
|
|
|
const int eci_length_segs = get_eci_length_segs(segs, seg_count);
|
2022-07-14 16:01:30 +01:00
|
|
|
|
struct zint_seg *local_segs = (struct zint_seg *) z_alloca(sizeof(struct zint_seg) * seg_count);
|
|
|
|
|
unsigned int *ddata = (unsigned int *) z_alloca(sizeof(unsigned int) * eci_length_segs);
|
2021-01-11 18:11:41 +00:00
|
|
|
|
char *grid;
|
2009-10-21 09:08:44 +00:00
|
|
|
|
|
2022-05-19 10:17:51 +01:00
|
|
|
|
segs_cpy(symbol, segs, seg_count, local_segs); /* Shallow copy (needed to set default ECIs & protect lengths) */
|
Add multiple segments support for AZTEC, CODEONE, DATAMATRIX, DOTCODE,
GRIDMATRIX, HANXIN, MAXICODE, MICROPDF417, PDF417, QRCODE, RMQR, ULTRA
RMQR: fix ECI encoding (wrong bit length for indicator)
MICROQR: check versions M1 and M2 for allowed characters so as to give
better error messages
DOTCODE: some small optimizations
common.c: add is_chr(), segs_length(), segs_cpy()
CODEONE/CODE128/DOTCODE/GRIDMATRIX/HANXIN/MAXICODE/QRCODE/ULTRA: add
namespace prefixes to static funcs/data
includes: use Z_ prefix, unuse double underscore prefixes (guard defines)
manual.txt: compress some tables using double/treble column sets
2022-05-09 19:50:50 +01:00
|
|
|
|
|
2021-01-11 18:11:41 +00:00
|
|
|
|
/* If ZINT_FULL_MULTIBYTE set use Hanzi mode in DATA_MODE or for non-GB 2312 in UNICODE_MODE */
|
2020-11-27 12:54:44 +00:00
|
|
|
|
full_multibyte = (symbol->option_3 & 0xFF) == ZINT_FULL_MULTIBYTE;
|
2020-04-02 14:41:13 +01:00
|
|
|
|
|
2019-11-28 19:15:29 +00:00
|
|
|
|
if ((symbol->input_mode & 0x07) == DATA_MODE) {
|
Add multiple segments support for AZTEC, CODEONE, DATAMATRIX, DOTCODE,
GRIDMATRIX, HANXIN, MAXICODE, MICROPDF417, PDF417, QRCODE, RMQR, ULTRA
RMQR: fix ECI encoding (wrong bit length for indicator)
MICROQR: check versions M1 and M2 for allowed characters so as to give
better error messages
DOTCODE: some small optimizations
common.c: add is_chr(), segs_length(), segs_cpy()
CODEONE/CODE128/DOTCODE/GRIDMATRIX/HANXIN/MAXICODE/QRCODE/ULTRA: add
namespace prefixes to static funcs/data
includes: use Z_ prefix, unuse double underscore prefixes (guard defines)
manual.txt: compress some tables using double/treble column sets
2022-05-09 19:50:50 +01:00
|
|
|
|
gb2312_cpy_segs(local_segs, seg_count, ddata, full_multibyte);
|
2016-08-16 12:43:41 +01:00
|
|
|
|
} else {
|
Add multiple segments support for AZTEC, CODEONE, DATAMATRIX, DOTCODE,
GRIDMATRIX, HANXIN, MAXICODE, MICROPDF417, PDF417, QRCODE, RMQR, ULTRA
RMQR: fix ECI encoding (wrong bit length for indicator)
MICROQR: check versions M1 and M2 for allowed characters so as to give
better error messages
DOTCODE: some small optimizations
common.c: add is_chr(), segs_length(), segs_cpy()
CODEONE/CODE128/DOTCODE/GRIDMATRIX/HANXIN/MAXICODE/QRCODE/ULTRA: add
namespace prefixes to static funcs/data
includes: use Z_ prefix, unuse double underscore prefixes (guard defines)
manual.txt: compress some tables using double/treble column sets
2022-05-09 19:50:50 +01:00
|
|
|
|
unsigned int *dd = ddata;
|
|
|
|
|
for (i = 0; i < seg_count; i++) {
|
|
|
|
|
int done = 0;
|
2022-05-19 10:17:51 +01:00
|
|
|
|
if (local_segs[i].eci != 0 && local_segs[i].eci != 29) { /* Unless default or ECI 29 (GB 2312) */
|
|
|
|
|
/* Try other conversions */
|
Add multiple segments support for AZTEC, CODEONE, DATAMATRIX, DOTCODE,
GRIDMATRIX, HANXIN, MAXICODE, MICROPDF417, PDF417, QRCODE, RMQR, ULTRA
RMQR: fix ECI encoding (wrong bit length for indicator)
MICROQR: check versions M1 and M2 for allowed characters so as to give
better error messages
DOTCODE: some small optimizations
common.c: add is_chr(), segs_length(), segs_cpy()
CODEONE/CODE128/DOTCODE/GRIDMATRIX/HANXIN/MAXICODE/QRCODE/ULTRA: add
namespace prefixes to static funcs/data
includes: use Z_ prefix, unuse double underscore prefixes (guard defines)
manual.txt: compress some tables using double/treble column sets
2022-05-09 19:50:50 +01:00
|
|
|
|
error_number = gb2312_utf8_to_eci(local_segs[i].eci, local_segs[i].source, &local_segs[i].length,
|
|
|
|
|
dd, full_multibyte);
|
|
|
|
|
if (error_number == 0) {
|
|
|
|
|
done = 1;
|
2022-05-19 10:17:51 +01:00
|
|
|
|
} else {
|
Add multiple segments support for AZTEC, CODEONE, DATAMATRIX, DOTCODE,
GRIDMATRIX, HANXIN, MAXICODE, MICROPDF417, PDF417, QRCODE, RMQR, ULTRA
RMQR: fix ECI encoding (wrong bit length for indicator)
MICROQR: check versions M1 and M2 for allowed characters so as to give
better error messages
DOTCODE: some small optimizations
common.c: add is_chr(), segs_length(), segs_cpy()
CODEONE/CODE128/DOTCODE/GRIDMATRIX/HANXIN/MAXICODE/QRCODE/ULTRA: add
namespace prefixes to static funcs/data
includes: use Z_ prefix, unuse double underscore prefixes (guard defines)
manual.txt: compress some tables using double/treble column sets
2022-05-09 19:50:50 +01:00
|
|
|
|
sprintf(symbol->errtxt, "535: Invalid character in input data for ECI %d", local_segs[i].eci);
|
|
|
|
|
return error_number;
|
|
|
|
|
}
|
2016-02-20 09:38:03 +00:00
|
|
|
|
}
|
Add multiple segments support for AZTEC, CODEONE, DATAMATRIX, DOTCODE,
GRIDMATRIX, HANXIN, MAXICODE, MICROPDF417, PDF417, QRCODE, RMQR, ULTRA
RMQR: fix ECI encoding (wrong bit length for indicator)
MICROQR: check versions M1 and M2 for allowed characters so as to give
better error messages
DOTCODE: some small optimizations
common.c: add is_chr(), segs_length(), segs_cpy()
CODEONE/CODE128/DOTCODE/GRIDMATRIX/HANXIN/MAXICODE/QRCODE/ULTRA: add
namespace prefixes to static funcs/data
includes: use Z_ prefix, unuse double underscore prefixes (guard defines)
manual.txt: compress some tables using double/treble column sets
2022-05-09 19:50:50 +01:00
|
|
|
|
if (!done) {
|
|
|
|
|
/* Try GB 2312 (EUC-CN) */
|
|
|
|
|
error_number = gb2312_utf8(symbol, local_segs[i].source, &local_segs[i].length, dd);
|
|
|
|
|
if (error_number != 0) {
|
|
|
|
|
return error_number;
|
|
|
|
|
}
|
2022-04-10 11:12:18 +01:00
|
|
|
|
}
|
Add multiple segments support for AZTEC, CODEONE, DATAMATRIX, DOTCODE,
GRIDMATRIX, HANXIN, MAXICODE, MICROPDF417, PDF417, QRCODE, RMQR, ULTRA
RMQR: fix ECI encoding (wrong bit length for indicator)
MICROQR: check versions M1 and M2 for allowed characters so as to give
better error messages
DOTCODE: some small optimizations
common.c: add is_chr(), segs_length(), segs_cpy()
CODEONE/CODE128/DOTCODE/GRIDMATRIX/HANXIN/MAXICODE/QRCODE/ULTRA: add
namespace prefixes to static funcs/data
includes: use Z_ prefix, unuse double underscore prefixes (guard defines)
manual.txt: compress some tables using double/treble column sets
2022-05-09 19:50:50 +01:00
|
|
|
|
dd += local_segs[i].length;
|
2016-08-16 12:43:41 +01:00
|
|
|
|
}
|
2016-02-20 09:38:03 +00:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
if (symbol->output_options & READER_INIT) reader = 1;
|
2017-10-23 21:37:52 +02:00
|
|
|
|
|
Add Structured Append support for AZTEC, CODEONE, DATAMATRIX, DOTCODE,
GRIDMATRIX, MAXICODE, MICROPDF417, PDF417, QRCODE, ULTRA
DOTCODE: use pre-calculated generator poly coeffs in Reed-Solomon for
performance improvement
PDF417/MICROPDF417: use common routine pdf417_initial()
GUI: code lines <= 118, shorthand widget_obj(),
shorten calling upcean_addon_gap(), upcean_guard_descent()
various backend: var name debug -> debug_print
2021-09-28 21:42:44 +01:00
|
|
|
|
if (symbol->structapp.count) {
|
|
|
|
|
if (symbol->structapp.count < 2 || symbol->structapp.count > 16) {
|
|
|
|
|
strcpy(symbol->errtxt, "536: Structured Append count out of range (2-16)");
|
|
|
|
|
return ZINT_ERROR_INVALID_OPTION;
|
|
|
|
|
}
|
|
|
|
|
if (symbol->structapp.index < 1 || symbol->structapp.index > symbol->structapp.count) {
|
|
|
|
|
sprintf(symbol->errtxt, "537: Structured Append index out of range (1-%d)", symbol->structapp.count);
|
|
|
|
|
return ZINT_ERROR_INVALID_OPTION;
|
|
|
|
|
}
|
|
|
|
|
if (symbol->structapp.id[0]) {
|
|
|
|
|
int id, id_len;
|
|
|
|
|
|
- API: add new zint_symbol `dpmm` field for output resolution (BMP/
EMF/PCX/PNG/TIF only, i.e. excluding EPS, GIF & SVG)
- Add support for specifying scale by X-dimension and resolution
with new option `--scalexdimdp` for CLI/Tcl & new API function
`ZBarcode_Scale_From_XdimDp()` (+ `ZBarcode_XdimDp_From_Scale()`
& `ZBarcode_Default_Xdim()`) and new GUI popup; manual: document
- BMP/EMF/PCX/PNG/TIF: use new `dpmm` resolution field (for EMF
following Inkscape)
- backend_qt: add `dpmm()`, `vectorWidth()`, `vectorHeight()`,
`noPng()`, `getVersion()`, `takesGS1AIData()`, & `XdimDp` stuff
incl. new `QZintXdimDp` struct for passing around scale vars &
use in `getAsCLI()`; add comments
- Raise `scale` limit to 200 (from 100) to allow for large dpmm
- output: create directories & subdirectories as necessary for
output path using new function `out_fopen()` and use in BMP/EMF/
EPS/GIF/PCX/PNG/SVG/TIF
- DPLEIT/DPIDENT: format HRT according to (incomplete)
documentation, and set default height to 72X (from 50X)
- CODE128B renamed to CODE128AB as can use subsets A and/or B
- CODABAR: fix minimum height calc
- EMF: fix indexing of handles (zero-based not 1-based)
- GUI: fix symbology zap (previous technique of clearing and
re-loading settings without doing a sync no longer works);
fix UPCEAN guard descent enable
- MAILMARK: better error message if input < 14 characters
- GUI: add "Default" button for DAFT tracker ratio & enable/disable
various default buttons; use new `takesGS1AIData()` to
enable/disable GS1-specific checkboxes
- CLI: use new `validate_float()` to parse float options (7
significant digits allowed only, no scientific notation)
- DATAMATRIX/GRIDMATRIX/PDF417/QR/ULTRA: micro-optimize structapp
ID parse
- library/CLI: fiddle with static asserts (make CHAR_BIT sensitive,
supposedly)
- win32/README: update building libpng (assembly removed)
- README.linux: document incompatibility of Qt6 >= 6.3
- manual: expand Barcode Studio waffle
- test suite: change range separator to hyphen and allow multiple
excludes
2022-12-02 21:39:01 +00:00
|
|
|
|
for (id_len = 1; id_len < 4 && symbol->structapp.id[id_len]; id_len++);
|
Add Structured Append support for AZTEC, CODEONE, DATAMATRIX, DOTCODE,
GRIDMATRIX, MAXICODE, MICROPDF417, PDF417, QRCODE, ULTRA
DOTCODE: use pre-calculated generator poly coeffs in Reed-Solomon for
performance improvement
PDF417/MICROPDF417: use common routine pdf417_initial()
GUI: code lines <= 118, shorthand widget_obj(),
shorten calling upcean_addon_gap(), upcean_guard_descent()
various backend: var name debug -> debug_print
2021-09-28 21:42:44 +01:00
|
|
|
|
|
|
|
|
|
if (id_len > 3) { /* 255 (8 bits) */
|
|
|
|
|
strcpy(symbol->errtxt, "538: Structured Append ID too long (3 digit maximum)");
|
|
|
|
|
return ZINT_ERROR_INVALID_OPTION;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
id = to_int((const unsigned char *) symbol->structapp.id, id_len);
|
|
|
|
|
if (id == -1) {
|
|
|
|
|
strcpy(symbol->errtxt, "539: Invalid Structured Append ID (digits only)");
|
|
|
|
|
return ZINT_ERROR_INVALID_OPTION;
|
|
|
|
|
}
|
|
|
|
|
if (id > 255) {
|
|
|
|
|
sprintf(symbol->errtxt, "530: Structured Append ID '%d' out of range (0-255)", id);
|
|
|
|
|
return ZINT_ERROR_INVALID_OPTION;
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
p_structapp = &symbol->structapp;
|
|
|
|
|
}
|
|
|
|
|
|
2017-07-23 17:59:51 +01:00
|
|
|
|
if (symbol->eci > 811799) {
|
2017-07-27 16:01:53 +01:00
|
|
|
|
strcpy(symbol->errtxt, "533: Invalid ECI");
|
2017-07-23 17:59:51 +01:00
|
|
|
|
return ZINT_ERROR_INVALID_OPTION;
|
|
|
|
|
}
|
2016-02-20 09:38:03 +00:00
|
|
|
|
|
Add multiple segments support for AZTEC, CODEONE, DATAMATRIX, DOTCODE,
GRIDMATRIX, HANXIN, MAXICODE, MICROPDF417, PDF417, QRCODE, RMQR, ULTRA
RMQR: fix ECI encoding (wrong bit length for indicator)
MICROQR: check versions M1 and M2 for allowed characters so as to give
better error messages
DOTCODE: some small optimizations
common.c: add is_chr(), segs_length(), segs_cpy()
CODEONE/CODE128/DOTCODE/GRIDMATRIX/HANXIN/MAXICODE/QRCODE/ULTRA: add
namespace prefixes to static funcs/data
includes: use Z_ prefix, unuse double underscore prefixes (guard defines)
manual.txt: compress some tables using double/treble column sets
2022-05-09 19:50:50 +01:00
|
|
|
|
error_number = gm_encode_segs(ddata, local_segs, seg_count, binary, reader, p_structapp, &bin_len, debug_print);
|
2016-02-20 09:38:03 +00:00
|
|
|
|
if (error_number != 0) {
|
2017-07-27 16:01:53 +01:00
|
|
|
|
strcpy(symbol->errtxt, "531: Input data too long");
|
2016-02-20 09:38:03 +00:00
|
|
|
|
return error_number;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/* Determine the size of the symbol */
|
2020-11-27 12:54:44 +00:00
|
|
|
|
data_cw = bin_len / 7; /* Binary length always a multiple of 7 */
|
2016-02-20 09:38:03 +00:00
|
|
|
|
|
|
|
|
|
auto_layers = 13;
|
|
|
|
|
for (i = 12; i > 0; i--) {
|
|
|
|
|
if (gm_recommend_cw[(i - 1)] >= data_cw) {
|
|
|
|
|
auto_layers = i;
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
min_layers = 13;
|
|
|
|
|
for (i = 12; i > 0; i--) {
|
|
|
|
|
if (gm_max_cw[(i - 1)] >= data_cw) {
|
|
|
|
|
min_layers = i;
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
layers = auto_layers;
|
2019-12-04 13:45:01 +00:00
|
|
|
|
|
|
|
|
|
if ((symbol->option_2 >= 1) && (symbol->option_2 <= 13)) {
|
|
|
|
|
input_latch = 1;
|
|
|
|
|
if (symbol->option_2 >= min_layers) {
|
|
|
|
|
layers = symbol->option_2;
|
|
|
|
|
} else {
|
|
|
|
|
strcpy(symbol->errtxt, "534: Input data too long for selected symbol size");
|
|
|
|
|
return ZINT_ERROR_TOO_LONG;
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
2016-02-20 09:38:03 +00:00
|
|
|
|
auto_ecc_level = 3;
|
|
|
|
|
if (layers == 1) {
|
|
|
|
|
auto_ecc_level = 5;
|
2020-11-27 12:54:44 +00:00
|
|
|
|
} else if ((layers == 2) || (layers == 3)) {
|
2016-02-20 09:38:03 +00:00
|
|
|
|
auto_ecc_level = 4;
|
|
|
|
|
}
|
2019-12-04 13:45:01 +00:00
|
|
|
|
ecc_level = auto_ecc_level;
|
|
|
|
|
|
2016-02-20 09:38:03 +00:00
|
|
|
|
min_ecc_level = 1;
|
|
|
|
|
if (layers == 1) {
|
|
|
|
|
min_ecc_level = 4;
|
2020-11-27 12:54:44 +00:00
|
|
|
|
} else if (layers == 2) {
|
2016-02-20 09:38:03 +00:00
|
|
|
|
min_ecc_level = 2;
|
|
|
|
|
}
|
|
|
|
|
|
2019-12-04 13:45:01 +00:00
|
|
|
|
if ((symbol->option_1 >= 1) && (symbol->option_1 <= 5)) {
|
|
|
|
|
if (symbol->option_1 >= min_ecc_level) {
|
|
|
|
|
ecc_level = symbol->option_1;
|
2016-02-20 09:38:03 +00:00
|
|
|
|
} else {
|
2019-12-04 13:45:01 +00:00
|
|
|
|
ecc_level = min_ecc_level;
|
2016-02-20 09:38:03 +00:00
|
|
|
|
}
|
|
|
|
|
}
|
2019-12-04 13:45:01 +00:00
|
|
|
|
if (data_cw > gm_data_codewords[(5 * (layers - 1)) + (ecc_level - 1)]) {
|
2020-11-27 12:54:44 +00:00
|
|
|
|
/* If layers user-specified (option_2), try reducing ECC level first */
|
|
|
|
|
if (input_latch && ecc_level > min_ecc_level) {
|
2019-12-04 13:45:01 +00:00
|
|
|
|
do {
|
|
|
|
|
ecc_level--;
|
2021-06-19 13:11:23 +01:00
|
|
|
|
} while ((data_cw > gm_data_codewords[(5 * (layers - 1)) + (ecc_level - 1)])
|
|
|
|
|
&& (ecc_level > min_ecc_level));
|
2016-02-20 09:38:03 +00:00
|
|
|
|
}
|
2019-12-04 13:45:01 +00:00
|
|
|
|
while (data_cw > gm_data_codewords[(5 * (layers - 1)) + (ecc_level - 1)] && (layers < 13)) {
|
2016-02-20 09:38:03 +00:00
|
|
|
|
layers++;
|
|
|
|
|
}
|
2020-11-27 12:54:44 +00:00
|
|
|
|
/* ECC min level 1 for layers > 2 */
|
|
|
|
|
while (data_cw > gm_data_codewords[(5 * (layers - 1)) + (ecc_level - 1)] && ecc_level > 1) {
|
2019-12-04 13:45:01 +00:00
|
|
|
|
ecc_level--;
|
2016-02-20 09:38:03 +00:00
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
data_max = 1313;
|
|
|
|
|
switch (ecc_level) {
|
|
|
|
|
case 2: data_max = 1167;
|
|
|
|
|
break;
|
|
|
|
|
case 3: data_max = 1021;
|
|
|
|
|
break;
|
|
|
|
|
case 4: data_max = 875;
|
|
|
|
|
break;
|
|
|
|
|
case 5: data_max = 729;
|
|
|
|
|
break;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
if (data_cw > data_max) {
|
2017-07-27 16:01:53 +01:00
|
|
|
|
strcpy(symbol->errtxt, "532: Input data too long");
|
2016-02-20 09:38:03 +00:00
|
|
|
|
return ZINT_ERROR_TOO_LONG;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
gm_add_ecc(binary, data_cw, layers, ecc_level, word);
|
2019-12-19 00:37:55 +00:00
|
|
|
|
#ifdef ZINT_TEST
|
2019-12-16 17:31:52 +00:00
|
|
|
|
if (symbol->debug & ZINT_DEBUG_TEST) debug_test_codeword_dump(symbol, word, data_cw);
|
2019-12-19 00:37:55 +00:00
|
|
|
|
#endif
|
2016-02-20 09:38:03 +00:00
|
|
|
|
size = 6 + (layers * 12);
|
|
|
|
|
modules = 1 + (layers * 2);
|
2020-11-27 12:54:44 +00:00
|
|
|
|
size_squared = size * size;
|
2016-02-20 09:38:03 +00:00
|
|
|
|
|
2022-07-14 16:01:30 +01:00
|
|
|
|
grid = (char *) z_alloca(size_squared);
|
2020-11-27 12:54:44 +00:00
|
|
|
|
memset(grid, '0', size_squared);
|
2016-02-20 09:38:03 +00:00
|
|
|
|
|
Add multiple segments support for AZTEC, CODEONE, DATAMATRIX, DOTCODE,
GRIDMATRIX, HANXIN, MAXICODE, MICROPDF417, PDF417, QRCODE, RMQR, ULTRA
RMQR: fix ECI encoding (wrong bit length for indicator)
MICROQR: check versions M1 and M2 for allowed characters so as to give
better error messages
DOTCODE: some small optimizations
common.c: add is_chr(), segs_length(), segs_cpy()
CODEONE/CODE128/DOTCODE/GRIDMATRIX/HANXIN/MAXICODE/QRCODE/ULTRA: add
namespace prefixes to static funcs/data
includes: use Z_ prefix, unuse double underscore prefixes (guard defines)
manual.txt: compress some tables using double/treble column sets
2022-05-09 19:50:50 +01:00
|
|
|
|
gm_place_data_in_grid(word, grid, modules, size);
|
|
|
|
|
gm_place_layer_id(grid, size, layers, modules, ecc_level);
|
2016-02-20 09:38:03 +00:00
|
|
|
|
|
|
|
|
|
/* Add macromodule frames */
|
|
|
|
|
for (x = 0; x < modules; x++) {
|
2017-09-10 12:03:09 -03:00
|
|
|
|
int dark = 1 - (x & 1);
|
2016-02-20 09:38:03 +00:00
|
|
|
|
for (y = 0; y < modules; y++) {
|
|
|
|
|
if (dark == 1) {
|
|
|
|
|
for (i = 0; i < 5; i++) {
|
|
|
|
|
grid[((y * 6) * size) + (x * 6) + i] = '1';
|
|
|
|
|
grid[(((y * 6) + 5) * size) + (x * 6) + i] = '1';
|
|
|
|
|
grid[(((y * 6) + i) * size) + (x * 6)] = '1';
|
|
|
|
|
grid[(((y * 6) + i) * size) + (x * 6) + 5] = '1';
|
|
|
|
|
}
|
|
|
|
|
grid[(((y * 6) + 5) * size) + (x * 6) + 5] = '1';
|
|
|
|
|
dark = 0;
|
|
|
|
|
} else {
|
|
|
|
|
dark = 1;
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/* Copy values to symbol */
|
|
|
|
|
symbol->width = size;
|
|
|
|
|
symbol->rows = size;
|
|
|
|
|
|
|
|
|
|
for (x = 0; x < size; x++) {
|
|
|
|
|
for (y = 0; y < size; y++) {
|
|
|
|
|
if (grid[(y * size) + x] == '1') {
|
|
|
|
|
set_module(symbol, y, x);
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
symbol->row_height[x] = 1;
|
|
|
|
|
}
|
2021-06-19 13:11:23 +01:00
|
|
|
|
symbol->height = size;
|
2016-02-20 09:38:03 +00:00
|
|
|
|
|
2022-04-10 11:12:18 +01:00
|
|
|
|
return warn_number;
|
2009-10-21 09:08:44 +00:00
|
|
|
|
}
|
2022-04-10 11:12:18 +01:00
|
|
|
|
|
|
|
|
|
/* vim: set ts=4 sw=4 et : */
|