/* * GS1 AI checker generated by "backend/tools/gen_gs1_lint.php" from * https://raw.githubusercontent.com/gs1/gs1-syntax-dictionary/main/gs1-syntax-dictionary.txt */ /* libzint - the open source barcode library Copyright (C) 2021-2024 Robin Stuart Redistribution and use in source and binary forms, with or without modification, are permitted provided that the following conditions are met: 1. Redistributions of source code must retain the above copyright notice, this list of conditions and the following disclaimer. 2. Redistributions in binary form must reproduce the above copyright notice, this list of conditions and the following disclaimer in the documentation and/or other materials provided with the distribution. 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 without specific prior written permission. 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 OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. */ /* SPDX-License-Identifier: BSD-3-Clause */ #ifndef Z_GS1_LINT_H #define Z_GS1_LINT_H /* N18,csum,key (Used by SSCC, GSRN - PROVIDER, GSRN - RECIPIENT) */ static int n18_csum_key(const unsigned char *data, const int data_len, int *p_err_no, int *p_err_posn, char err_msg[50]) { return data_len == 18 && csum(data, data_len, 0, 18, 18, p_err_no, p_err_posn, err_msg, 1 /*length_only*/) && key(data, data_len, 0, 18, 18, p_err_no, p_err_posn, err_msg, 1 /*length_only*/) && numeric(data, data_len, 0, 18, 18, p_err_no, p_err_posn, err_msg) && csum(data, data_len, 0, 18, 18, p_err_no, p_err_posn, err_msg, 0) && key(data, data_len, 0, 18, 18, p_err_no, p_err_posn, err_msg, 0); } /* N14,csum,key (Used by GTIN, CONTENT, MTO GTIN) */ static int n14_csum_key(const unsigned char *data, const int data_len, int *p_err_no, int *p_err_posn, char err_msg[50]) { return data_len == 14 && csum(data, data_len, 0, 14, 14, p_err_no, p_err_posn, err_msg, 1 /*length_only*/) && key(data, data_len, 0, 14, 14, p_err_no, p_err_posn, err_msg, 1 /*length_only*/) && numeric(data, data_len, 0, 14, 14, p_err_no, p_err_posn, err_msg) && csum(data, data_len, 0, 14, 14, p_err_no, p_err_posn, err_msg, 0) && key(data, data_len, 0, 14, 14, p_err_no, p_err_posn, err_msg, 0); } /* X..20 (Used by BATCH/LOT, SERIAL, CPV, PCN, GLN EXTENSION COMPONENT, SHIP TO POST, RTN TO POST, REFURB LOT, ...) */ static int x__20(const unsigned char *data, const int data_len, int *p_err_no, int *p_err_posn, char err_msg[50]) { return data_len >= 1 && data_len <= 20 && cset82(data, data_len, 0, 1, 20, p_err_no, p_err_posn, err_msg); } /* N6,yymmd0 (Used by PROD DATE, DUE DATE, PACK DATE, BEST BEFORE or BEST BY, SELL BY, USE BY or EXPIRY) */ static int n6_yymmd0(const unsigned char *data, const int data_len, int *p_err_no, int *p_err_posn, char err_msg[50]) { return data_len == 6 && yymmd0(data, data_len, 0, 6, 6, p_err_no, p_err_posn, err_msg, 1 /*length_only*/) && numeric(data, data_len, 0, 6, 6, p_err_no, p_err_posn, err_msg) && yymmd0(data, data_len, 0, 6, 6, p_err_no, p_err_posn, err_msg, 0); } /* N2 (Used by VARIANT) */ static int n2(const unsigned char *data, const int data_len, int *p_err_no, int *p_err_posn, char err_msg[50]) { return data_len == 2 && numeric(data, data_len, 0, 2, 2, p_err_no, p_err_posn, err_msg); } /* X..28 (Used by TPX) */ static int x__28(const unsigned char *data, const int data_len, int *p_err_no, int *p_err_posn, char err_msg[50]) { return data_len >= 1 && data_len <= 28 && cset82(data, data_len, 0, 1, 28, p_err_no, p_err_posn, err_msg); } /* X..30 (Used by ADDITIONAL ID, CUST. PART No., SECONDARY SERIAL, REF. TO SOURCE, ORDER NUMBER, ROUTE, SHIP TO...) */ static int x__30(const unsigned char *data, const int data_len, int *p_err_no, int *p_err_posn, char err_msg[50]) { return data_len >= 1 && data_len <= 30 && cset82(data, data_len, 0, 1, 30, p_err_no, p_err_posn, err_msg); } /* N..6 (Used by MTO VARIANT) */ static int n__6(const unsigned char *data, const int data_len, int *p_err_no, int *p_err_posn, char err_msg[50]) { return data_len >= 1 && data_len <= 6 && numeric(data, data_len, 0, 1, 6, p_err_no, p_err_posn, err_msg); } /* N13,csum,key [X..17] (Used by GDTI) */ static int n13_csum_key__x__17_(const unsigned char *data, const int data_len, int *p_err_no, int *p_err_posn, char err_msg[50]) { return data_len >= 13 && data_len <= 30 && csum(data, data_len, 0, 13, 13, p_err_no, p_err_posn, err_msg, 1 /*length_only*/) && key(data, data_len, 0, 13, 13, p_err_no, p_err_posn, err_msg, 1 /*length_only*/) && numeric(data, data_len, 0, 13, 13, p_err_no, p_err_posn, err_msg) && csum(data, data_len, 0, 13, 13, p_err_no, p_err_posn, err_msg, 0) && key(data, data_len, 0, 13, 13, p_err_no, p_err_posn, err_msg, 0) && cset82(data, data_len, 13, 0, 17, p_err_no, p_err_posn, err_msg); } /* N13,csum,key [N..12] (Used by GCN) */ static int n13_csum_key__n__12_(const unsigned char *data, const int data_len, int *p_err_no, int *p_err_posn, char err_msg[50]) { return data_len >= 13 && data_len <= 25 && csum(data, data_len, 0, 13, 13, p_err_no, p_err_posn, err_msg, 1 /*length_only*/) && key(data, data_len, 0, 13, 13, p_err_no, p_err_posn, err_msg, 1 /*length_only*/) && numeric(data, data_len, 0, 13, 13, p_err_no, p_err_posn, err_msg) && csum(data, data_len, 0, 13, 13, p_err_no, p_err_posn, err_msg, 0) && key(data, data_len, 0, 13, 13, p_err_no, p_err_posn, err_msg, 0) && numeric(data, data_len, 13, 0, 12, p_err_no, p_err_posn, err_msg); } /* N..8 (Used by VAR. COUNT, COUNT) */ static int n__8(const unsigned char *data, const int data_len, int *p_err_no, int *p_err_posn, char err_msg[50]) { return data_len >= 1 && data_len <= 8 && numeric(data, data_len, 0, 1, 8, p_err_no, p_err_posn, err_msg); } /* N6 (Used by NET WEIGHT (kg), LENGTH (m), WIDTH (m), HEIGHT (m), AREA (m²), NET VOLUME (l), NET VOLUME (m³)...) */ static int n6(const unsigned char *data, const int data_len, int *p_err_no, int *p_err_posn, char err_msg[50]) { return data_len == 6 && numeric(data, data_len, 0, 6, 6, p_err_no, p_err_posn, err_msg); } /* N..15 (Used by AMOUNT, PRICE) */ static int n__15(const unsigned char *data, const int data_len, int *p_err_no, int *p_err_posn, char err_msg[50]) { return data_len >= 1 && data_len <= 15 && numeric(data, data_len, 0, 1, 15, p_err_no, p_err_posn, err_msg); } /* N3,iso4217 N..15 (Used by AMOUNT, PRICE) */ static int n3_iso4217_n__15(const unsigned char *data, const int data_len, int *p_err_no, int *p_err_posn, char err_msg[50]) { return data_len >= 4 && data_len <= 18 && iso4217(data, data_len, 0, 3, 3, p_err_no, p_err_posn, err_msg, 1 /*length_only*/) && numeric(data, data_len, 0, 3, 3, p_err_no, p_err_posn, err_msg) && iso4217(data, data_len, 0, 3, 3, p_err_no, p_err_posn, err_msg, 0) && numeric(data, data_len, 3, 1, 15, p_err_no, p_err_posn, err_msg); } /* N4 (Used by PRCNT OFF, POINTS) */ static int n4(const unsigned char *data, const int data_len, int *p_err_no, int *p_err_posn, char err_msg[50]) { return data_len == 4 && numeric(data, data_len, 0, 4, 4, p_err_no, p_err_posn, err_msg); } /* X..30,key (Used by GINC, GIAI - ASSEMBLY, GIAI) */ static int x__30_key(const unsigned char *data, const int data_len, int *p_err_no, int *p_err_posn, char err_msg[50]) { return data_len >= 1 && data_len <= 30 && key(data, data_len, 0, 1, 30, p_err_no, p_err_posn, err_msg, 1 /*length_only*/) && cset82(data, data_len, 0, 1, 30, p_err_no, p_err_posn, err_msg) && key(data, data_len, 0, 1, 30, p_err_no, p_err_posn, err_msg, 0); } /* N17,csum,key (Used by GSIN) */ static int n17_csum_key(const unsigned char *data, const int data_len, int *p_err_no, int *p_err_posn, char err_msg[50]) { return data_len == 17 && csum(data, data_len, 0, 17, 17, p_err_no, p_err_posn, err_msg, 1 /*length_only*/) && key(data, data_len, 0, 17, 17, p_err_no, p_err_posn, err_msg, 1 /*length_only*/) && numeric(data, data_len, 0, 17, 17, p_err_no, p_err_posn, err_msg) && csum(data, data_len, 0, 17, 17, p_err_no, p_err_posn, err_msg, 0) && key(data, data_len, 0, 17, 17, p_err_no, p_err_posn, err_msg, 0); } /* N13,csum,key (Used by SHIP TO LOC, BILL TO, PURCHASE FROM, SHIP FOR LOC, LOC No., PAY TO, PROD/SERV LOC, PARTY) */ static int n13_csum_key(const unsigned char *data, const int data_len, int *p_err_no, int *p_err_posn, char err_msg[50]) { return data_len == 13 && csum(data, data_len, 0, 13, 13, p_err_no, p_err_posn, err_msg, 1 /*length_only*/) && key(data, data_len, 0, 13, 13, p_err_no, p_err_posn, err_msg, 1 /*length_only*/) && numeric(data, data_len, 0, 13, 13, p_err_no, p_err_posn, err_msg) && csum(data, data_len, 0, 13, 13, p_err_no, p_err_posn, err_msg, 0) && key(data, data_len, 0, 13, 13, p_err_no, p_err_posn, err_msg, 0); } /* N3,iso3166 X..9 (Used by SHIP TO POST) */ static int n3_iso3166_x__9(const unsigned char *data, const int data_len, int *p_err_no, int *p_err_posn, char err_msg[50]) { return data_len >= 4 && data_len <= 12 && iso3166(data, data_len, 0, 3, 3, p_err_no, p_err_posn, err_msg, 1 /*length_only*/) && numeric(data, data_len, 0, 3, 3, p_err_no, p_err_posn, err_msg) && iso3166(data, data_len, 0, 3, 3, p_err_no, p_err_posn, err_msg, 0) && cset82(data, data_len, 3, 1, 9, p_err_no, p_err_posn, err_msg); } /* N3,iso3166 (Used by ORIGIN, COUNTRY - PROCESS, COUNTRY - FULL PROCESS) */ static int n3_iso3166(const unsigned char *data, const int data_len, int *p_err_no, int *p_err_posn, char err_msg[50]) { return data_len == 3 && iso3166(data, data_len, 0, 3, 3, p_err_no, p_err_posn, err_msg, 1 /*length_only*/) && numeric(data, data_len, 0, 3, 3, p_err_no, p_err_posn, err_msg) && iso3166(data, data_len, 0, 3, 3, p_err_no, p_err_posn, err_msg, 0); } /* N3,iso3166 [N3],iso3166 [N3],iso3166 [N3],iso3166 [N3],iso3166 (Used by COUNTRY - INITIAL PROCESS, COUNTRY -...) */ static int n3_iso3166__n3__iso3166__n3__iso3166__n3__iso3166__n3__iso3166(const unsigned char *data, const int data_len, int *p_err_no, int *p_err_posn, char err_msg[50]) { return data_len >= 3 && data_len <= 15 && iso3166(data, data_len, 0, 3, 3, p_err_no, p_err_posn, err_msg, 1 /*length_only*/) && iso3166(data, data_len, 3, 0, 3, p_err_no, p_err_posn, err_msg, 1 /*length_only*/) && iso3166(data, data_len, 6, 0, 3, p_err_no, p_err_posn, err_msg, 1 /*length_only*/) && iso3166(data, data_len, 9, 0, 3, p_err_no, p_err_posn, err_msg, 1 /*length_only*/) && iso3166(data, data_len, 12, 0, 3, p_err_no, p_err_posn, err_msg, 1 /*length_only*/) && numeric(data, data_len, 0, 3, 3, p_err_no, p_err_posn, err_msg) && iso3166(data, data_len, 0, 3, 3, p_err_no, p_err_posn, err_msg, 0) && numeric(data, data_len, 3, 0, 3, p_err_no, p_err_posn, err_msg) && iso3166(data, data_len, 3, 0, 3, p_err_no, p_err_posn, err_msg, 0) && numeric(data, data_len, 6, 0, 3, p_err_no, p_err_posn, err_msg) && iso3166(data, data_len, 6, 0, 3, p_err_no, p_err_posn, err_msg, 0) && numeric(data, data_len, 9, 0, 3, p_err_no, p_err_posn, err_msg) && iso3166(data, data_len, 9, 0, 3, p_err_no, p_err_posn, err_msg, 0) && numeric(data, data_len, 12, 0, 3, p_err_no, p_err_posn, err_msg) && iso3166(data, data_len, 12, 0, 3, p_err_no, p_err_posn, err_msg, 0); } /* X..3 (Used by ORIGIN SUBDIVISION, AQUATIC SPECIES) */ static int x__3(const unsigned char *data, const int data_len, int *p_err_no, int *p_err_posn, char err_msg[50]) { return data_len >= 1 && data_len <= 3 && cset82(data, data_len, 0, 1, 3, p_err_no, p_err_posn, err_msg); } /* X..35,pcenc (Used by SHIP TO COMP, SHIP TO NAME, RTN TO COMP, RTN TO NAME, SRV DESCRIPTION) */ static int x__35_pcenc(const unsigned char *data, const int data_len, int *p_err_no, int *p_err_posn, char err_msg[50]) { return data_len >= 1 && data_len <= 35 && pcenc(data, data_len, 0, 1, 35, p_err_no, p_err_posn, err_msg, 1 /*length_only*/) && cset82(data, data_len, 0, 1, 35, p_err_no, p_err_posn, err_msg) && pcenc(data, data_len, 0, 1, 35, p_err_no, p_err_posn, err_msg, 0); } /* X..70,pcenc (Used by SHIP TO ADD1, SHIP TO ADD2, SHIP TO SUB, SHIP TO LOC, SHIP TO REG, RTN TO ADD1, RTN TO ...) */ static int x__70_pcenc(const unsigned char *data, const int data_len, int *p_err_no, int *p_err_posn, char err_msg[50]) { return data_len >= 1 && data_len <= 70 && pcenc(data, data_len, 0, 1, 70, p_err_no, p_err_posn, err_msg, 1 /*length_only*/) && cset82(data, data_len, 0, 1, 70, p_err_no, p_err_posn, err_msg) && pcenc(data, data_len, 0, 1, 70, p_err_no, p_err_posn, err_msg, 0); } /* X2,iso3166alpha2 (Used by SHIP TO COUNTRY, RTN TO COUNTRY) */ static int x2_iso3166alpha2(const unsigned char *data, const int data_len, int *p_err_no, int *p_err_posn, char err_msg[50]) { return data_len == 2 && iso3166alpha2(data, data_len, 0, 2, 2, p_err_no, p_err_posn, err_msg, 1 /*length_only*/) && cset82(data, data_len, 0, 2, 2, p_err_no, p_err_posn, err_msg) && iso3166alpha2(data, data_len, 0, 2, 2, p_err_no, p_err_posn, err_msg, 0); } /* N10,latitude N10,longitude (Used by SHIP TO GEO) */ static int n10_latitude_n10_longitude(const unsigned char *data, const int data_len, int *p_err_no, int *p_err_posn, char err_msg[50]) { return data_len == 20 && latitude(data, data_len, 0, 10, 10, p_err_no, p_err_posn, err_msg, 1 /*length_only*/) && longitude(data, data_len, 10, 10, 10, p_err_no, p_err_posn, err_msg, 1 /*length_only*/) && numeric(data, data_len, 0, 10, 10, p_err_no, p_err_posn, err_msg) && latitude(data, data_len, 0, 10, 10, p_err_no, p_err_posn, err_msg, 0) && numeric(data, data_len, 10, 10, 10, p_err_no, p_err_posn, err_msg) && longitude(data, data_len, 10, 10, 10, p_err_no, p_err_posn, err_msg, 0); } /* N1,yesno (Used by DANGEROUS GOODS, AUTH TO LEAVE, SIG REQUIRED) */ static int n1_yesno(const unsigned char *data, const int data_len, int *p_err_no, int *p_err_posn, char err_msg[50]) { return data_len == 1 && yesno(data, data_len, 0, 1, 1, p_err_no, p_err_posn, err_msg, 1 /*length_only*/) && numeric(data, data_len, 0, 1, 1, p_err_no, p_err_posn, err_msg) && yesno(data, data_len, 0, 1, 1, p_err_no, p_err_posn, err_msg, 0); } /* N6,yymmd0 N4,hhmm (Used by NOT BEF DEL DT, NOT AFT DEL DT) */ static int n6_yymmd0_n4_hhmm(const unsigned char *data, const int data_len, int *p_err_no, int *p_err_posn, char err_msg[50]) { return data_len == 10 && yymmd0(data, data_len, 0, 6, 6, p_err_no, p_err_posn, err_msg, 1 /*length_only*/) && hhmm(data, data_len, 6, 4, 4, p_err_no, p_err_posn, err_msg, 1 /*length_only*/) && numeric(data, data_len, 0, 6, 6, p_err_no, p_err_posn, err_msg) && yymmd0(data, data_len, 0, 6, 6, p_err_no, p_err_posn, err_msg, 0) && numeric(data, data_len, 6, 4, 4, p_err_no, p_err_posn, err_msg) && hhmm(data, data_len, 6, 4, 4, p_err_no, p_err_posn, err_msg, 0); } /* N6,yymmdd (Used by REL DATE, FIRST FREEZE DATE) */ static int n6_yymmdd(const unsigned char *data, const int data_len, int *p_err_no, int *p_err_posn, char err_msg[50]) { return data_len == 6 && yymmdd(data, data_len, 0, 6, 6, p_err_no, p_err_posn, err_msg, 1 /*length_only*/) && numeric(data, data_len, 0, 6, 6, p_err_no, p_err_posn, err_msg) && yymmdd(data, data_len, 0, 6, 6, p_err_no, p_err_posn, err_msg, 0); } /* N6 [X1],hyphen (Used by MAX TEMP F., MAX TEMP C., MIN TEMP F., MIN TEMP C.) */ static int n6__x1__hyphen(const unsigned char *data, const int data_len, int *p_err_no, int *p_err_posn, char err_msg[50]) { return data_len >= 6 && data_len <= 7 && hyphen(data, data_len, 6, 0, 1, p_err_no, p_err_posn, err_msg, 1 /*length_only*/) && numeric(data, data_len, 0, 6, 6, p_err_no, p_err_posn, err_msg) && cset82(data, data_len, 6, 0, 1, p_err_no, p_err_posn, err_msg) && hyphen(data, data_len, 6, 0, 1, p_err_no, p_err_posn, err_msg, 0); } /* N13 (Used by NSN) */ static int n13(const unsigned char *data, const int data_len, int *p_err_no, int *p_err_posn, char err_msg[50]) { return data_len == 13 && numeric(data, data_len, 0, 13, 13, p_err_no, p_err_posn, err_msg); } /* N6,yymmdd N4,hhmm (Used by EXPIRY TIME) */ static int n6_yymmdd_n4_hhmm(const unsigned char *data, const int data_len, int *p_err_no, int *p_err_posn, char err_msg[50]) { return data_len == 10 && yymmdd(data, data_len, 0, 6, 6, p_err_no, p_err_posn, err_msg, 1 /*length_only*/) && hhmm(data, data_len, 6, 4, 4, p_err_no, p_err_posn, err_msg, 1 /*length_only*/) && numeric(data, data_len, 0, 6, 6, p_err_no, p_err_posn, err_msg) && yymmdd(data, data_len, 0, 6, 6, p_err_no, p_err_posn, err_msg, 0) && numeric(data, data_len, 6, 4, 4, p_err_no, p_err_posn, err_msg) && hhmm(data, data_len, 6, 4, 4, p_err_no, p_err_posn, err_msg, 0); } /* N..4 (Used by ACTIVE POTENCY) */ static int n__4(const unsigned char *data, const int data_len, int *p_err_no, int *p_err_posn, char err_msg[50]) { return data_len >= 1 && data_len <= 4 && numeric(data, data_len, 0, 1, 4, p_err_no, p_err_posn, err_msg); } /* X..12 (Used by CATCH AREA) */ static int x__12(const unsigned char *data, const int data_len, int *p_err_no, int *p_err_posn, char err_msg[50]) { return data_len >= 1 && data_len <= 12 && cset82(data, data_len, 0, 1, 12, p_err_no, p_err_posn, err_msg); } /* N6,yymmdd [N6],yymmdd (Used by HARVEST DATE) */ static int n6_yymmdd__n6__yymmdd(const unsigned char *data, const int data_len, int *p_err_no, int *p_err_posn, char err_msg[50]) { return data_len >= 6 && data_len <= 12 && yymmdd(data, data_len, 0, 6, 6, p_err_no, p_err_posn, err_msg, 1 /*length_only*/) && yymmdd(data, data_len, 6, 0, 6, p_err_no, p_err_posn, err_msg, 1 /*length_only*/) && numeric(data, data_len, 0, 6, 6, p_err_no, p_err_posn, err_msg) && yymmdd(data, data_len, 0, 6, 6, p_err_no, p_err_posn, err_msg, 0) && numeric(data, data_len, 6, 0, 6, p_err_no, p_err_posn, err_msg) && yymmdd(data, data_len, 6, 0, 6, p_err_no, p_err_posn, err_msg, 0); } /* X..10 (Used by FISHING GEAR TYPE, SUFFIX) */ static int x__10(const unsigned char *data, const int data_len, int *p_err_no, int *p_err_posn, char err_msg[50]) { return data_len >= 1 && data_len <= 10 && cset82(data, data_len, 0, 1, 10, p_err_no, p_err_posn, err_msg); } /* X..2 (Used by PROD METHOD) */ static int x__2(const unsigned char *data, const int data_len, int *p_err_no, int *p_err_posn, char err_msg[50]) { return data_len >= 1 && data_len <= 2 && cset82(data, data_len, 0, 1, 2, p_err_no, p_err_posn, err_msg); } /* N6,yymmdd [N4],hhmm (Used by TEST BY DATE) */ static int n6_yymmdd__n4__hhmm(const unsigned char *data, const int data_len, int *p_err_no, int *p_err_posn, char err_msg[50]) { return data_len >= 6 && data_len <= 10 && yymmdd(data, data_len, 0, 6, 6, p_err_no, p_err_posn, err_msg, 1 /*length_only*/) && hhmm(data, data_len, 6, 0, 4, p_err_no, p_err_posn, err_msg, 1 /*length_only*/) && numeric(data, data_len, 0, 6, 6, p_err_no, p_err_posn, err_msg) && yymmdd(data, data_len, 0, 6, 6, p_err_no, p_err_posn, err_msg, 0) && numeric(data, data_len, 6, 0, 4, p_err_no, p_err_posn, err_msg) && hhmm(data, data_len, 6, 0, 4, p_err_no, p_err_posn, err_msg, 0); } /* N3,iso3166999 X..27 (Used by PROCESSOR # 0, PROCESSOR # 1, PROCESSOR # 2, PROCESSOR # 3, PROCESSOR # 4, PROC...) */ static int n3_iso3166999_x__27(const unsigned char *data, const int data_len, int *p_err_no, int *p_err_posn, char err_msg[50]) { return data_len >= 4 && data_len <= 30 && iso3166999(data, data_len, 0, 3, 3, p_err_no, p_err_posn, err_msg, 1 /*length_only*/) && numeric(data, data_len, 0, 3, 3, p_err_no, p_err_posn, err_msg) && iso3166999(data, data_len, 0, 3, 3, p_err_no, p_err_posn, err_msg, 0) && cset82(data, data_len, 3, 1, 27, p_err_no, p_err_posn, err_msg); } /* N1 X1 X1 X1,importeridx (Used by UIC+EXT) */ static int n1_x1_x1_x1_importeridx(const unsigned char *data, const int data_len, int *p_err_no, int *p_err_posn, char err_msg[50]) { return data_len == 4 && importeridx(data, data_len, 3, 1, 1, p_err_no, p_err_posn, err_msg, 1 /*length_only*/) && numeric(data, data_len, 0, 1, 1, p_err_no, p_err_posn, err_msg) && cset82(data, data_len, 1, 1, 1, p_err_no, p_err_posn, err_msg) && cset82(data, data_len, 2, 1, 1, p_err_no, p_err_posn, err_msg) && cset82(data, data_len, 3, 1, 1, p_err_no, p_err_posn, err_msg) && importeridx(data, data_len, 3, 1, 1, p_err_no, p_err_posn, err_msg, 0); } /* X..4,packagetype (Used by UFRGT UNIT TYPE) */ static int x__4_packagetype(const unsigned char *data, const int data_len, int *p_err_no, int *p_err_posn, char err_msg[50]) { return data_len >= 1 && data_len <= 4 && packagetype(data, data_len, 0, 1, 4, p_err_no, p_err_posn, err_msg, 1 /*length_only*/) && cset82(data, data_len, 0, 1, 4, p_err_no, p_err_posn, err_msg) && packagetype(data, data_len, 0, 1, 4, p_err_no, p_err_posn, err_msg, 0); } /* X2 X..28 (Used by CERT # 1, CERT # 2, CERT # 3, CERT # 4, CERT # 5, CERT # 6, CERT # 7, CERT # 8, CERT # 9, ...) */ static int x2_x__28(const unsigned char *data, const int data_len, int *p_err_no, int *p_err_posn, char err_msg[50]) { return data_len >= 3 && data_len <= 30 && cset82(data, data_len, 0, 2, 2, p_err_no, p_err_posn, err_msg) && cset82(data, data_len, 2, 1, 28, p_err_no, p_err_posn, err_msg); } /* N2,mediatype (Used by AIDC MEDIA TYPE) */ static int n2_mediatype(const unsigned char *data, const int data_len, int *p_err_no, int *p_err_posn, char err_msg[50]) { return data_len == 2 && mediatype(data, data_len, 0, 2, 2, p_err_no, p_err_posn, err_msg, 1 /*length_only*/) && numeric(data, data_len, 0, 2, 2, p_err_no, p_err_posn, err_msg) && mediatype(data, data_len, 0, 2, 2, p_err_no, p_err_posn, err_msg, 0); } /* X..25 (Used by VCN, REF No.) */ static int x__25(const unsigned char *data, const int data_len, int *p_err_no, int *p_err_posn, char err_msg[50]) { return data_len >= 1 && data_len <= 25 && cset82(data, data_len, 0, 1, 25, p_err_no, p_err_posn, err_msg); } /* N8,yyyymmdd (Used by DOB) */ static int n8_yyyymmdd(const unsigned char *data, const int data_len, int *p_err_no, int *p_err_posn, char err_msg[50]) { return data_len == 8 && yyyymmdd(data, data_len, 0, 8, 8, p_err_no, p_err_posn, err_msg, 1 /*length_only*/) && numeric(data, data_len, 0, 8, 8, p_err_no, p_err_posn, err_msg) && yyyymmdd(data, data_len, 0, 8, 8, p_err_no, p_err_posn, err_msg, 0); } /* N8,yyyymmdd N4,hhmm (Used by DOB TIME) */ static int n8_yyyymmdd_n4_hhmm(const unsigned char *data, const int data_len, int *p_err_no, int *p_err_posn, char err_msg[50]) { return data_len == 12 && yyyymmdd(data, data_len, 0, 8, 8, p_err_no, p_err_posn, err_msg, 1 /*length_only*/) && hhmm(data, data_len, 8, 4, 4, p_err_no, p_err_posn, err_msg, 1 /*length_only*/) && numeric(data, data_len, 0, 8, 8, p_err_no, p_err_posn, err_msg) && yyyymmdd(data, data_len, 0, 8, 8, p_err_no, p_err_posn, err_msg, 0) && numeric(data, data_len, 8, 4, 4, p_err_no, p_err_posn, err_msg) && hhmm(data, data_len, 8, 4, 4, p_err_no, p_err_posn, err_msg, 0); } /* N1,iso5218 (Used by BIO SEX) */ static int n1_iso5218(const unsigned char *data, const int data_len, int *p_err_no, int *p_err_posn, char err_msg[50]) { return data_len == 1 && iso5218(data, data_len, 0, 1, 1, p_err_no, p_err_posn, err_msg, 1 /*length_only*/) && numeric(data, data_len, 0, 1, 1, p_err_no, p_err_posn, err_msg) && iso5218(data, data_len, 0, 1, 1, p_err_no, p_err_posn, err_msg, 0); } /* X..40,pcenc (Used by FAMILY NAME, GIVEN NAME, BABY) */ static int x__40_pcenc(const unsigned char *data, const int data_len, int *p_err_no, int *p_err_posn, char err_msg[50]) { return data_len >= 1 && data_len <= 40 && pcenc(data, data_len, 0, 1, 40, p_err_no, p_err_posn, err_msg, 1 /*length_only*/) && cset82(data, data_len, 0, 1, 40, p_err_no, p_err_posn, err_msg) && pcenc(data, data_len, 0, 1, 40, p_err_no, p_err_posn, err_msg, 0); } /* X..90,pcenc (Used by FULL NAME) */ static int x__90_pcenc(const unsigned char *data, const int data_len, int *p_err_no, int *p_err_posn, char err_msg[50]) { return data_len >= 1 && data_len <= 90 && pcenc(data, data_len, 0, 1, 90, p_err_no, p_err_posn, err_msg, 1 /*length_only*/) && cset82(data, data_len, 0, 1, 90, p_err_no, p_err_posn, err_msg) && pcenc(data, data_len, 0, 1, 90, p_err_no, p_err_posn, err_msg, 0); } /* X3,posinseqslash (Used by BIRTH SEQUENCE) */ static int x3_posinseqslash(const unsigned char *data, const int data_len, int *p_err_no, int *p_err_posn, char err_msg[50]) { return data_len == 3 && posinseqslash(data, data_len, 0, 3, 3, p_err_no, p_err_posn, err_msg, 1 /*length_only*/) && cset82(data, data_len, 0, 3, 3, p_err_no, p_err_posn, err_msg) && posinseqslash(data, data_len, 0, 3, 3, p_err_no, p_err_posn, err_msg, 0); } /* N4,nonzero N5,nonzero N3,nonzero N1,winding N1 (Used by DIMENSIONS) */ static int n4_nonzero_n5_nonzero_n3_nonzero_n1_winding_n1(const unsigned char *data, const int data_len, int *p_err_no, int *p_err_posn, char err_msg[50]) { return data_len == 14 && nonzero(data, data_len, 0, 4, 4, p_err_no, p_err_posn, err_msg, 1 /*length_only*/) && nonzero(data, data_len, 4, 5, 5, p_err_no, p_err_posn, err_msg, 1 /*length_only*/) && nonzero(data, data_len, 9, 3, 3, p_err_no, p_err_posn, err_msg, 1 /*length_only*/) && winding(data, data_len, 12, 1, 1, p_err_no, p_err_posn, err_msg, 1 /*length_only*/) && numeric(data, data_len, 0, 4, 4, p_err_no, p_err_posn, err_msg) && nonzero(data, data_len, 0, 4, 4, p_err_no, p_err_posn, err_msg, 0) && numeric(data, data_len, 4, 5, 5, p_err_no, p_err_posn, err_msg) && nonzero(data, data_len, 4, 5, 5, p_err_no, p_err_posn, err_msg, 0) && numeric(data, data_len, 9, 3, 3, p_err_no, p_err_posn, err_msg) && nonzero(data, data_len, 9, 3, 3, p_err_no, p_err_posn, err_msg, 0) && numeric(data, data_len, 12, 1, 1, p_err_no, p_err_posn, err_msg) && winding(data, data_len, 12, 1, 1, p_err_no, p_err_posn, err_msg, 0) && numeric(data, data_len, 13, 1, 1, p_err_no, p_err_posn, err_msg); } /* N1,zero N13,csum,key [X..16] (Used by GRAI) */ static int n1_zero_n13_csum_key__x__16_(const unsigned char *data, const int data_len, int *p_err_no, int *p_err_posn, char err_msg[50]) { return data_len >= 14 && data_len <= 30 && zero(data, data_len, 0, 1, 1, p_err_no, p_err_posn, err_msg, 1 /*length_only*/) && csum(data, data_len, 1, 13, 13, p_err_no, p_err_posn, err_msg, 1 /*length_only*/) && key(data, data_len, 1, 13, 13, p_err_no, p_err_posn, err_msg, 1 /*length_only*/) && numeric(data, data_len, 0, 1, 1, p_err_no, p_err_posn, err_msg) && zero(data, data_len, 0, 1, 1, p_err_no, p_err_posn, err_msg, 0) && numeric(data, data_len, 1, 13, 13, p_err_no, p_err_posn, err_msg) && csum(data, data_len, 1, 13, 13, p_err_no, p_err_posn, err_msg, 0) && key(data, data_len, 1, 13, 13, p_err_no, p_err_posn, err_msg, 0) && cset82(data, data_len, 14, 0, 16, p_err_no, p_err_posn, err_msg); } /* N14,csum N4,pieceoftotal (Used by ITIP, ITIP CONTENT) */ static int n14_csum_n4_pieceoftotal(const unsigned char *data, const int data_len, int *p_err_no, int *p_err_posn, char err_msg[50]) { return data_len == 18 && csum(data, data_len, 0, 14, 14, p_err_no, p_err_posn, err_msg, 1 /*length_only*/) && pieceoftotal(data, data_len, 14, 4, 4, p_err_no, p_err_posn, err_msg, 1 /*length_only*/) && numeric(data, data_len, 0, 14, 14, p_err_no, p_err_posn, err_msg) && csum(data, data_len, 0, 14, 14, p_err_no, p_err_posn, err_msg, 0) && numeric(data, data_len, 14, 4, 4, p_err_no, p_err_posn, err_msg) && pieceoftotal(data, data_len, 14, 4, 4, p_err_no, p_err_posn, err_msg, 0); } /* X..34,iban (Used by IBAN) */ static int x__34_iban(const unsigned char *data, const int data_len, int *p_err_no, int *p_err_posn, char err_msg[50]) { return data_len >= 1 && data_len <= 34 && iban(data, data_len, 0, 1, 34, p_err_no, p_err_posn, err_msg, 1 /*length_only*/) && cset82(data, data_len, 0, 1, 34, p_err_no, p_err_posn, err_msg) && iban(data, data_len, 0, 1, 34, p_err_no, p_err_posn, err_msg, 0); } /* N6,yymmdd N2,hh [N2],mm [N2],ss (Used by PROD TIME) */ static int n6_yymmdd_n2_hh__n2__mm__n2__ss(const unsigned char *data, const int data_len, int *p_err_no, int *p_err_posn, char err_msg[50]) { return data_len >= 8 && data_len <= 12 && yymmdd(data, data_len, 0, 6, 6, p_err_no, p_err_posn, err_msg, 1 /*length_only*/) && hh(data, data_len, 6, 2, 2, p_err_no, p_err_posn, err_msg, 1 /*length_only*/) && mm(data, data_len, 8, 0, 2, p_err_no, p_err_posn, err_msg, 1 /*length_only*/) && ss(data, data_len, 10, 0, 2, p_err_no, p_err_posn, err_msg, 1 /*length_only*/) && numeric(data, data_len, 0, 6, 6, p_err_no, p_err_posn, err_msg) && yymmdd(data, data_len, 0, 6, 6, p_err_no, p_err_posn, err_msg, 0) && numeric(data, data_len, 6, 2, 2, p_err_no, p_err_posn, err_msg) && hh(data, data_len, 6, 2, 2, p_err_no, p_err_posn, err_msg, 0) && numeric(data, data_len, 8, 0, 2, p_err_no, p_err_posn, err_msg) && mm(data, data_len, 8, 0, 2, p_err_no, p_err_posn, err_msg, 0) && numeric(data, data_len, 10, 0, 2, p_err_no, p_err_posn, err_msg) && ss(data, data_len, 10, 0, 2, p_err_no, p_err_posn, err_msg, 0); } /* X..50 (Used by OPTSEN) */ static int x__50(const unsigned char *data, const int data_len, int *p_err_no, int *p_err_posn, char err_msg[50]) { return data_len >= 1 && data_len <= 50 && cset82(data, data_len, 0, 1, 50, p_err_no, p_err_posn, err_msg); } /* Y..30,key (Used by CPID) */ static int y__30_key(const unsigned char *data, const int data_len, int *p_err_no, int *p_err_posn, char err_msg[50]) { return data_len >= 1 && data_len <= 30 && key(data, data_len, 0, 1, 30, p_err_no, p_err_posn, err_msg, 1 /*length_only*/) && cset39(data, data_len, 0, 1, 30, p_err_no, p_err_posn, err_msg) && key(data, data_len, 0, 1, 30, p_err_no, p_err_posn, err_msg, 0); } /* N..12,nozeroprefix (Used by CPID SERIAL) */ static int n__12_nozeroprefix(const unsigned char *data, const int data_len, int *p_err_no, int *p_err_posn, char err_msg[50]) { return data_len >= 1 && data_len <= 12 && nozeroprefix(data, data_len, 0, 1, 12, p_err_no, p_err_posn, err_msg, 1 /*length_only*/) && numeric(data, data_len, 0, 1, 12, p_err_no, p_err_posn, err_msg) && nozeroprefix(data, data_len, 0, 1, 12, p_err_no, p_err_posn, err_msg, 0); } /* X..25,csumalpha,key (Used by GMN) */ static int x__25_csumalpha_key(const unsigned char *data, const int data_len, int *p_err_no, int *p_err_posn, char err_msg[50]) { return data_len >= 1 && data_len <= 25 && csumalpha(data, data_len, 0, 1, 25, p_err_no, p_err_posn, err_msg, 1 /*length_only*/) && key(data, data_len, 0, 1, 25, p_err_no, p_err_posn, err_msg, 1 /*length_only*/) && cset82(data, data_len, 0, 1, 25, p_err_no, p_err_posn, err_msg) && csumalpha(data, data_len, 0, 1, 25, p_err_no, p_err_posn, err_msg, 0) && key(data, data_len, 0, 1, 25, p_err_no, p_err_posn, err_msg, 0); } /* X..25,csumalpha,key,hasnondigit (Used by MUDI) */ static int x__25_csumalpha_key_hasnondigit(const unsigned char *data, const int data_len, int *p_err_no, int *p_err_posn, char err_msg[50]) { return data_len >= 1 && data_len <= 25 && csumalpha(data, data_len, 0, 1, 25, p_err_no, p_err_posn, err_msg, 1 /*length_only*/) && key(data, data_len, 0, 1, 25, p_err_no, p_err_posn, err_msg, 1 /*length_only*/) && hasnondigit(data, data_len, 0, 1, 25, p_err_no, p_err_posn, err_msg, 1 /*length_only*/) && cset82(data, data_len, 0, 1, 25, p_err_no, p_err_posn, err_msg) && csumalpha(data, data_len, 0, 1, 25, p_err_no, p_err_posn, err_msg, 0) && key(data, data_len, 0, 1, 25, p_err_no, p_err_posn, err_msg, 0) && hasnondigit(data, data_len, 0, 1, 25, p_err_no, p_err_posn, err_msg, 0); } /* N..10 (Used by SRIN) */ static int n__10(const unsigned char *data, const int data_len, int *p_err_no, int *p_err_posn, char err_msg[50]) { return data_len >= 1 && data_len <= 10 && numeric(data, data_len, 0, 1, 10, p_err_no, p_err_posn, err_msg); } /* Z..90 (Used by DIGSIG) */ static int z__90(const unsigned char *data, const int data_len, int *p_err_no, int *p_err_posn, char err_msg[50]) { return data_len >= 1 && data_len <= 90 && cset64(data, data_len, 0, 1, 90, p_err_no, p_err_posn, err_msg); } /* X..70,couponcode */ static int x__70_couponcode(const unsigned char *data, const int data_len, int *p_err_no, int *p_err_posn, char err_msg[50]) { return data_len >= 1 && data_len <= 70 && couponcode(data, data_len, 0, 1, 70, p_err_no, p_err_posn, err_msg, 1 /*length_only*/) && cset82(data, data_len, 0, 1, 70, p_err_no, p_err_posn, err_msg) && couponcode(data, data_len, 0, 1, 70, p_err_no, p_err_posn, err_msg, 0); } /* X..70,couponposoffer */ static int x__70_couponposoffer(const unsigned char *data, const int data_len, int *p_err_no, int *p_err_posn, char err_msg[50]) { return data_len >= 1 && data_len <= 70 && couponposoffer(data, data_len, 0, 1, 70, p_err_no, p_err_posn, err_msg, 1 /*length_only*/) && cset82(data, data_len, 0, 1, 70, p_err_no, p_err_posn, err_msg) && couponposoffer(data, data_len, 0, 1, 70, p_err_no, p_err_posn, err_msg, 0); } /* X..70 (Used by PRODUCT URL) */ static int x__70(const unsigned char *data, const int data_len, int *p_err_no, int *p_err_posn, char err_msg[50]) { return data_len >= 1 && data_len <= 70 && cset82(data, data_len, 0, 1, 70, p_err_no, p_err_posn, err_msg); } /* X..90 (Used by INTERNAL) */ static int x__90(const unsigned char *data, const int data_len, int *p_err_no, int *p_err_posn, char err_msg[50]) { return data_len >= 1 && data_len <= 90 && cset82(data, data_len, 0, 1, 90, p_err_no, p_err_posn, err_msg); } /* Entry point. Returns 1 on success, 0 on failure: `*p_err_no` set to 1 if unknown AI, 2 if bad data length */ static int gs1_lint(const int ai, const unsigned char *data, const int data_len, int *p_err_no, int *p_err_posn, char err_msg[50]) { /* Assume data length failure */ *p_err_no = 2; if (ai < 100) { if (ai == 0) { return n18_csum_key(data, data_len, p_err_no, p_err_posn, err_msg); } if (ai >= 1 && ai <= 3) { return n14_csum_key(data, data_len, p_err_no, p_err_posn, err_msg); } if (ai == 10 || ai == 21 || ai == 22) { return x__20(data, data_len, p_err_no, p_err_posn, err_msg); } if ((ai >= 11 && ai <= 13) || (ai >= 15 && ai <= 17)) { return n6_yymmd0(data, data_len, p_err_no, p_err_posn, err_msg); } if (ai == 20) { return n2(data, data_len, p_err_no, p_err_posn, err_msg); } if (ai == 30 || ai == 37) { return n__8(data, data_len, p_err_no, p_err_posn, err_msg); } if (ai == 90) { return x__30(data, data_len, p_err_no, p_err_posn, err_msg); } if (ai >= 91) { return x__90(data, data_len, p_err_no, p_err_posn, err_msg); } } else if (ai < 300) { if (ai == 235) { return x__28(data, data_len, p_err_no, p_err_posn, err_msg); } if (ai == 240 || ai == 241 || ai == 250 || ai == 251) { return x__30(data, data_len, p_err_no, p_err_posn, err_msg); } if (ai == 242) { return n__6(data, data_len, p_err_no, p_err_posn, err_msg); } if (ai == 243 || ai == 254) { return x__20(data, data_len, p_err_no, p_err_posn, err_msg); } if (ai == 253) { return n13_csum_key__x__17_(data, data_len, p_err_no, p_err_posn, err_msg); } if (ai == 255) { return n13_csum_key__n__12_(data, data_len, p_err_no, p_err_posn, err_msg); } } else if (ai < 500) { if (ai == 400 || ai == 403) { return x__30(data, data_len, p_err_no, p_err_posn, err_msg); } if (ai == 401) { return x__30_key(data, data_len, p_err_no, p_err_posn, err_msg); } if (ai == 402) { return n17_csum_key(data, data_len, p_err_no, p_err_posn, err_msg); } if (ai >= 410 && ai <= 417) { return n13_csum_key(data, data_len, p_err_no, p_err_posn, err_msg); } if (ai == 420) { return x__20(data, data_len, p_err_no, p_err_posn, err_msg); } if (ai == 421) { return n3_iso3166_x__9(data, data_len, p_err_no, p_err_posn, err_msg); } if (ai == 422 || ai == 424 || ai == 426) { return n3_iso3166(data, data_len, p_err_no, p_err_posn, err_msg); } if (ai == 423 || ai == 425) { return n3_iso3166__n3__iso3166__n3__iso3166__n3__iso3166__n3__iso3166(data, data_len, p_err_no, p_err_posn, err_msg); } if (ai == 427) { return x__3(data, data_len, p_err_no, p_err_posn, err_msg); } } else if (ai < 800) { if (ai >= 710 && ai <= 716) { return x__20(data, data_len, p_err_no, p_err_posn, err_msg); } } else if (ai < 3200) { if ((ai >= 3100 && ai <= 3105) || (ai >= 3110 && ai <= 3115) || (ai >= 3120 && ai <= 3125) || (ai >= 3130 && ai <= 3135) || (ai >= 3140 && ai <= 3145) || (ai >= 3150 && ai <= 3155) || (ai >= 3160 && ai <= 3165)) { return n6(data, data_len, p_err_no, p_err_posn, err_msg); } } else if (ai < 3300) { if (ai <= 3205 || (ai >= 3210 && ai <= 3215) || (ai >= 3220 && ai <= 3225) || (ai >= 3230 && ai <= 3235) || (ai >= 3240 && ai <= 3245) || (ai >= 3250 && ai <= 3255) || (ai >= 3260 && ai <= 3265) || (ai >= 3270 && ai <= 3275) || (ai >= 3280 && ai <= 3285) || (ai >= 3290 && ai <= 3295)) { return n6(data, data_len, p_err_no, p_err_posn, err_msg); } } else if (ai < 3400) { if (ai <= 3305 || (ai >= 3310 && ai <= 3315) || (ai >= 3320 && ai <= 3325) || (ai >= 3330 && ai <= 3335) || (ai >= 3340 && ai <= 3345) || (ai >= 3350 && ai <= 3355) || (ai >= 3360 && ai <= 3365) || (ai >= 3370 && ai <= 3375)) { return n6(data, data_len, p_err_no, p_err_posn, err_msg); } } else if (ai < 3500) { if (ai <= 3405 || (ai >= 3410 && ai <= 3415) || (ai >= 3420 && ai <= 3425) || (ai >= 3430 && ai <= 3435) || (ai >= 3440 && ai <= 3445) || (ai >= 3450 && ai <= 3455) || (ai >= 3460 && ai <= 3465) || (ai >= 3470 && ai <= 3475) || (ai >= 3480 && ai <= 3485) || (ai >= 3490 && ai <= 3495)) { return n6(data, data_len, p_err_no, p_err_posn, err_msg); } } else if (ai < 3600) { if (ai <= 3505 || (ai >= 3510 && ai <= 3515) || (ai >= 3520 && ai <= 3525) || (ai >= 3530 && ai <= 3535) || (ai >= 3540 && ai <= 3545) || (ai >= 3550 && ai <= 3555) || (ai >= 3560 && ai <= 3565) || (ai >= 3570 && ai <= 3575)) { return n6(data, data_len, p_err_no, p_err_posn, err_msg); } } else if (ai < 3700) { if (ai <= 3605 || (ai >= 3610 && ai <= 3615) || (ai >= 3620 && ai <= 3625) || (ai >= 3630 && ai <= 3635) || (ai >= 3640 && ai <= 3645) || (ai >= 3650 && ai <= 3655) || (ai >= 3660 && ai <= 3665) || (ai >= 3670 && ai <= 3675) || (ai >= 3680 && ai <= 3685) || (ai >= 3690 && ai <= 3695)) { return n6(data, data_len, p_err_no, p_err_posn, err_msg); } } else if (ai < 4000) { if ((ai >= 3900 && ai <= 3909) || (ai >= 3920 && ai <= 3929)) { return n__15(data, data_len, p_err_no, p_err_posn, err_msg); } if ((ai >= 3910 && ai <= 3919) || (ai >= 3930 && ai <= 3939)) { return n3_iso4217_n__15(data, data_len, p_err_no, p_err_posn, err_msg); } if (ai >= 3940 && ai <= 3943) { return n4(data, data_len, p_err_no, p_err_posn, err_msg); } if (ai >= 3950 && ai <= 3955) { return n6(data, data_len, p_err_no, p_err_posn, err_msg); } } else if (ai < 4400) { if (ai == 4300 || ai == 4301 || ai == 4310 || ai == 4311 || ai == 4320) { return x__35_pcenc(data, data_len, p_err_no, p_err_posn, err_msg); } if ((ai >= 4302 && ai <= 4306) || (ai >= 4312 && ai <= 4316)) { return x__70_pcenc(data, data_len, p_err_no, p_err_posn, err_msg); } if (ai == 4307 || ai == 4317) { return x2_iso3166alpha2(data, data_len, p_err_no, p_err_posn, err_msg); } if (ai == 4308 || ai == 4319) { return x__30(data, data_len, p_err_no, p_err_posn, err_msg); } if (ai == 4309) { return n10_latitude_n10_longitude(data, data_len, p_err_no, p_err_posn, err_msg); } if (ai == 4318) { return x__20(data, data_len, p_err_no, p_err_posn, err_msg); } if (ai >= 4321 && ai <= 4323) { return n1_yesno(data, data_len, p_err_no, p_err_posn, err_msg); } if (ai == 4324 || ai == 4325) { return n6_yymmd0_n4_hhmm(data, data_len, p_err_no, p_err_posn, err_msg); } if (ai == 4326) { return n6_yymmdd(data, data_len, p_err_no, p_err_posn, err_msg); } if (ai >= 4330 && ai <= 4333) { return n6__x1__hyphen(data, data_len, p_err_no, p_err_posn, err_msg); } } else if (ai < 7100) { if (ai == 7001) { return n13(data, data_len, p_err_no, p_err_posn, err_msg); } if (ai == 7002) { return x__30(data, data_len, p_err_no, p_err_posn, err_msg); } if (ai == 7003) { return n6_yymmdd_n4_hhmm(data, data_len, p_err_no, p_err_posn, err_msg); } if (ai == 7004) { return n__4(data, data_len, p_err_no, p_err_posn, err_msg); } if (ai == 7005) { return x__12(data, data_len, p_err_no, p_err_posn, err_msg); } if (ai == 7006) { return n6_yymmdd(data, data_len, p_err_no, p_err_posn, err_msg); } if (ai == 7007) { return n6_yymmdd__n6__yymmdd(data, data_len, p_err_no, p_err_posn, err_msg); } if (ai == 7008) { return x__3(data, data_len, p_err_no, p_err_posn, err_msg); } if (ai == 7009) { return x__10(data, data_len, p_err_no, p_err_posn, err_msg); } if (ai == 7010) { return x__2(data, data_len, p_err_no, p_err_posn, err_msg); } if (ai == 7011) { return n6_yymmdd__n4__hhmm(data, data_len, p_err_no, p_err_posn, err_msg); } if (ai >= 7020 && ai <= 7022) { return x__20(data, data_len, p_err_no, p_err_posn, err_msg); } if (ai == 7023) { return x__30_key(data, data_len, p_err_no, p_err_posn, err_msg); } if (ai >= 7030 && ai <= 7039) { return n3_iso3166999_x__27(data, data_len, p_err_no, p_err_posn, err_msg); } if (ai == 7040) { return n1_x1_x1_x1_importeridx(data, data_len, p_err_no, p_err_posn, err_msg); } if (ai == 7041) { return x__4_packagetype(data, data_len, p_err_no, p_err_posn, err_msg); } } else if (ai < 7300) { if (ai >= 7230 && ai <= 7239) { return x2_x__28(data, data_len, p_err_no, p_err_posn, err_msg); } if (ai == 7240) { return x__20(data, data_len, p_err_no, p_err_posn, err_msg); } if (ai == 7241) { return n2_mediatype(data, data_len, p_err_no, p_err_posn, err_msg); } if (ai == 7242) { return x__25(data, data_len, p_err_no, p_err_posn, err_msg); } if (ai == 7250) { return n8_yyyymmdd(data, data_len, p_err_no, p_err_posn, err_msg); } if (ai == 7251) { return n8_yyyymmdd_n4_hhmm(data, data_len, p_err_no, p_err_posn, err_msg); } if (ai == 7252) { return n1_iso5218(data, data_len, p_err_no, p_err_posn, err_msg); } if (ai == 7253 || ai == 7254 || ai == 7259) { return x__40_pcenc(data, data_len, p_err_no, p_err_posn, err_msg); } if (ai == 7255) { return x__10(data, data_len, p_err_no, p_err_posn, err_msg); } if (ai == 7256) { return x__90_pcenc(data, data_len, p_err_no, p_err_posn, err_msg); } if (ai == 7257) { return x__70_pcenc(data, data_len, p_err_no, p_err_posn, err_msg); } if (ai == 7258) { return x3_posinseqslash(data, data_len, p_err_no, p_err_posn, err_msg); } } else if (ai < 8100) { if (ai == 8001) { return n4_nonzero_n5_nonzero_n3_nonzero_n1_winding_n1(data, data_len, p_err_no, p_err_posn, err_msg); } if (ai == 8002 || ai == 8012) { return x__20(data, data_len, p_err_no, p_err_posn, err_msg); } if (ai == 8003) { return n1_zero_n13_csum_key__x__16_(data, data_len, p_err_no, p_err_posn, err_msg); } if (ai == 8004) { return x__30_key(data, data_len, p_err_no, p_err_posn, err_msg); } if (ai == 8005) { return n6(data, data_len, p_err_no, p_err_posn, err_msg); } if (ai == 8006 || ai == 8026) { return n14_csum_n4_pieceoftotal(data, data_len, p_err_no, p_err_posn, err_msg); } if (ai == 8007) { return x__34_iban(data, data_len, p_err_no, p_err_posn, err_msg); } if (ai == 8008) { return n6_yymmdd_n2_hh__n2__mm__n2__ss(data, data_len, p_err_no, p_err_posn, err_msg); } if (ai == 8009) { return x__50(data, data_len, p_err_no, p_err_posn, err_msg); } if (ai == 8010) { return y__30_key(data, data_len, p_err_no, p_err_posn, err_msg); } if (ai == 8011) { return n__12_nozeroprefix(data, data_len, p_err_no, p_err_posn, err_msg); } if (ai == 8013) { return x__25_csumalpha_key(data, data_len, p_err_no, p_err_posn, err_msg); } if (ai == 8014) { return x__25_csumalpha_key_hasnondigit(data, data_len, p_err_no, p_err_posn, err_msg); } if (ai == 8017 || ai == 8018) { return n18_csum_key(data, data_len, p_err_no, p_err_posn, err_msg); } if (ai == 8019) { return n__10(data, data_len, p_err_no, p_err_posn, err_msg); } if (ai == 8020) { return x__25(data, data_len, p_err_no, p_err_posn, err_msg); } if (ai == 8030) { return z__90(data, data_len, p_err_no, p_err_posn, err_msg); } } else if (ai < 8200) { if (ai == 8110) { return x__70_couponcode(data, data_len, p_err_no, p_err_posn, err_msg); } if (ai == 8111) { return n4(data, data_len, p_err_no, p_err_posn, err_msg); } if (ai == 8112) { return x__70_couponposoffer(data, data_len, p_err_no, p_err_posn, err_msg); } } else if (ai < 8300) { if (ai == 8200) { return x__70(data, data_len, p_err_no, p_err_posn, err_msg); } } /* Unknown AI */ *p_err_no = 1; return 0; } #endif /* Z_GS1_LINT_H */