| 12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394959697989910010110210310410510610710810911011111211311411511611711811912012112212312412512612712812913013113213313413513613713813914014114214314414514614714814915015115215315415515615715815916016116216316416516616716816917017117217317417517617717817918018118218318418518618718818919019119219319419519619719819920020120220320420520620720820921021121221321421521621721821922022122222322422522622722822923023123223323423523623723823924024124224324424524624724824925025125225325425525625725825926026126226326426526626726826927027127227327427527627727827928028128228328428528628728828929029129229329429529629729829930030130230330430530630730830931031131231331431531631731831932032132232332432532632732832933033133233333433533633733833934034134234334434534634734834935035135235335435535635735835936036136236336436536636736836937037137237337437537637737837938038138238338438538638738838939039139239339439539639739839940040140240340440540640740840941041141241341441541641741841942042142242342442542642742842943043143243343443543643743843944044144244344444544644744844945045145245345445545645745845946046146246346446546646746846947047147247347447547647747847948048148248348448548648748848949049149249349449549649749849950050150250350450550650750850951051151251351451551651751851952052152252352452552652752852953053153253353453553653753853954054154254354454554654754854955055155255355455555655755855956056156256356456556656756856957057157257357457557657757857958058158258358458558658758858959059159259359459559659759859960060160260360460560660760860961061161261361461561661761861962062162262362462562662762862963063163263363463563663763863964064164264364464564664764864965065165265365465565665765865966066166266366466566666766866967067167267367467567667767867968068168268368468568668768868969069169269369469569669769869970070170270370470570670770870971071171271371471571671771871972072172272372472572672772872973073173273373473573673773873974074174274374474574674774874975075175275375475575675775875976076176276376476576676776876977077177277377477577677777877978078178278378478578678778878979079179279379479579679779879980080180280380480580680780880981081181281381481581681781881982082182282382482582682782882983083183283383483583683783883984084184284384484584684784884985085185285385485585685785885986086186286386486586686786886987087187287387487587687787887988088188288388488588688788888989089189289389489589689789889990090190290390490590690790890991091191291391491591691791891992092192292392492592692792892993093193293393493593693793893994094194294394494594694794894995095195295395495595695795895996096196296396496596696796896997097197297397497597697797897998098198298398498598698798898999099199299399499599699799899910001001100210031004100510061007100810091010101110121013101410151016101710181019102010211022102310241025102610271028102910301031 |
- /*
- * 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 <rstuart114@gmail.com>
- 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,hhmi (Used by NOT BEF DEL DT, NOT AFT DEL DT) */
- static int n6_yymmd0_n4_hhmi(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*/)
- && hhmi(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)
- && hhmi(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,hhmi (Used by EXPIRY TIME) */
- static int n6_yymmdd_n4_hhmi(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*/)
- && hhmi(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)
- && hhmi(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],hhmi (Used by TEST BY DATE) */
- static int n6_yymmdd__n4__hhmi(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*/)
- && hhmi(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)
- && hhmi(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,hhmi (Used by DOB TIME) */
- static int n8_yyyymmdd_n4_hhmi(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*/)
- && hhmi(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)
- && hhmi(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],mi [N2],ss (Used by PROD TIME) */
- static int n6_yymmdd_n2_hh__n2__mi__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*/)
- && mi(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)
- && mi(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_hhmi(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_hhmi(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__hhmi(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_hhmi(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__mi__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 */
|