Mercurial > hgrepos > Python2 > PyMuPDF
diff mupdf-source/thirdparty/zint/backend/tests/fuzz/fuzz_gs1.c @ 2:b50eed0cc0ef upstream
ADD: MuPDF v1.26.7: the MuPDF source as downloaded by a default build of PyMuPDF 1.26.4.
The directory name has changed: no version number in the expanded directory now.
| author | Franz Glasner <fzglas.hg@dom66.de> |
|---|---|
| date | Mon, 15 Sep 2025 11:43:07 +0200 |
| parents | |
| children |
line wrap: on
line diff
--- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/mupdf-source/thirdparty/zint/backend/tests/fuzz/fuzz_gs1.c Mon Sep 15 11:43:07 2025 +0200 @@ -0,0 +1,123 @@ +/* fuzz_gs1.c - fuzzer for libzint (GS1-enabled symbologies, GS1_MODE) */ +/* + libzint - the open source barcode library + Copyright (C) 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 */ + +#ifdef __cplusplus +extern "C" { +#endif /* __cplusplus */ + +#if 0 +#define Z_FUZZ_DEBUG /* Set `symbol->debug` flag */ +#define Z_FUZZ_SET_OUTPUT_OPTIONS /* Set `symbol->output_options` */ +#endif +#include "fuzz.h" + +int LLVMFuzzerTestOneInput(const unsigned char *data, size_t size) { + static const int symbologies[] = { + BARCODE_AZTEC, BARCODE_CODE16K, BARCODE_CODE49, BARCODE_CODEONE, BARCODE_DATAMATRIX, BARCODE_DBAR_EXP, + BARCODE_DBAR_EXPSTK, BARCODE_DOTCODE, BARCODE_GS1_128, BARCODE_QRCODE, BARCODE_RMQR, BARCODE_ULTRA, + BARCODE_EANX_CC, BARCODE_GS1_128_CC, BARCODE_DBAR_OMN_CC, BARCODE_DBAR_LTD_CC, BARCODE_DBAR_EXP_CC, + BARCODE_UPCA_CC, BARCODE_UPCE_CC, BARCODE_DBAR_STK_CC, BARCODE_DBAR_OMNSTK_CC, BARCODE_DBAR_EXPSTK_CC, + }; + struct zint_symbol *symbol; + unsigned char *gs1_buf; + int i; + + /* Ignore empty or very large input */ + if (size < 1 || size > 10000) { + return 0; + } + + symbol = ZBarcode_Create(); + assert(symbol); + + gs1_buf = (unsigned char *) malloc(size + 2); + assert(gs1_buf); + gs1_buf[0] = '['; /* Add dummy AI - along with GS1NOCHECK_MODE disables GS1 verification */ + gs1_buf[1] = ']'; + + for (i = 0; i < ZARRAY_SIZE(symbologies); i++) { + static const char primary_ai[] = "[01]12345678901231"; + static const char primary_upce[] = "12345670"; + static const char primary[] = "123456789012"; + const int idx = symbologies[i]; + const int is_composite = ZBarcode_Cap(idx, ZINT_CAP_COMPOSITE) & ZINT_CAP_COMPOSITE; + const unsigned char *input; + int length; + int ret; + + assert(ZBarcode_ValidID(idx)); + + input = data; + length = set_symbol(symbol, idx, !is_composite /*chk_sane*/, 1 /*no_eci*/, &input, size); + if (!length) { + continue; + } + + if (is_composite) { + if (idx == BARCODE_GS1_128_CC || idx == BARCODE_DBAR_EXP_CC || idx == BARCODE_DBAR_EXPSTK_CC) { + strcpy(symbol->primary, primary_ai); + } else if (idx == BARCODE_UPCE_CC) { + strcpy(symbol->primary, primary_upce); + } else { + strcpy(symbol->primary, primary); + } + } + + /* Try it first without GS1NOCHECK_MODE */ + symbol->input_mode = (symbol->input_mode & ~0x07) | GS1_MODE; + + ret = ZBarcode_Encode(symbol, input, length); + assert(ret != ZINT_ERROR_ENCODING_PROBLEM); + + ZBarcode_Clear(symbol); + + /* Now with GS1NOCHECK_MODE */ + symbol->input_mode = (symbol->input_mode & ~0x07) | GS1_MODE | GS1NOCHECK_MODE; + symbol->input_mode &= ~GS1PARENS_MODE; + + memcpy(gs1_buf + 2, input, length); + + ret = ZBarcode_Encode(symbol, gs1_buf, length + 2); + assert(ret != ZINT_ERROR_ENCODING_PROBLEM); + } + + (void) free(gs1_buf); + ZBarcode_Delete(symbol); + + return 0; +} + +#ifdef __cplusplus +} +#endif /* __cplusplus */ + +/* vim: set ts=4 sw=4 et : */
