diff --git a/README.md b/README.md index 8b5671e..2033ad5 100644 --- a/README.md +++ b/README.md @@ -1,3 +1,18 @@ # Databrae -Inexpensive, direct, high speed item access without RFID \ No newline at end of file +--- + +## The Short Story + +RFID is expensive and requires expensive equipment to make it work in a library. So instead, this project uses a small data matrix barcode added to the spine label, or to the spine of the item. This barcode is simply another way of accessing the item's barcode you'd normally find on the cover, the one that would be scanned at a circulation desk or by a self-check machine. This allows the item to be scannable while sitting on the shelf. + +Using an inexpensive 2D barcode scanner -- something that a library might already have on hand -- library staff can act upon individual items or work with them in bulk. This allows for inventory, shelf-reading, weeding, and other library tasks that can be performed in a manner similar to what is done with RFID, but at a fraction of the cost. + +## IUG Speaking Proposal + +One of the dreams of the Circulation Librarian is the ability to access and evaluate the items on the shelves without touching every single item. If you're running an inventory, or checking last circ dates for a weeding project, or checking for errant item statuses, the process is the same: Scan the item into your ILS and move on from there. RFID promised a solution for this, with handheld wands that are supposed to read the tags and you never have to touch the items. + +Except for two problems: One, everything about RFID is expensive and two, wands don't always work. Sooner or later, you'll run into an issue where you cannot scan an RFID tag and need to pull the item off the shelf. And for some libraries, the expensive nature of RFID, from the price of tags to the price of equipment, hampers their ability to improve their workflows and make their jobs easier. + +I have an idea. I admit, it's a crazy idea, but it's everything RFID isn't. It's inexpensive, the software is free and open source, your library won't need to buy a lot of special equipment, the price of conversion is pennies on the dollar compared to RFID, it doesn't matter what ILS you're running, and there's a good chance you already have everything you need. + diff --git a/composer.json b/composer.json new file mode 100644 index 0000000..76465c3 --- /dev/null +++ b/composer.json @@ -0,0 +1,5 @@ +{ + "require": { + "tecnickcom/tc-lib-barcode": "^2.4" + } +} diff --git a/composer.lock b/composer.lock new file mode 100644 index 0000000..acfadba --- /dev/null +++ b/composer.lock @@ -0,0 +1,188 @@ +{ + "_readme": [ + "This file locks the dependencies of your project to a known state", + "Read more about it at https://getcomposer.org/doc/01-basic-usage.md#installing-dependencies", + "This file is @generated automatically" + ], + "content-hash": "fec1884528cfb2fb28b4e18390c129bc", + "packages": [ + { + "name": "tecnickcom/tc-lib-barcode", + "version": "2.4.8", + "source": { + "type": "git", + "url": "https://github.com/tecnickcom/tc-lib-barcode.git", + "reference": "f238ffd120d98a34df6573590e7ed02f766a91c4" + }, + "dist": { + "type": "zip", + "url": "https://api.github.com/repos/tecnickcom/tc-lib-barcode/zipball/f238ffd120d98a34df6573590e7ed02f766a91c4", + "reference": "f238ffd120d98a34df6573590e7ed02f766a91c4", + "shasum": "" + }, + "require": { + "ext-bcmath": "*", + "ext-date": "*", + "ext-gd": "*", + "ext-pcre": "*", + "php": ">=8.1", + "tecnickcom/tc-lib-color": "^2.2" + }, + "require-dev": { + "pdepend/pdepend": "2.16.2", + "phpmd/phpmd": "2.15.0", + "phpunit/phpunit": "12.2.0 || 11.5.7 || 10.5.40", + "squizlabs/php_codesniffer": "3.13.0" + }, + "type": "library", + "autoload": { + "psr-4": { + "Com\\Tecnick\\Barcode\\": "src" + } + }, + "notification-url": "https://packagist.org/downloads/", + "license": [ + "LGPL-3.0-or-later" + ], + "authors": [ + { + "name": "Nicola Asuni", + "email": "info@tecnick.com", + "role": "lead" + } + ], + "description": "PHP library to generate linear and bidimensional barcodes", + "homepage": "http://www.tecnick.com", + "keywords": [ + "3 of 9", + "ANSI MH10.8M-1983", + "CBC", + "CODABAR", + "CODE 11", + "CODE 128 A B C", + "CODE 39", + "CODE 93", + "EAN 13", + "EAN 8", + "ECC200", + "ISO IEC 15438 2006", + "ISO IEC 16022", + "ISO IEC 24778 2008", + "Intelligent Mail Barcode", + "Interleaved 2 of 5", + "KIX", + "Klant", + "MSI", + "Onecode", + "PHARMACODE", + "PHARMACODE TWO-TRACKS", + "POSTNET", + "RMS4CC", + "Standard 2 of 5", + "UPC-A", + "UPC-E", + "USD-3", + "USPS-B-3200", + "USS-93", + "aztec", + "barcode", + "datamatrix", + "pdf417", + "planet", + "qr-code", + "royal mail", + "tc-lib-barcode", + "upc" + ], + "support": { + "issues": "https://github.com/tecnickcom/tc-lib-barcode/issues", + "source": "https://github.com/tecnickcom/tc-lib-barcode/tree/2.4.8" + }, + "funding": [ + { + "url": "https://www.paypal.com/donate/?hosted_button_id=NZUEC5XS8MFBJ", + "type": "custom" + } + ], + "time": "2025-06-06T11:35:02+00:00" + }, + { + "name": "tecnickcom/tc-lib-color", + "version": "2.2.13", + "source": { + "type": "git", + "url": "https://github.com/tecnickcom/tc-lib-color.git", + "reference": "85d1366fb33813aa521d30e3d7c7d7d82a8103a6" + }, + "dist": { + "type": "zip", + "url": "https://api.github.com/repos/tecnickcom/tc-lib-color/zipball/85d1366fb33813aa521d30e3d7c7d7d82a8103a6", + "reference": "85d1366fb33813aa521d30e3d7c7d7d82a8103a6", + "shasum": "" + }, + "require": { + "ext-pcre": "*", + "php": ">=8.1" + }, + "require-dev": { + "pdepend/pdepend": "2.16.2", + "phpmd/phpmd": "2.15.0", + "phpunit/phpunit": "12.2.0 || 11.5.7 || 10.5.40", + "squizlabs/php_codesniffer": "3.13.0" + }, + "type": "library", + "autoload": { + "psr-4": { + "Com\\Tecnick\\Color\\": "src" + } + }, + "notification-url": "https://packagist.org/downloads/", + "license": [ + "LGPL-3.0-or-later" + ], + "authors": [ + { + "name": "Nicola Asuni", + "email": "info@tecnick.com", + "role": "lead" + } + ], + "description": "PHP library to manipulate various color representations", + "homepage": "http://www.tecnick.com", + "keywords": [ + "cmyk", + "color", + "colors", + "colour", + "colours", + "hsl", + "hsla", + "javascript", + "rgb", + "rgba", + "tc-lib-color", + "web" + ], + "support": { + "issues": "https://github.com/tecnickcom/tc-lib-color/issues", + "source": "https://github.com/tecnickcom/tc-lib-color/tree/2.2.13" + }, + "funding": [ + { + "url": "https://www.paypal.com/donate/?hosted_button_id=NZUEC5XS8MFBJ", + "type": "custom" + } + ], + "time": "2025-06-06T11:33:19+00:00" + } + ], + "packages-dev": [], + "aliases": [], + "minimum-stability": "stable", + "stability-flags": [], + "prefer-stable": false, + "prefer-lowest": false, + "platform": [], + "platform-dev": [], + "plugin-api-version": "2.6.0" +} diff --git a/index-csv.php b/index-csv.php new file mode 100644 index 0000000..231c570 --- /dev/null +++ b/index-csv.php @@ -0,0 +1,499 @@ + strtolower(trim((string)$h)), $hdr); + + foreach (['data1','data2','data3','data4','barcode'] as $req) { + if (!in_array($req, $headers, true)) $errors[] = "Missing required header: {$req}."; + } + if ($errors) { fclose($fh); return []; } + + while (($row = fgetcsv($fh, 0, $delimiter)) !== false) { + if ($row === [null] || $row === false) continue; + if (count(array_filter($row, fn($v) => trim((string)$v) !== '')) === 0) continue; // skip blank line + $assoc = []; + foreach ($required as $key) { + $idx = array_search($key, $headers, true); + $assoc[$key] = $idx !== false && isset($row[$idx]) ? trim((string)$row[$idx]) : ''; + } + if (implode('', $assoc) === '') continue; + $rows[] = $assoc; + } + fclose($fh); + if (empty($rows)) $errors[] = "CSV contained no usable rows after the header."; + return $rows; +} +function render_datamatrix_svg(string $content): string { + global $autoloadOk; + if (!$autoloadOk) return ''; + $barcode = new Barcode(); + $obj = $barcode->getBarcodeObj( + 'DATAMATRIX', + $content, + -1, -1, 'black', [0,0,0,0] + ); + $obj->setBackgroundColor('white'); + return $obj->getSvgCode(); +} + +/* ---------------- Sheet Template System ---------------- */ +// Default preset: Demco 1.5" x 1.0" on Letter (guess: 5x8 grid, 0.5" margins, 0.125" gaps). +// You can adjust these in the UI and re-preview until alignment is perfect. +$defaults = [ + 'page_width_in' => 8.5, + 'page_height_in' => 11.0, + 'margin_top_in' => 0.5, + 'margin_right_in' => 0.5, + 'margin_bottom_in' => 0.5, + 'margin_left_in' => 0.5, + 'cols' => 5, + 'rows' => 8, + 'label_w_in' => 1.5, + 'label_h_in' => 1.0, + 'gap_h_in' => 0.125, // horizontal gap between columns + 'gap_v_in' => 0.125, // vertical gap between rows + 'barcode_h_in' => 0.30, // barcode height inside 1.0" label + 'font_in' => 0.12, // approx 8.6pt + 'show_outlines' => '1' +]; + +// Pull current template params from POST (template form) or keep defaults +function valf($name, $def) { + return isset($_POST[$name]) && $_POST[$name] !== '' ? $_POST[$name] : $def; +} +$page_width_in = (float) valf('page_width_in', $defaults['page_width_in']); +$page_height_in = (float) valf('page_height_in', $defaults['page_height_in']); +$margin_top_in = (float) valf('margin_top_in', $defaults['margin_top_in']); +$margin_right_in = (float) valf('margin_right_in', $defaults['margin_right_in']); +$margin_bottom_in = (float) valf('margin_bottom_in', $defaults['margin_bottom_in']); +$margin_left_in = (float) valf('margin_left_in', $defaults['margin_left_in']); +$cols = max(1, (int) valf('cols', $defaults['cols'])); +$rows = max(1, (int) valf('rows', $defaults['rows'])); +$label_w_in = (float) valf('label_w_in', $defaults['label_w_in']); +$label_h_in = (float) valf('label_h_in', $defaults['label_h_in']); +$gap_h_in = (float) valf('gap_h_in', $defaults['gap_h_in']); +$gap_v_in = (float) valf('gap_v_in', $defaults['gap_v_in']); +$barcode_h_in = (float) valf('barcode_h_in', $defaults['barcode_h_in']); +$font_in = (float) valf('font_in', $defaults['font_in']); +$show_outlines = isset($_POST['show_outlines']) ? '1' : $defaults['show_outlines']; + +// Records pipeline (single or CSV) +$errors = []; +$records = []; +$isPosted = ($_SERVER['REQUEST_METHOD'] === 'POST'); + +$data1 = $_POST['data1'] ?? ''; +$data2 = $_POST['data2'] ?? ''; +$data3 = $_POST['data3'] ?? ''; +$data4 = $_POST['data4'] ?? ''; +$barcodeText = $_POST['barcode'] ?? ''; + +$mode = $_POST['mode'] ?? ''; + +if ($isPosted && $mode === 'csv') { + if (!isset($_FILES['csvfile']) || !is_uploaded_file($_FILES['csvfile']['tmp_name'])) { + $errors[] = "Please choose a CSV file to upload."; + } else { + $size = $_FILES['csvfile']['size'] ?? 0; + if ($size > 10 * 1024 * 1024) { $errors[] = "CSV too large (max 10MB)."; } + else { $records = read_csv_assoc($_FILES['csvfile']['tmp_name'], $errors); } + } +} elseif ($isPosted && $mode === 'single') { + if ($barcodeText === '') $errors[] = "Please provide a Barcode value."; + else { + $records[] = ['data1'=>$data1,'data2'=>$data2,'data3'=>$data3,'data4'=>$data4,'barcode'=>$barcodeText]; + } +} + +// Compute pagination +$perPage = $cols * $rows; +$pages = []; +if ($records) { + $pages = array_chunk($records, $perPage); +} + +?> + + + + +Label Generator — CSV + Sheet Template + + + + + + +

Label Generator

+

Import CSV and print to a **1.5" × 1.0"** template (Demco) at 100% / Actual size.

+ +
+ + +
+

Single Label

+
+ + + + + + + +
+
+ + +
+
+ + +
+
+ + +
+
+ + +
+
+ + +
+
+
+ + +
+

Data Matrix prints as SVG at in height.

+
+
+ + +
+

Import CSV (data1,data2,data3,data4,barcode)

+
+ + +
+
+ + +
+
+ + + + + +
+ + +
+

Delimiters (comma, tab, semicolon) auto-detected. Headers must match exactly.

+
+
+ + +
+

Template (Demco 1.5" × 1.0")

+
+
+
+
+ +
+
+
+
+ +
+
+ +
+
+ +
+
+ +
+
+ +
+ > + +
+
+ + + + + + + + + +
+ + +
+

+ Tip: Do a test print on plain paper with “Show label outlines” checked. + Hold it behind a real sheet to check alignment, then tweak margins/gaps as needed. +

+
+
+ + + +
+ Issues: + +
+ + + + +
+ + label(s), sheet(s) @ ×. +
+ +
+ $pageRecs): ?> +
+
+ +
+ +
+
+
+
+
+
+
+ +
+ +
+ +
+
+ +
+ + + +
+ Composer autoload not found. Install the barcode library with:
+ composer require tecnickcom/tc-lib-barcode
+ (Make sure BCMath is enabled.) +
+ + +
+ + \ No newline at end of file diff --git a/index.php b/index.php new file mode 100644 index 0000000..92d57d6 --- /dev/null +++ b/index.php @@ -0,0 +1,216 @@ +composer require tecnickcom/tc-lib-barcode in this folder.'; + } elseif ($barcodeText === '') { + $errorMsg = 'Please provide a Barcode value.'; + } else { + try { + $barcode = new Barcode(); + + // Create the data matrix as an SVG + $bobj = $barcode->getBarcodeObj( + 'DATAMATRIX', + $barcodeText, + -1, // width auto + -1, // height auto + 'black', + [0, 0, 0, 0] + ); + $bobj->setBackgroundColor('white'); + $svgBarcode = $bobj->getSvgCode(); + } catch (Throwable $e) { + $errorMsg = 'Barcode generation error: ' . safe($e->getMessage()); + } + } +} +?> + + + + +Spine Label Generator + + + + + +

Spine Label Generator

+ +
+
+ + +
+
+ + +
+
+ + +
+
+ + +
+
+ + +
+
+ +
+

Tip: In the browser print dialog, set scale to 100% / Actual size.

+
+ + +
+ + + +
+
+
+
+
+
+
+
+ +
+ +
+
+
+ + + + \ No newline at end of file diff --git a/vendor/autoload.php b/vendor/autoload.php new file mode 100644 index 0000000..dd25084 --- /dev/null +++ b/vendor/autoload.php @@ -0,0 +1,25 @@ + + * Jordi Boggiano + * + * For the full copyright and license information, please view the LICENSE + * file that was distributed with this source code. + */ + +namespace Composer\Autoload; + +/** + * ClassLoader implements a PSR-0, PSR-4 and classmap class loader. + * + * $loader = new \Composer\Autoload\ClassLoader(); + * + * // register classes with namespaces + * $loader->add('Symfony\Component', __DIR__.'/component'); + * $loader->add('Symfony', __DIR__.'/framework'); + * + * // activate the autoloader + * $loader->register(); + * + * // to enable searching the include path (eg. for PEAR packages) + * $loader->setUseIncludePath(true); + * + * In this example, if you try to use a class in the Symfony\Component + * namespace or one of its children (Symfony\Component\Console for instance), + * the autoloader will first look for the class under the component/ + * directory, and it will then fallback to the framework/ directory if not + * found before giving up. + * + * This class is loosely based on the Symfony UniversalClassLoader. + * + * @author Fabien Potencier + * @author Jordi Boggiano + * @see https://www.php-fig.org/psr/psr-0/ + * @see https://www.php-fig.org/psr/psr-4/ + */ +class ClassLoader +{ + /** @var \Closure(string):void */ + private static $includeFile; + + /** @var string|null */ + private $vendorDir; + + // PSR-4 + /** + * @var array> + */ + private $prefixLengthsPsr4 = array(); + /** + * @var array> + */ + private $prefixDirsPsr4 = array(); + /** + * @var list + */ + private $fallbackDirsPsr4 = array(); + + // PSR-0 + /** + * List of PSR-0 prefixes + * + * Structured as array('F (first letter)' => array('Foo\Bar (full prefix)' => array('path', 'path2'))) + * + * @var array>> + */ + private $prefixesPsr0 = array(); + /** + * @var list + */ + private $fallbackDirsPsr0 = array(); + + /** @var bool */ + private $useIncludePath = false; + + /** + * @var array + */ + private $classMap = array(); + + /** @var bool */ + private $classMapAuthoritative = false; + + /** + * @var array + */ + private $missingClasses = array(); + + /** @var string|null */ + private $apcuPrefix; + + /** + * @var array + */ + private static $registeredLoaders = array(); + + /** + * @param string|null $vendorDir + */ + public function __construct($vendorDir = null) + { + $this->vendorDir = $vendorDir; + self::initializeIncludeClosure(); + } + + /** + * @return array> + */ + public function getPrefixes() + { + if (!empty($this->prefixesPsr0)) { + return call_user_func_array('array_merge', array_values($this->prefixesPsr0)); + } + + return array(); + } + + /** + * @return array> + */ + public function getPrefixesPsr4() + { + return $this->prefixDirsPsr4; + } + + /** + * @return list + */ + public function getFallbackDirs() + { + return $this->fallbackDirsPsr0; + } + + /** + * @return list + */ + public function getFallbackDirsPsr4() + { + return $this->fallbackDirsPsr4; + } + + /** + * @return array Array of classname => path + */ + public function getClassMap() + { + return $this->classMap; + } + + /** + * @param array $classMap Class to filename map + * + * @return void + */ + public function addClassMap(array $classMap) + { + if ($this->classMap) { + $this->classMap = array_merge($this->classMap, $classMap); + } else { + $this->classMap = $classMap; + } + } + + /** + * Registers a set of PSR-0 directories for a given prefix, either + * appending or prepending to the ones previously set for this prefix. + * + * @param string $prefix The prefix + * @param list|string $paths The PSR-0 root directories + * @param bool $prepend Whether to prepend the directories + * + * @return void + */ + public function add($prefix, $paths, $prepend = false) + { + $paths = (array) $paths; + if (!$prefix) { + if ($prepend) { + $this->fallbackDirsPsr0 = array_merge( + $paths, + $this->fallbackDirsPsr0 + ); + } else { + $this->fallbackDirsPsr0 = array_merge( + $this->fallbackDirsPsr0, + $paths + ); + } + + return; + } + + $first = $prefix[0]; + if (!isset($this->prefixesPsr0[$first][$prefix])) { + $this->prefixesPsr0[$first][$prefix] = $paths; + + return; + } + if ($prepend) { + $this->prefixesPsr0[$first][$prefix] = array_merge( + $paths, + $this->prefixesPsr0[$first][$prefix] + ); + } else { + $this->prefixesPsr0[$first][$prefix] = array_merge( + $this->prefixesPsr0[$first][$prefix], + $paths + ); + } + } + + /** + * Registers a set of PSR-4 directories for a given namespace, either + * appending or prepending to the ones previously set for this namespace. + * + * @param string $prefix The prefix/namespace, with trailing '\\' + * @param list|string $paths The PSR-4 base directories + * @param bool $prepend Whether to prepend the directories + * + * @throws \InvalidArgumentException + * + * @return void + */ + public function addPsr4($prefix, $paths, $prepend = false) + { + $paths = (array) $paths; + if (!$prefix) { + // Register directories for the root namespace. + if ($prepend) { + $this->fallbackDirsPsr4 = array_merge( + $paths, + $this->fallbackDirsPsr4 + ); + } else { + $this->fallbackDirsPsr4 = array_merge( + $this->fallbackDirsPsr4, + $paths + ); + } + } elseif (!isset($this->prefixDirsPsr4[$prefix])) { + // Register directories for a new namespace. + $length = strlen($prefix); + if ('\\' !== $prefix[$length - 1]) { + throw new \InvalidArgumentException("A non-empty PSR-4 prefix must end with a namespace separator."); + } + $this->prefixLengthsPsr4[$prefix[0]][$prefix] = $length; + $this->prefixDirsPsr4[$prefix] = $paths; + } elseif ($prepend) { + // Prepend directories for an already registered namespace. + $this->prefixDirsPsr4[$prefix] = array_merge( + $paths, + $this->prefixDirsPsr4[$prefix] + ); + } else { + // Append directories for an already registered namespace. + $this->prefixDirsPsr4[$prefix] = array_merge( + $this->prefixDirsPsr4[$prefix], + $paths + ); + } + } + + /** + * Registers a set of PSR-0 directories for a given prefix, + * replacing any others previously set for this prefix. + * + * @param string $prefix The prefix + * @param list|string $paths The PSR-0 base directories + * + * @return void + */ + public function set($prefix, $paths) + { + if (!$prefix) { + $this->fallbackDirsPsr0 = (array) $paths; + } else { + $this->prefixesPsr0[$prefix[0]][$prefix] = (array) $paths; + } + } + + /** + * Registers a set of PSR-4 directories for a given namespace, + * replacing any others previously set for this namespace. + * + * @param string $prefix The prefix/namespace, with trailing '\\' + * @param list|string $paths The PSR-4 base directories + * + * @throws \InvalidArgumentException + * + * @return void + */ + public function setPsr4($prefix, $paths) + { + if (!$prefix) { + $this->fallbackDirsPsr4 = (array) $paths; + } else { + $length = strlen($prefix); + if ('\\' !== $prefix[$length - 1]) { + throw new \InvalidArgumentException("A non-empty PSR-4 prefix must end with a namespace separator."); + } + $this->prefixLengthsPsr4[$prefix[0]][$prefix] = $length; + $this->prefixDirsPsr4[$prefix] = (array) $paths; + } + } + + /** + * Turns on searching the include path for class files. + * + * @param bool $useIncludePath + * + * @return void + */ + public function setUseIncludePath($useIncludePath) + { + $this->useIncludePath = $useIncludePath; + } + + /** + * Can be used to check if the autoloader uses the include path to check + * for classes. + * + * @return bool + */ + public function getUseIncludePath() + { + return $this->useIncludePath; + } + + /** + * Turns off searching the prefix and fallback directories for classes + * that have not been registered with the class map. + * + * @param bool $classMapAuthoritative + * + * @return void + */ + public function setClassMapAuthoritative($classMapAuthoritative) + { + $this->classMapAuthoritative = $classMapAuthoritative; + } + + /** + * Should class lookup fail if not found in the current class map? + * + * @return bool + */ + public function isClassMapAuthoritative() + { + return $this->classMapAuthoritative; + } + + /** + * APCu prefix to use to cache found/not-found classes, if the extension is enabled. + * + * @param string|null $apcuPrefix + * + * @return void + */ + public function setApcuPrefix($apcuPrefix) + { + $this->apcuPrefix = function_exists('apcu_fetch') && filter_var(ini_get('apc.enabled'), FILTER_VALIDATE_BOOLEAN) ? $apcuPrefix : null; + } + + /** + * The APCu prefix in use, or null if APCu caching is not enabled. + * + * @return string|null + */ + public function getApcuPrefix() + { + return $this->apcuPrefix; + } + + /** + * Registers this instance as an autoloader. + * + * @param bool $prepend Whether to prepend the autoloader or not + * + * @return void + */ + public function register($prepend = false) + { + spl_autoload_register(array($this, 'loadClass'), true, $prepend); + + if (null === $this->vendorDir) { + return; + } + + if ($prepend) { + self::$registeredLoaders = array($this->vendorDir => $this) + self::$registeredLoaders; + } else { + unset(self::$registeredLoaders[$this->vendorDir]); + self::$registeredLoaders[$this->vendorDir] = $this; + } + } + + /** + * Unregisters this instance as an autoloader. + * + * @return void + */ + public function unregister() + { + spl_autoload_unregister(array($this, 'loadClass')); + + if (null !== $this->vendorDir) { + unset(self::$registeredLoaders[$this->vendorDir]); + } + } + + /** + * Loads the given class or interface. + * + * @param string $class The name of the class + * @return true|null True if loaded, null otherwise + */ + public function loadClass($class) + { + if ($file = $this->findFile($class)) { + $includeFile = self::$includeFile; + $includeFile($file); + + return true; + } + + return null; + } + + /** + * Finds the path to the file where the class is defined. + * + * @param string $class The name of the class + * + * @return string|false The path if found, false otherwise + */ + public function findFile($class) + { + // class map lookup + if (isset($this->classMap[$class])) { + return $this->classMap[$class]; + } + if ($this->classMapAuthoritative || isset($this->missingClasses[$class])) { + return false; + } + if (null !== $this->apcuPrefix) { + $file = apcu_fetch($this->apcuPrefix.$class, $hit); + if ($hit) { + return $file; + } + } + + $file = $this->findFileWithExtension($class, '.php'); + + // Search for Hack files if we are running on HHVM + if (false === $file && defined('HHVM_VERSION')) { + $file = $this->findFileWithExtension($class, '.hh'); + } + + if (null !== $this->apcuPrefix) { + apcu_add($this->apcuPrefix.$class, $file); + } + + if (false === $file) { + // Remember that this class does not exist. + $this->missingClasses[$class] = true; + } + + return $file; + } + + /** + * Returns the currently registered loaders keyed by their corresponding vendor directories. + * + * @return array + */ + public static function getRegisteredLoaders() + { + return self::$registeredLoaders; + } + + /** + * @param string $class + * @param string $ext + * @return string|false + */ + private function findFileWithExtension($class, $ext) + { + // PSR-4 lookup + $logicalPathPsr4 = strtr($class, '\\', DIRECTORY_SEPARATOR) . $ext; + + $first = $class[0]; + if (isset($this->prefixLengthsPsr4[$first])) { + $subPath = $class; + while (false !== $lastPos = strrpos($subPath, '\\')) { + $subPath = substr($subPath, 0, $lastPos); + $search = $subPath . '\\'; + if (isset($this->prefixDirsPsr4[$search])) { + $pathEnd = DIRECTORY_SEPARATOR . substr($logicalPathPsr4, $lastPos + 1); + foreach ($this->prefixDirsPsr4[$search] as $dir) { + if (file_exists($file = $dir . $pathEnd)) { + return $file; + } + } + } + } + } + + // PSR-4 fallback dirs + foreach ($this->fallbackDirsPsr4 as $dir) { + if (file_exists($file = $dir . DIRECTORY_SEPARATOR . $logicalPathPsr4)) { + return $file; + } + } + + // PSR-0 lookup + if (false !== $pos = strrpos($class, '\\')) { + // namespaced class name + $logicalPathPsr0 = substr($logicalPathPsr4, 0, $pos + 1) + . strtr(substr($logicalPathPsr4, $pos + 1), '_', DIRECTORY_SEPARATOR); + } else { + // PEAR-like class name + $logicalPathPsr0 = strtr($class, '_', DIRECTORY_SEPARATOR) . $ext; + } + + if (isset($this->prefixesPsr0[$first])) { + foreach ($this->prefixesPsr0[$first] as $prefix => $dirs) { + if (0 === strpos($class, $prefix)) { + foreach ($dirs as $dir) { + if (file_exists($file = $dir . DIRECTORY_SEPARATOR . $logicalPathPsr0)) { + return $file; + } + } + } + } + } + + // PSR-0 fallback dirs + foreach ($this->fallbackDirsPsr0 as $dir) { + if (file_exists($file = $dir . DIRECTORY_SEPARATOR . $logicalPathPsr0)) { + return $file; + } + } + + // PSR-0 include paths. + if ($this->useIncludePath && $file = stream_resolve_include_path($logicalPathPsr0)) { + return $file; + } + + return false; + } + + /** + * @return void + */ + private static function initializeIncludeClosure() + { + if (self::$includeFile !== null) { + return; + } + + /** + * Scope isolated include. + * + * Prevents access to $this/self from included files. + * + * @param string $file + * @return void + */ + self::$includeFile = \Closure::bind(static function($file) { + include $file; + }, null, null); + } +} diff --git a/vendor/composer/InstalledVersions.php b/vendor/composer/InstalledVersions.php new file mode 100644 index 0000000..51e734a --- /dev/null +++ b/vendor/composer/InstalledVersions.php @@ -0,0 +1,359 @@ + + * Jordi Boggiano + * + * For the full copyright and license information, please view the LICENSE + * file that was distributed with this source code. + */ + +namespace Composer; + +use Composer\Autoload\ClassLoader; +use Composer\Semver\VersionParser; + +/** + * This class is copied in every Composer installed project and available to all + * + * See also https://getcomposer.org/doc/07-runtime.md#installed-versions + * + * To require its presence, you can require `composer-runtime-api ^2.0` + * + * @final + */ +class InstalledVersions +{ + /** + * @var mixed[]|null + * @psalm-var array{root: array{name: string, pretty_version: string, version: string, reference: string|null, type: string, install_path: string, aliases: string[], dev: bool}, versions: array}|array{}|null + */ + private static $installed; + + /** + * @var bool|null + */ + private static $canGetVendors; + + /** + * @var array[] + * @psalm-var array}> + */ + private static $installedByVendor = array(); + + /** + * Returns a list of all package names which are present, either by being installed, replaced or provided + * + * @return string[] + * @psalm-return list + */ + public static function getInstalledPackages() + { + $packages = array(); + foreach (self::getInstalled() as $installed) { + $packages[] = array_keys($installed['versions']); + } + + if (1 === \count($packages)) { + return $packages[0]; + } + + return array_keys(array_flip(\call_user_func_array('array_merge', $packages))); + } + + /** + * Returns a list of all package names with a specific type e.g. 'library' + * + * @param string $type + * @return string[] + * @psalm-return list + */ + public static function getInstalledPackagesByType($type) + { + $packagesByType = array(); + + foreach (self::getInstalled() as $installed) { + foreach ($installed['versions'] as $name => $package) { + if (isset($package['type']) && $package['type'] === $type) { + $packagesByType[] = $name; + } + } + } + + return $packagesByType; + } + + /** + * Checks whether the given package is installed + * + * This also returns true if the package name is provided or replaced by another package + * + * @param string $packageName + * @param bool $includeDevRequirements + * @return bool + */ + public static function isInstalled($packageName, $includeDevRequirements = true) + { + foreach (self::getInstalled() as $installed) { + if (isset($installed['versions'][$packageName])) { + return $includeDevRequirements || !isset($installed['versions'][$packageName]['dev_requirement']) || $installed['versions'][$packageName]['dev_requirement'] === false; + } + } + + return false; + } + + /** + * Checks whether the given package satisfies a version constraint + * + * e.g. If you want to know whether version 2.3+ of package foo/bar is installed, you would call: + * + * Composer\InstalledVersions::satisfies(new VersionParser, 'foo/bar', '^2.3') + * + * @param VersionParser $parser Install composer/semver to have access to this class and functionality + * @param string $packageName + * @param string|null $constraint A version constraint to check for, if you pass one you have to make sure composer/semver is required by your package + * @return bool + */ + public static function satisfies(VersionParser $parser, $packageName, $constraint) + { + $constraint = $parser->parseConstraints((string) $constraint); + $provided = $parser->parseConstraints(self::getVersionRanges($packageName)); + + return $provided->matches($constraint); + } + + /** + * Returns a version constraint representing all the range(s) which are installed for a given package + * + * It is easier to use this via isInstalled() with the $constraint argument if you need to check + * whether a given version of a package is installed, and not just whether it exists + * + * @param string $packageName + * @return string Version constraint usable with composer/semver + */ + public static function getVersionRanges($packageName) + { + foreach (self::getInstalled() as $installed) { + if (!isset($installed['versions'][$packageName])) { + continue; + } + + $ranges = array(); + if (isset($installed['versions'][$packageName]['pretty_version'])) { + $ranges[] = $installed['versions'][$packageName]['pretty_version']; + } + if (array_key_exists('aliases', $installed['versions'][$packageName])) { + $ranges = array_merge($ranges, $installed['versions'][$packageName]['aliases']); + } + if (array_key_exists('replaced', $installed['versions'][$packageName])) { + $ranges = array_merge($ranges, $installed['versions'][$packageName]['replaced']); + } + if (array_key_exists('provided', $installed['versions'][$packageName])) { + $ranges = array_merge($ranges, $installed['versions'][$packageName]['provided']); + } + + return implode(' || ', $ranges); + } + + throw new \OutOfBoundsException('Package "' . $packageName . '" is not installed'); + } + + /** + * @param string $packageName + * @return string|null If the package is being replaced or provided but is not really installed, null will be returned as version, use satisfies or getVersionRanges if you need to know if a given version is present + */ + public static function getVersion($packageName) + { + foreach (self::getInstalled() as $installed) { + if (!isset($installed['versions'][$packageName])) { + continue; + } + + if (!isset($installed['versions'][$packageName]['version'])) { + return null; + } + + return $installed['versions'][$packageName]['version']; + } + + throw new \OutOfBoundsException('Package "' . $packageName . '" is not installed'); + } + + /** + * @param string $packageName + * @return string|null If the package is being replaced or provided but is not really installed, null will be returned as version, use satisfies or getVersionRanges if you need to know if a given version is present + */ + public static function getPrettyVersion($packageName) + { + foreach (self::getInstalled() as $installed) { + if (!isset($installed['versions'][$packageName])) { + continue; + } + + if (!isset($installed['versions'][$packageName]['pretty_version'])) { + return null; + } + + return $installed['versions'][$packageName]['pretty_version']; + } + + throw new \OutOfBoundsException('Package "' . $packageName . '" is not installed'); + } + + /** + * @param string $packageName + * @return string|null If the package is being replaced or provided but is not really installed, null will be returned as reference + */ + public static function getReference($packageName) + { + foreach (self::getInstalled() as $installed) { + if (!isset($installed['versions'][$packageName])) { + continue; + } + + if (!isset($installed['versions'][$packageName]['reference'])) { + return null; + } + + return $installed['versions'][$packageName]['reference']; + } + + throw new \OutOfBoundsException('Package "' . $packageName . '" is not installed'); + } + + /** + * @param string $packageName + * @return string|null If the package is being replaced or provided but is not really installed, null will be returned as install path. Packages of type metapackages also have a null install path. + */ + public static function getInstallPath($packageName) + { + foreach (self::getInstalled() as $installed) { + if (!isset($installed['versions'][$packageName])) { + continue; + } + + return isset($installed['versions'][$packageName]['install_path']) ? $installed['versions'][$packageName]['install_path'] : null; + } + + throw new \OutOfBoundsException('Package "' . $packageName . '" is not installed'); + } + + /** + * @return array + * @psalm-return array{name: string, pretty_version: string, version: string, reference: string|null, type: string, install_path: string, aliases: string[], dev: bool} + */ + public static function getRootPackage() + { + $installed = self::getInstalled(); + + return $installed[0]['root']; + } + + /** + * Returns the raw installed.php data for custom implementations + * + * @deprecated Use getAllRawData() instead which returns all datasets for all autoloaders present in the process. getRawData only returns the first dataset loaded, which may not be what you expect. + * @return array[] + * @psalm-return array{root: array{name: string, pretty_version: string, version: string, reference: string|null, type: string, install_path: string, aliases: string[], dev: bool}, versions: array} + */ + public static function getRawData() + { + @trigger_error('getRawData only returns the first dataset loaded, which may not be what you expect. Use getAllRawData() instead which returns all datasets for all autoloaders present in the process.', E_USER_DEPRECATED); + + if (null === self::$installed) { + // only require the installed.php file if this file is loaded from its dumped location, + // and not from its source location in the composer/composer package, see https://github.com/composer/composer/issues/9937 + if (substr(__DIR__, -8, 1) !== 'C') { + self::$installed = include __DIR__ . '/installed.php'; + } else { + self::$installed = array(); + } + } + + return self::$installed; + } + + /** + * Returns the raw data of all installed.php which are currently loaded for custom implementations + * + * @return array[] + * @psalm-return list}> + */ + public static function getAllRawData() + { + return self::getInstalled(); + } + + /** + * Lets you reload the static array from another file + * + * This is only useful for complex integrations in which a project needs to use + * this class but then also needs to execute another project's autoloader in process, + * and wants to ensure both projects have access to their version of installed.php. + * + * A typical case would be PHPUnit, where it would need to make sure it reads all + * the data it needs from this class, then call reload() with + * `require $CWD/vendor/composer/installed.php` (or similar) as input to make sure + * the project in which it runs can then also use this class safely, without + * interference between PHPUnit's dependencies and the project's dependencies. + * + * @param array[] $data A vendor/composer/installed.php data set + * @return void + * + * @psalm-param array{root: array{name: string, pretty_version: string, version: string, reference: string|null, type: string, install_path: string, aliases: string[], dev: bool}, versions: array} $data + */ + public static function reload($data) + { + self::$installed = $data; + self::$installedByVendor = array(); + } + + /** + * @return array[] + * @psalm-return list}> + */ + private static function getInstalled() + { + if (null === self::$canGetVendors) { + self::$canGetVendors = method_exists('Composer\Autoload\ClassLoader', 'getRegisteredLoaders'); + } + + $installed = array(); + + if (self::$canGetVendors) { + foreach (ClassLoader::getRegisteredLoaders() as $vendorDir => $loader) { + if (isset(self::$installedByVendor[$vendorDir])) { + $installed[] = self::$installedByVendor[$vendorDir]; + } elseif (is_file($vendorDir.'/composer/installed.php')) { + /** @var array{root: array{name: string, pretty_version: string, version: string, reference: string|null, type: string, install_path: string, aliases: string[], dev: bool}, versions: array} $required */ + $required = require $vendorDir.'/composer/installed.php'; + $installed[] = self::$installedByVendor[$vendorDir] = $required; + if (null === self::$installed && strtr($vendorDir.'/composer', '\\', '/') === strtr(__DIR__, '\\', '/')) { + self::$installed = $installed[count($installed) - 1]; + } + } + } + } + + if (null === self::$installed) { + // only require the installed.php file if this file is loaded from its dumped location, + // and not from its source location in the composer/composer package, see https://github.com/composer/composer/issues/9937 + if (substr(__DIR__, -8, 1) !== 'C') { + /** @var array{root: array{name: string, pretty_version: string, version: string, reference: string|null, type: string, install_path: string, aliases: string[], dev: bool}, versions: array} $required */ + $required = require __DIR__ . '/installed.php'; + self::$installed = $required; + } else { + self::$installed = array(); + } + } + + if (self::$installed !== array()) { + $installed[] = self::$installed; + } + + return $installed; + } +} diff --git a/vendor/composer/LICENSE b/vendor/composer/LICENSE new file mode 100644 index 0000000..62ecfd8 --- /dev/null +++ b/vendor/composer/LICENSE @@ -0,0 +1,19 @@ +Copyright (c) Nils Adermann, Jordi Boggiano + +Permission is hereby granted, free of charge, to any person obtaining a copy +of this software and associated documentation files (the "Software"), to deal +in the Software without restriction, including without limitation the rights +to use, copy, modify, merge, publish, distribute, sublicense, and/or sell +copies of the Software, and to permit persons to whom the Software is furnished +to do so, subject to the following conditions: + +The above copyright notice and this permission notice shall be included in all +copies or substantial portions of the Software. + +THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR +IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, +FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE +AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER +LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, +OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN +THE SOFTWARE. diff --git a/vendor/composer/autoload_classmap.php b/vendor/composer/autoload_classmap.php new file mode 100644 index 0000000..0fb0a2c --- /dev/null +++ b/vendor/composer/autoload_classmap.php @@ -0,0 +1,10 @@ + $vendorDir . '/composer/InstalledVersions.php', +); diff --git a/vendor/composer/autoload_namespaces.php b/vendor/composer/autoload_namespaces.php new file mode 100644 index 0000000..15a2ff3 --- /dev/null +++ b/vendor/composer/autoload_namespaces.php @@ -0,0 +1,9 @@ + array($vendorDir . '/tecnickcom/tc-lib-color/src'), + 'Com\\Tecnick\\Barcode\\' => array($vendorDir . '/tecnickcom/tc-lib-barcode/src'), +); diff --git a/vendor/composer/autoload_real.php b/vendor/composer/autoload_real.php new file mode 100644 index 0000000..736fd5d --- /dev/null +++ b/vendor/composer/autoload_real.php @@ -0,0 +1,38 @@ +register(true); + + return $loader; + } +} diff --git a/vendor/composer/autoload_static.php b/vendor/composer/autoload_static.php new file mode 100644 index 0000000..19935bd --- /dev/null +++ b/vendor/composer/autoload_static.php @@ -0,0 +1,41 @@ + + array ( + 'Com\\Tecnick\\Color\\' => 18, + 'Com\\Tecnick\\Barcode\\' => 20, + ), + ); + + public static $prefixDirsPsr4 = array ( + 'Com\\Tecnick\\Color\\' => + array ( + 0 => __DIR__ . '/..' . '/tecnickcom/tc-lib-color/src', + ), + 'Com\\Tecnick\\Barcode\\' => + array ( + 0 => __DIR__ . '/..' . '/tecnickcom/tc-lib-barcode/src', + ), + ); + + public static $classMap = array ( + 'Composer\\InstalledVersions' => __DIR__ . '/..' . '/composer/InstalledVersions.php', + ); + + public static function getInitializer(ClassLoader $loader) + { + return \Closure::bind(function () use ($loader) { + $loader->prefixLengthsPsr4 = ComposerStaticInitd5ed540bdb8bd184c88ae0e4cb8f041f::$prefixLengthsPsr4; + $loader->prefixDirsPsr4 = ComposerStaticInitd5ed540bdb8bd184c88ae0e4cb8f041f::$prefixDirsPsr4; + $loader->classMap = ComposerStaticInitd5ed540bdb8bd184c88ae0e4cb8f041f::$classMap; + + }, null, ClassLoader::class); + } +} diff --git a/vendor/composer/installed.json b/vendor/composer/installed.json new file mode 100644 index 0000000..8bbb05a --- /dev/null +++ b/vendor/composer/installed.json @@ -0,0 +1,181 @@ +{ + "packages": [ + { + "name": "tecnickcom/tc-lib-barcode", + "version": "2.4.8", + "version_normalized": "2.4.8.0", + "source": { + "type": "git", + "url": "https://github.com/tecnickcom/tc-lib-barcode.git", + "reference": "f238ffd120d98a34df6573590e7ed02f766a91c4" + }, + "dist": { + "type": "zip", + "url": "https://api.github.com/repos/tecnickcom/tc-lib-barcode/zipball/f238ffd120d98a34df6573590e7ed02f766a91c4", + "reference": "f238ffd120d98a34df6573590e7ed02f766a91c4", + "shasum": "" + }, + "require": { + "ext-bcmath": "*", + "ext-date": "*", + "ext-gd": "*", + "ext-pcre": "*", + "php": ">=8.1", + "tecnickcom/tc-lib-color": "^2.2" + }, + "require-dev": { + "pdepend/pdepend": "2.16.2", + "phpmd/phpmd": "2.15.0", + "phpunit/phpunit": "12.2.0 || 11.5.7 || 10.5.40", + "squizlabs/php_codesniffer": "3.13.0" + }, + "time": "2025-06-06T11:35:02+00:00", + "type": "library", + "installation-source": "dist", + "autoload": { + "psr-4": { + "Com\\Tecnick\\Barcode\\": "src" + } + }, + "notification-url": "https://packagist.org/downloads/", + "license": [ + "LGPL-3.0-or-later" + ], + "authors": [ + { + "name": "Nicola Asuni", + "email": "info@tecnick.com", + "role": "lead" + } + ], + "description": "PHP library to generate linear and bidimensional barcodes", + "homepage": "http://www.tecnick.com", + "keywords": [ + "3 of 9", + "ANSI MH10.8M-1983", + "CBC", + "CODABAR", + "CODE 11", + "CODE 128 A B C", + "CODE 39", + "CODE 93", + "EAN 13", + "EAN 8", + "ECC200", + "ISO IEC 15438 2006", + "ISO IEC 16022", + "ISO IEC 24778 2008", + "Intelligent Mail Barcode", + "Interleaved 2 of 5", + "KIX", + "Klant", + "MSI", + "Onecode", + "PHARMACODE", + "PHARMACODE TWO-TRACKS", + "POSTNET", + "RMS4CC", + "Standard 2 of 5", + "UPC-A", + "UPC-E", + "USD-3", + "USPS-B-3200", + "USS-93", + "aztec", + "barcode", + "datamatrix", + "pdf417", + "planet", + "qr-code", + "royal mail", + "tc-lib-barcode", + "upc" + ], + "support": { + "issues": "https://github.com/tecnickcom/tc-lib-barcode/issues", + "source": "https://github.com/tecnickcom/tc-lib-barcode/tree/2.4.8" + }, + "funding": [ + { + "url": "https://www.paypal.com/donate/?hosted_button_id=NZUEC5XS8MFBJ", + "type": "custom" + } + ], + "install-path": "../tecnickcom/tc-lib-barcode" + }, + { + "name": "tecnickcom/tc-lib-color", + "version": "2.2.13", + "version_normalized": "2.2.13.0", + "source": { + "type": "git", + "url": "https://github.com/tecnickcom/tc-lib-color.git", + "reference": "85d1366fb33813aa521d30e3d7c7d7d82a8103a6" + }, + "dist": { + "type": "zip", + "url": "https://api.github.com/repos/tecnickcom/tc-lib-color/zipball/85d1366fb33813aa521d30e3d7c7d7d82a8103a6", + "reference": "85d1366fb33813aa521d30e3d7c7d7d82a8103a6", + "shasum": "" + }, + "require": { + "ext-pcre": "*", + "php": ">=8.1" + }, + "require-dev": { + "pdepend/pdepend": "2.16.2", + "phpmd/phpmd": "2.15.0", + "phpunit/phpunit": "12.2.0 || 11.5.7 || 10.5.40", + "squizlabs/php_codesniffer": "3.13.0" + }, + "time": "2025-06-06T11:33:19+00:00", + "type": "library", + "installation-source": "dist", + "autoload": { + "psr-4": { + "Com\\Tecnick\\Color\\": "src" + } + }, + "notification-url": "https://packagist.org/downloads/", + "license": [ + "LGPL-3.0-or-later" + ], + "authors": [ + { + "name": "Nicola Asuni", + "email": "info@tecnick.com", + "role": "lead" + } + ], + "description": "PHP library to manipulate various color representations", + "homepage": "http://www.tecnick.com", + "keywords": [ + "cmyk", + "color", + "colors", + "colour", + "colours", + "hsl", + "hsla", + "javascript", + "rgb", + "rgba", + "tc-lib-color", + "web" + ], + "support": { + "issues": "https://github.com/tecnickcom/tc-lib-color/issues", + "source": "https://github.com/tecnickcom/tc-lib-color/tree/2.2.13" + }, + "funding": [ + { + "url": "https://www.paypal.com/donate/?hosted_button_id=NZUEC5XS8MFBJ", + "type": "custom" + } + ], + "install-path": "../tecnickcom/tc-lib-color" + } + ], + "dev": true, + "dev-package-names": [] +} diff --git a/vendor/composer/installed.php b/vendor/composer/installed.php new file mode 100644 index 0000000..02942a0 --- /dev/null +++ b/vendor/composer/installed.php @@ -0,0 +1,41 @@ + array( + 'name' => '__root__', + 'pretty_version' => '1.0.0+no-version-set', + 'version' => '1.0.0.0', + 'reference' => null, + 'type' => 'library', + 'install_path' => __DIR__ . '/../../', + 'aliases' => array(), + 'dev' => true, + ), + 'versions' => array( + '__root__' => array( + 'pretty_version' => '1.0.0+no-version-set', + 'version' => '1.0.0.0', + 'reference' => null, + 'type' => 'library', + 'install_path' => __DIR__ . '/../../', + 'aliases' => array(), + 'dev_requirement' => false, + ), + 'tecnickcom/tc-lib-barcode' => array( + 'pretty_version' => '2.4.8', + 'version' => '2.4.8.0', + 'reference' => 'f238ffd120d98a34df6573590e7ed02f766a91c4', + 'type' => 'library', + 'install_path' => __DIR__ . '/../tecnickcom/tc-lib-barcode', + 'aliases' => array(), + 'dev_requirement' => false, + ), + 'tecnickcom/tc-lib-color' => array( + 'pretty_version' => '2.2.13', + 'version' => '2.2.13.0', + 'reference' => '85d1366fb33813aa521d30e3d7c7d7d82a8103a6', + 'type' => 'library', + 'install_path' => __DIR__ . '/../tecnickcom/tc-lib-color', + 'aliases' => array(), + 'dev_requirement' => false, + ), + ), +); diff --git a/vendor/composer/platform_check.php b/vendor/composer/platform_check.php new file mode 100644 index 0000000..4c3a5d6 --- /dev/null +++ b/vendor/composer/platform_check.php @@ -0,0 +1,26 @@ += 80100)) { + $issues[] = 'Your Composer dependencies require a PHP version ">= 8.1.0". You are running ' . PHP_VERSION . '.'; +} + +if ($issues) { + if (!headers_sent()) { + header('HTTP/1.1 500 Internal Server Error'); + } + if (!ini_get('display_errors')) { + if (PHP_SAPI === 'cli' || PHP_SAPI === 'phpdbg') { + fwrite(STDERR, 'Composer detected issues in your platform:' . PHP_EOL.PHP_EOL . implode(PHP_EOL, $issues) . PHP_EOL.PHP_EOL); + } elseif (!headers_sent()) { + echo 'Composer detected issues in your platform:' . PHP_EOL.PHP_EOL . str_replace('You are running '.PHP_VERSION.'.', '', implode(PHP_EOL, $issues)) . PHP_EOL.PHP_EOL; + } + } + trigger_error( + 'Composer detected issues in your platform: ' . implode(' ', $issues), + E_USER_ERROR + ); +} diff --git a/vendor/tecnickcom/tc-lib-barcode/.editorconfig b/vendor/tecnickcom/tc-lib-barcode/.editorconfig new file mode 100644 index 0000000..f8d1e73 --- /dev/null +++ b/vendor/tecnickcom/tc-lib-barcode/.editorconfig @@ -0,0 +1,20 @@ +# Ref: https://EditorConfig.org + +# top-most EditorConfig file +root = true + +# Unix-style end of lines and a blank line at the end of the file +[*] +indent_style = tab +end_of_line = lf +charset = utf-8 +trim_trailing_whitespace = true +insert_final_newline = true + +[*.php] +indent_style = space +indent_size = 4 + +[*.{js,json,scss,css,yml,vue}] +indent_style = space +indent_size = 2 diff --git a/vendor/tecnickcom/tc-lib-barcode/.github/FUNDING.yml b/vendor/tecnickcom/tc-lib-barcode/.github/FUNDING.yml new file mode 100644 index 0000000..c47c69e --- /dev/null +++ b/vendor/tecnickcom/tc-lib-barcode/.github/FUNDING.yml @@ -0,0 +1 @@ +custom: ['https://www.paypal.com/donate/?hosted_button_id=NZUEC5XS8MFBJ'] diff --git a/vendor/tecnickcom/tc-lib-barcode/.github/ISSUE_TEMPLATE/bug_report.md b/vendor/tecnickcom/tc-lib-barcode/.github/ISSUE_TEMPLATE/bug_report.md new file mode 100644 index 0000000..2c954f9 --- /dev/null +++ b/vendor/tecnickcom/tc-lib-barcode/.github/ISSUE_TEMPLATE/bug_report.md @@ -0,0 +1,29 @@ +--- +name: Bug report +about: Create a report to help us improve +title: '' +labels: '' +assignees: '' + +--- + +**Describe the bug** +A clear and concise description of what the bug is. + +**To Reproduce** +Steps to reproduce the behavior: +1. ... + +**Expected behavior** +A clear and concise description of what you expected to happen. + +**Logs** +If applicable, copy the relevant logs to help explain your problem. + +**Environment:** + - OS: + - PHP version: + - Version: + +**Additional context** +Add any other context about the problem here. diff --git a/vendor/tecnickcom/tc-lib-barcode/.github/ISSUE_TEMPLATE/feature_request.md b/vendor/tecnickcom/tc-lib-barcode/.github/ISSUE_TEMPLATE/feature_request.md new file mode 100644 index 0000000..bbcbbe7 --- /dev/null +++ b/vendor/tecnickcom/tc-lib-barcode/.github/ISSUE_TEMPLATE/feature_request.md @@ -0,0 +1,20 @@ +--- +name: Feature request +about: Suggest an idea for this project +title: '' +labels: '' +assignees: '' + +--- + +**Is your feature request related to a problem? Please describe.** +A clear and concise description of what the problem is. Ex. I'm always frustrated when [...] + +**Describe the solution you'd like** +A clear and concise description of what you want to happen. + +**Describe alternatives you've considered** +A clear and concise description of any alternative solutions or features you've considered. + +**Additional context** +Add any other context or screenshots about the feature request here. diff --git a/vendor/tecnickcom/tc-lib-barcode/.github/pull_request_template.md b/vendor/tecnickcom/tc-lib-barcode/.github/pull_request_template.md new file mode 100644 index 0000000..776ebc0 --- /dev/null +++ b/vendor/tecnickcom/tc-lib-barcode/.github/pull_request_template.md @@ -0,0 +1,25 @@ +# Description + +Please include a summary of the change and include relevant motivation and context. + +... + + +## Checklist: + +- [ ] The `make buildall` command has been run successfully without any error or warning. +- [ ] Any new code line is covered by unit tests and the coverage has not dropped. +- [ ] Any new code follows the style guidelines of this project. +- [ ] The code changes have been self-reviewed. +- [ ] Corresponding changes to the documentation have been made. +- [ ] The version has been updated in the VERSION file. + +## Type of change: + +- [ ] Bug fix (non-breaking change which fixes an issue) → The patch number in the VERSION file has been increased. +- [ ] New feature (non-breaking change which adds functionality) → The minor number in the VERSION file has been increased. +- [ ] Breaking change (fix or feature that would cause existing functionality to not work as expected) → The major number in the VERSION file has been increased. +- [ ] Automation. +- [ ] Documentation. +- [ ] Example. +- [ ] Testing. diff --git a/vendor/tecnickcom/tc-lib-barcode/.github/workflows/check.yml b/vendor/tecnickcom/tc-lib-barcode/.github/workflows/check.yml new file mode 100644 index 0000000..cd4a163 --- /dev/null +++ b/vendor/tecnickcom/tc-lib-barcode/.github/workflows/check.yml @@ -0,0 +1,56 @@ +name: check + +env: + XDEBUG_MODE: coverage + +permissions: + contents: read + +on: + push: + branches: + - 'main' + pull_request: + types: [opened, synchronize, reopened] + branches: + - main + +jobs: + test-php: + name: Test on php ${{ matrix.php-version }} and ${{ matrix.os }} + runs-on: ${{ matrix.os }} + continue-on-error: ${{ matrix.experimental }} + strategy: + fail-fast: false + matrix: + php-version: ["8.1", "8.2", "8.3", "8.4"] + experimental: [false] + os: [ubuntu-latest] + coverage-extension: [xdebug] + steps: + - uses: actions/checkout@v4 + - name: Use php ${{ matrix.php-version }} + uses: shivammathur/setup-php@v2 + with: + php-version: ${{ matrix.php-version }} + coverage: ${{ matrix.coverage-extension }} + extensions: xdebug, bcmath, curl, date, gd, hash, imagick, json, mbstring, openssl, pcre, zlib + ini-values: display_errors=on, error_reporting=-1, zend.assertions=1 + - name: List php modules + run: php -m + - name: List php modules using "no php ini" mode + run: php -m -n + - name: Cache module + uses: actions/cache@v4 + with: + path: ~/.composer/cache/ + key: composer-cache + - name: Install dependencies + run: make deps + - name: Run all tests + run: make qa + - name: Send coverage + uses: codecov/codecov-action@v5 + with: + flags: php-${{ matrix.php-version }}-${{ matrix.os }} + name: php-${{ matrix.php-version }}-${{ matrix.os }} diff --git a/vendor/tecnickcom/tc-lib-barcode/.gitignore b/vendor/tecnickcom/tc-lib-barcode/.gitignore new file mode 100644 index 0000000..4dd7d5e --- /dev/null +++ b/vendor/tecnickcom/tc-lib-barcode/.gitignore @@ -0,0 +1,20 @@ +**/*.bak +**/*.tmp +**/.#* +**/.DS_Store +**/._* +**/.idea +**/.vagrant +**/auth.json +**/nbproject +**/temp.php +**/test.php +.phpdoc +.phpunit.cache +.phpunit.result.cache +composer.lock +ecs.php +phpunit.xml +rector.php +target +vendor diff --git a/vendor/tecnickcom/tc-lib-barcode/CODEOWNERS b/vendor/tecnickcom/tc-lib-barcode/CODEOWNERS new file mode 100644 index 0000000..302fbf3 --- /dev/null +++ b/vendor/tecnickcom/tc-lib-barcode/CODEOWNERS @@ -0,0 +1 @@ +* @nicolaasuni diff --git a/vendor/tecnickcom/tc-lib-barcode/CODE_OF_CONDUCT.md b/vendor/tecnickcom/tc-lib-barcode/CODE_OF_CONDUCT.md new file mode 100644 index 0000000..18c9147 --- /dev/null +++ b/vendor/tecnickcom/tc-lib-barcode/CODE_OF_CONDUCT.md @@ -0,0 +1,128 @@ +# Contributor Covenant Code of Conduct + +## Our Pledge + +We as members, contributors, and leaders pledge to make participation in our +community a harassment-free experience for everyone, regardless of age, body +size, visible or invisible disability, ethnicity, sex characteristics, gender +identity and expression, level of experience, education, socio-economic status, +nationality, personal appearance, race, religion, or sexual identity +and orientation. + +We pledge to act and interact in ways that contribute to an open, welcoming, +diverse, inclusive, and healthy community. + +## Our Standards + +Examples of behavior that contributes to a positive environment for our +community include: + +* Demonstrating empathy and kindness toward other people +* Being respectful of differing opinions, viewpoints, and experiences +* Giving and gracefully accepting constructive feedback +* Accepting responsibility and apologizing to those affected by our mistakes, + and learning from the experience +* Focusing on what is best not just for us as individuals, but for the + overall community + +Examples of unacceptable behavior include: + +* The use of sexualized language or imagery, and sexual attention or + advances of any kind +* Trolling, insulting or derogatory comments, and personal or political attacks +* Public or private harassment +* Publishing others' private information, such as a physical or email + address, without their explicit permission +* Other conduct which could reasonably be considered inappropriate in a + professional setting + +## Enforcement Responsibilities + +Community leaders are responsible for clarifying and enforcing our standards of +acceptable behavior and will take appropriate and fair corrective action in +response to any behavior that they deem inappropriate, threatening, offensive, +or harmful. + +Community leaders have the right and responsibility to remove, edit, or reject +comments, commits, code, wiki edits, issues, and other contributions that are +not aligned to this Code of Conduct, and will communicate reasons for moderation +decisions when appropriate. + +## Scope + +This Code of Conduct applies within all community spaces, and also applies when +an individual is officially representing the community in public spaces. +Examples of representing our community include using an official e-mail address, +posting via an official social media account, or acting as an appointed +representative at an online or offline event. + +## Enforcement + +Instances of abusive, harassing, or otherwise unacceptable behavior may be +reported to the community leaders responsible for enforcement at +. +All complaints will be reviewed and investigated promptly and fairly. + +All community leaders are obligated to respect the privacy and security of the +reporter of any incident. + +## Enforcement Guidelines + +Community leaders will follow these Community Impact Guidelines in determining +the consequences for any action they deem in violation of this Code of Conduct: + +### 1. Correction + +**Community Impact**: Use of inappropriate language or other behavior deemed +unprofessional or unwelcome in the community. + +**Consequence**: A private, written warning from community leaders, providing +clarity around the nature of the violation and an explanation of why the +behavior was inappropriate. A public apology may be requested. + +### 2. Warning + +**Community Impact**: A violation through a single incident or series +of actions. + +**Consequence**: A warning with consequences for continued behavior. No +interaction with the people involved, including unsolicited interaction with +those enforcing the Code of Conduct, for a specified period of time. This +includes avoiding interactions in community spaces as well as external channels +like social media. Violating these terms may lead to a temporary or +permanent ban. + +### 3. Temporary Ban + +**Community Impact**: A serious violation of community standards, including +sustained inappropriate behavior. + +**Consequence**: A temporary ban from any sort of interaction or public +communication with the community for a specified period of time. No public or +private interaction with the people involved, including unsolicited interaction +with those enforcing the Code of Conduct, is allowed during this period. +Violating these terms may lead to a permanent ban. + +### 4. Permanent Ban + +**Community Impact**: Demonstrating a pattern of violation of community +standards, including sustained inappropriate behavior, harassment of an +individual, or aggression toward or disparagement of classes of individuals. + +**Consequence**: A permanent ban from any sort of public interaction within +the community. + +## Attribution + +This Code of Conduct is adapted from the [Contributor Covenant][homepage], +version 2.0, available at +https://www.contributor-covenant.org/version/2/0/code_of_conduct.html. + +Community Impact Guidelines were inspired by [Mozilla's code of conduct +enforcement ladder](https://github.com/mozilla/diversity). + +[homepage]: https://www.contributor-covenant.org + +For answers to common questions about this code of conduct, see the FAQ at +https://www.contributor-covenant.org/faq. Translations are available at +https://www.contributor-covenant.org/translations. diff --git a/vendor/tecnickcom/tc-lib-barcode/CONTRIBUTING.md b/vendor/tecnickcom/tc-lib-barcode/CONTRIBUTING.md new file mode 100644 index 0000000..db2739c --- /dev/null +++ b/vendor/tecnickcom/tc-lib-barcode/CONTRIBUTING.md @@ -0,0 +1,26 @@ +# How to Contribute + + +## Reporting a bug + +* **Do not open up a GitHub issue if the bug is a security vulnerability**, and instead to refer to our [Security policy](SECURITY.md). + +* Ensure the bug was not already reported by searching on GitHub Issues. + +* If you're unable to find an open issue addressing the problem, open a new one. Be sure to include a **title and clear description**, as much relevant information as possible, and a **code sample** or an **executable test case** demonstrating the expected behavior that is not occurring. + + +## Submitting a bug fix + +* Open a new GitHub pull request with the patch. + +* Ensure the PR description clearly describes the problem and solution. Include the relevant issue number if applicable. + +* Ensure the new code is following the existing conventions and the unit test coverage is 100%. + +* Before submitting, please run the following command locally to ensure the code is passing the automatic checks: `make buildall`. + + +## Add a new feature or change an existing one + +* Before writing any code please suggest the change by opening a new Feature Request on Issues. diff --git a/vendor/tecnickcom/tc-lib-barcode/LICENSE b/vendor/tecnickcom/tc-lib-barcode/LICENSE new file mode 100644 index 0000000..4c17a03 --- /dev/null +++ b/vendor/tecnickcom/tc-lib-barcode/LICENSE @@ -0,0 +1,862 @@ +********************************************************************** +* LICENSE +* +* SOFTWARE : tc-lib-barcode +* AUTHOR : Nicola Asuni +* COPYRIGHT : 2001-2025 Nicola Asuni - Tecnick.com LTD +********************************************************************** + + This is free software: you can redistribute it and/or modify it + under the terms of the GNU Lesser General Public License as + published by the Free Software Foundation, either version 3 of the + License, or (at your option) any later version. + +********************************************************************** +********************************************************************** + + GNU LESSER GENERAL PUBLIC LICENSE + Version 3, 29 June 2007 + + Copyright (C) 2007 Free Software Foundation, Inc. + Everyone is permitted to copy and distribute verbatim copies + of this license document, but changing it is not allowed. + + + This version of the GNU Lesser General Public License incorporates +the terms and conditions of version 3 of the GNU General Public +License, supplemented by the additional permissions listed below. + + 0. Additional Definitions. + + As used herein, "this License" refers to version 3 of the GNU Lesser +General Public License, and the "GNU GPL" refers to version 3 of the GNU +General Public License. + + "The Library" refers to a covered work governed by this License, +other than an Application or a Combined Work as defined below. + + An "Application" is any work that makes use of an interface provided +by the Library, but which is not otherwise based on the Library. +Defining a subclass of a class defined by the Library is deemed a mode +of using an interface provided by the Library. + + A "Combined Work" is a work produced by combining or linking an +Application with the Library. The particular version of the Library +with which the Combined Work was made is also called the "Linked +Version". + + The "Minimal Corresponding Source" for a Combined Work means the +Corresponding Source for the Combined Work, excluding any source code +for portions of the Combined Work that, considered in isolation, are +based on the Application, and not on the Linked Version. + + The "Corresponding Application Code" for a Combined Work means the +object code and/or source code for the Application, including any data +and utility programs needed for reproducing the Combined Work from the +Application, but excluding the System Libraries of the Combined Work. + + 1. Exception to Section 3 of the GNU GPL. + + You may convey a covered work under sections 3 and 4 of this License +without being bound by section 3 of the GNU GPL. + + 2. Conveying Modified Versions. + + If you modify a copy of the Library, and, in your modifications, a +facility refers to a function or data to be supplied by an Application +that uses the facility (other than as an argument passed when the +facility is invoked), then you may convey a copy of the modified +version: + + a) under this License, provided that you make a good faith effort to + ensure that, in the event an Application does not supply the + function or data, the facility still operates, and performs + whatever part of its purpose remains meaningful, or + + b) under the GNU GPL, with none of the additional permissions of + this License applicable to that copy. + + 3. Object Code Incorporating Material from Library Header Files. + + The object code form of an Application may incorporate material from +a header file that is part of the Library. You may convey such object +code under terms of your choice, provided that, if the incorporated +material is not limited to numerical parameters, data structure +layouts and accessors, or small macros, inline functions and templates +(ten or fewer lines in length), you do both of the following: + + a) Give prominent notice with each copy of the object code that the + Library is used in it and that the Library and its use are + covered by this License. + + b) Accompany the object code with a copy of the GNU GPL and this license + document. + + 4. Combined Works. + + You may convey a Combined Work under terms of your choice that, +taken together, effectively do not restrict modification of the +portions of the Library contained in the Combined Work and reverse +engineering for debugging such modifications, if you also do each of +the following: + + a) Give prominent notice with each copy of the Combined Work that + the Library is used in it and that the Library and its use are + covered by this License. + + b) Accompany the Combined Work with a copy of the GNU GPL and this license + document. + + c) For a Combined Work that displays copyright notices during + execution, include the copyright notice for the Library among + these notices, as well as a reference directing the user to the + copies of the GNU GPL and this license document. + + d) Do one of the following: + + 0) Convey the Minimal Corresponding Source under the terms of this + License, and the Corresponding Application Code in a form + suitable for, and under terms that permit, the user to + recombine or relink the Application with a modified version of + the Linked Version to produce a modified Combined Work, in the + manner specified by section 6 of the GNU GPL for conveying + Corresponding Source. + + 1) Use a suitable shared library mechanism for linking with the + Library. A suitable mechanism is one that (a) uses at run time + a copy of the Library already present on the user's computer + system, and (b) will operate properly with a modified version + of the Library that is interface-compatible with the Linked + Version. + + e) Provide Installation Information, but only if you would otherwise + be required to provide such information under section 6 of the + GNU GPL, and only to the extent that such information is + necessary to install and execute a modified version of the + Combined Work produced by recombining or relinking the + Application with a modified version of the Linked Version. (If + you use option 4d0, the Installation Information must accompany + the Minimal Corresponding Source and Corresponding Application + Code. If you use option 4d1, you must provide the Installation + Information in the manner specified by section 6 of the GNU GPL + for conveying Corresponding Source.) + + 5. Combined Libraries. + + You may place library facilities that are a work based on the +Library side by side in a single library together with other library +facilities that are not Applications and are not covered by this +License, and convey such a combined library under terms of your +choice, if you do both of the following: + + a) Accompany the combined library with a copy of the same work based + on the Library, uncombined with any other library facilities, + conveyed under the terms of this License. + + b) Give prominent notice with the combined library that part of it + is a work based on the Library, and explaining where to find the + accompanying uncombined form of the same work. + + 6. Revised Versions of the GNU Lesser General Public License. + + The Free Software Foundation may publish revised and/or new versions +of the GNU Lesser General Public License from time to time. Such new +versions will be similar in spirit to the present version, but may +differ in detail to address new problems or concerns. + + Each version is given a distinguishing version number. If the +Library as you received it specifies that a certain numbered version +of the GNU Lesser General Public License "or any later version" +applies to it, you have the option of following the terms and +conditions either of that published version or of any later version +published by the Free Software Foundation. If the Library as you +received it does not specify a version number of the GNU Lesser +General Public License, you may choose any version of the GNU Lesser +General Public License ever published by the Free Software Foundation. + + If the Library as you received it specifies that a proxy can decide +whether future versions of the GNU Lesser General Public License shall +apply, that proxy's public statement of acceptance of any version is +permanent authorization for you to choose that version for the +Library. + +********************************************************************** +********************************************************************** + + GNU GENERAL PUBLIC LICENSE + Version 3, 29 June 2007 + + Copyright (C) 2007 Free Software Foundation, Inc. + Everyone is permitted to copy and distribute verbatim copies + of this license document, but changing it is not allowed. + + Preamble + + The GNU General Public License is a free, copyleft license for +software and other kinds of works. + + The licenses for most software and other practical works are designed +to take away your freedom to share and change the works. By contrast, +the GNU General Public License is intended to guarantee your freedom to +share and change all versions of a program--to make sure it remains free +software for all its users. We, the Free Software Foundation, use the +GNU General Public License for most of our software; it applies also to +any other work released this way by its authors. You can apply it to +your programs, too. + + When we speak of free software, we are referring to freedom, not +price. Our General Public Licenses are designed to make sure that you +have the freedom to distribute copies of free software (and charge for +them if you wish), that you receive source code or can get it if you +want it, that you can change the software or use pieces of it in new +free programs, and that you know you can do these things. + + To protect your rights, we need to prevent others from denying you +these rights or asking you to surrender the rights. Therefore, you have +certain responsibilities if you distribute copies of the software, or if +you modify it: responsibilities to respect the freedom of others. + + For example, if you distribute copies of such a program, whether +gratis or for a fee, you must pass on to the recipients the same +freedoms that you received. You must make sure that they, too, receive +or can get the source code. And you must show them these terms so they +know their rights. + + Developers that use the GNU GPL protect your rights with two steps: +(1) assert copyright on the software, and (2) offer you this License +giving you legal permission to copy, distribute and/or modify it. + + For the developers' and authors' protection, the GPL clearly explains +that there is no warranty for this free software. For both users' and +authors' sake, the GPL requires that modified versions be marked as +changed, so that their problems will not be attributed erroneously to +authors of previous versions. + + Some devices are designed to deny users access to install or run +modified versions of the software inside them, although the manufacturer +can do so. This is fundamentally incompatible with the aim of +protecting users' freedom to change the software. The systematic +pattern of such abuse occurs in the area of products for individuals to +use, which is precisely where it is most unacceptable. Therefore, we +have designed this version of the GPL to prohibit the practice for those +products. If such problems arise substantially in other domains, we +stand ready to extend this provision to those domains in future versions +of the GPL, as needed to protect the freedom of users. + + Finally, every program is threatened constantly by software patents. +States should not allow patents to restrict development and use of +software on general-purpose computers, but in those that do, we wish to +avoid the special danger that patents applied to a free program could +make it effectively proprietary. To prevent this, the GPL assures that +patents cannot be used to render the program non-free. + + The precise terms and conditions for copying, distribution and +modification follow. + + TERMS AND CONDITIONS + + 0. Definitions. + + "This License" refers to version 3 of the GNU General Public License. + + "Copyright" also means copyright-like laws that apply to other kinds of +works, such as semiconductor masks. + + "The Program" refers to any copyrightable work licensed under this +License. Each licensee is addressed as "you". "Licensees" and +"recipients" may be individuals or organizations. + + To "modify" a work means to copy from or adapt all or part of the work +in a fashion requiring copyright permission, other than the making of an +exact copy. The resulting work is called a "modified version" of the +earlier work or a work "based on" the earlier work. + + A "covered work" means either the unmodified Program or a work based +on the Program. + + To "propagate" a work means to do anything with it that, without +permission, would make you directly or secondarily liable for +infringement under applicable copyright law, except executing it on a +computer or modifying a private copy. Propagation includes copying, +distribution (with or without modification), making available to the +public, and in some countries other activities as well. + + To "convey" a work means any kind of propagation that enables other +parties to make or receive copies. Mere interaction with a user through +a computer network, with no transfer of a copy, is not conveying. + + An interactive user interface displays "Appropriate Legal Notices" +to the extent that it includes a convenient and prominently visible +feature that (1) displays an appropriate copyright notice, and (2) +tells the user that there is no warranty for the work (except to the +extent that warranties are provided), that licensees may convey the +work under this License, and how to view a copy of this License. If +the interface presents a list of user commands or options, such as a +menu, a prominent item in the list meets this criterion. + + 1. Source Code. + + The "source code" for a work means the preferred form of the work +for making modifications to it. "Object code" means any non-source +form of a work. + + A "Standard Interface" means an interface that either is an official +standard defined by a recognized standards body, or, in the case of +interfaces specified for a particular programming language, one that +is widely used among developers working in that language. + + The "System Libraries" of an executable work include anything, other +than the work as a whole, that (a) is included in the normal form of +packaging a Major Component, but which is not part of that Major +Component, and (b) serves only to enable use of the work with that +Major Component, or to implement a Standard Interface for which an +implementation is available to the public in source code form. A +"Major Component", in this context, means a major essential component +(kernel, window system, and so on) of the specific operating system +(if any) on which the executable work runs, or a compiler used to +produce the work, or an object code interpreter used to run it. + + The "Corresponding Source" for a work in object code form means all +the source code needed to generate, install, and (for an executable +work) run the object code and to modify the work, including scripts to +control those activities. However, it does not include the work's +System Libraries, or general-purpose tools or generally available free +programs which are used unmodified in performing those activities but +which are not part of the work. For example, Corresponding Source +includes interface definition files associated with source files for +the work, and the source code for shared libraries and dynamically +linked subprograms that the work is specifically designed to require, +such as by intimate data communication or control flow between those +subprograms and other parts of the work. + + The Corresponding Source need not include anything that users +can regenerate automatically from other parts of the Corresponding +Source. + + The Corresponding Source for a work in source code form is that +same work. + + 2. Basic Permissions. + + All rights granted under this License are granted for the term of +copyright on the Program, and are irrevocable provided the stated +conditions are met. This License explicitly affirms your unlimited +permission to run the unmodified Program. The output from running a +covered work is covered by this License only if the output, given its +content, constitutes a covered work. This License acknowledges your +rights of fair use or other equivalent, as provided by copyright law. + + You may make, run and propagate covered works that you do not +convey, without conditions so long as your license otherwise remains +in force. You may convey covered works to others for the sole purpose +of having them make modifications exclusively for you, or provide you +with facilities for running those works, provided that you comply with +the terms of this License in conveying all material for which you do +not control copyright. Those thus making or running the covered works +for you must do so exclusively on your behalf, under your direction +and control, on terms that prohibit them from making any copies of +your copyrighted material outside their relationship with you. + + Conveying under any other circumstances is permitted solely under +the conditions stated below. Sublicensing is not allowed; section 10 +makes it unnecessary. + + 3. Protecting Users' Legal Rights From Anti-Circumvention Law. + + No covered work shall be deemed part of an effective technological +measure under any applicable law fulfilling obligations under article +11 of the WIPO copyright treaty adopted on 20 December 1996, or +similar laws prohibiting or restricting circumvention of such +measures. + + When you convey a covered work, you waive any legal power to forbid +circumvention of technological measures to the extent such circumvention +is effected by exercising rights under this License with respect to +the covered work, and you disclaim any intention to limit operation or +modification of the work as a means of enforcing, against the work's +users, your or third parties' legal rights to forbid circumvention of +technological measures. + + 4. Conveying Verbatim Copies. + + You may convey verbatim copies of the Program's source code as you +receive it, in any medium, provided that you conspicuously and +appropriately publish on each copy an appropriate copyright notice; +keep intact all notices stating that this License and any +non-permissive terms added in accord with section 7 apply to the code; +keep intact all notices of the absence of any warranty; and give all +recipients a copy of this License along with the Program. + + You may charge any price or no price for each copy that you convey, +and you may offer support or warranty protection for a fee. + + 5. Conveying Modified Source Versions. + + You may convey a work based on the Program, or the modifications to +produce it from the Program, in the form of source code under the +terms of section 4, provided that you also meet all of these conditions: + + a) The work must carry prominent notices stating that you modified + it, and giving a relevant date. + + b) The work must carry prominent notices stating that it is + released under this License and any conditions added under section + 7. This requirement modifies the requirement in section 4 to + "keep intact all notices". + + c) You must license the entire work, as a whole, under this + License to anyone who comes into possession of a copy. This + License will therefore apply, along with any applicable section 7 + additional terms, to the whole of the work, and all its parts, + regardless of how they are packaged. This License gives no + permission to license the work in any other way, but it does not + invalidate such permission if you have separately received it. + + d) If the work has interactive user interfaces, each must display + Appropriate Legal Notices; however, if the Program has interactive + interfaces that do not display Appropriate Legal Notices, your + work need not make them do so. + + A compilation of a covered work with other separate and independent +works, which are not by their nature extensions of the covered work, +and which are not combined with it such as to form a larger program, +in or on a volume of a storage or distribution medium, is called an +"aggregate" if the compilation and its resulting copyright are not +used to limit the access or legal rights of the compilation's users +beyond what the individual works permit. Inclusion of a covered work +in an aggregate does not cause this License to apply to the other +parts of the aggregate. + + 6. Conveying Non-Source Forms. + + You may convey a covered work in object code form under the terms +of sections 4 and 5, provided that you also convey the +machine-readable Corresponding Source under the terms of this License, +in one of these ways: + + a) Convey the object code in, or embodied in, a physical product + (including a physical distribution medium), accompanied by the + Corresponding Source fixed on a durable physical medium + customarily used for software interchange. + + b) Convey the object code in, or embodied in, a physical product + (including a physical distribution medium), accompanied by a + written offer, valid for at least three years and valid for as + long as you offer spare parts or customer support for that product + model, to give anyone who possesses the object code either (1) a + copy of the Corresponding Source for all the software in the + product that is covered by this License, on a durable physical + medium customarily used for software interchange, for a price no + more than your reasonable cost of physically performing this + conveying of source, or (2) access to copy the + Corresponding Source from a network server at no charge. + + c) Convey individual copies of the object code with a copy of the + written offer to provide the Corresponding Source. This + alternative is allowed only occasionally and noncommercially, and + only if you received the object code with such an offer, in accord + with subsection 6b. + + d) Convey the object code by offering access from a designated + place (gratis or for a charge), and offer equivalent access to the + Corresponding Source in the same way through the same place at no + further charge. You need not require recipients to copy the + Corresponding Source along with the object code. If the place to + copy the object code is a network server, the Corresponding Source + may be on a different server (operated by you or a third party) + that supports equivalent copying facilities, provided you maintain + clear directions next to the object code saying where to find the + Corresponding Source. Regardless of what server hosts the + Corresponding Source, you remain obligated to ensure that it is + available for as long as needed to satisfy these requirements. + + e) Convey the object code using peer-to-peer transmission, provided + you inform other peers where the object code and Corresponding + Source of the work are being offered to the general public at no + charge under subsection 6d. + + A separable portion of the object code, whose source code is excluded +from the Corresponding Source as a System Library, need not be +included in conveying the object code work. + + A "User Product" is either (1) a "consumer product", which means any +tangible personal property which is normally used for personal, family, +or household purposes, or (2) anything designed or sold for incorporation +into a dwelling. In determining whether a product is a consumer product, +doubtful cases shall be resolved in favor of coverage. For a particular +product received by a particular user, "normally used" refers to a +typical or common use of that class of product, regardless of the status +of the particular user or of the way in which the particular user +actually uses, or expects or is expected to use, the product. A product +is a consumer product regardless of whether the product has substantial +commercial, industrial or non-consumer uses, unless such uses represent +the only significant mode of use of the product. + + "Installation Information" for a User Product means any methods, +procedures, authorization keys, or other information required to install +and execute modified versions of a covered work in that User Product from +a modified version of its Corresponding Source. The information must +suffice to ensure that the continued functioning of the modified object +code is in no case prevented or interfered with solely because +modification has been made. + + If you convey an object code work under this section in, or with, or +specifically for use in, a User Product, and the conveying occurs as +part of a transaction in which the right of possession and use of the +User Product is transferred to the recipient in perpetuity or for a +fixed term (regardless of how the transaction is characterized), the +Corresponding Source conveyed under this section must be accompanied +by the Installation Information. But this requirement does not apply +if neither you nor any third party retains the ability to install +modified object code on the User Product (for example, the work has +been installed in ROM). + + The requirement to provide Installation Information does not include a +requirement to continue to provide support service, warranty, or updates +for a work that has been modified or installed by the recipient, or for +the User Product in which it has been modified or installed. Access to a +network may be denied when the modification itself materially and +adversely affects the operation of the network or violates the rules and +protocols for communication across the network. + + Corresponding Source conveyed, and Installation Information provided, +in accord with this section must be in a format that is publicly +documented (and with an implementation available to the public in +source code form), and must require no special password or key for +unpacking, reading or copying. + + 7. Additional Terms. + + "Additional permissions" are terms that supplement the terms of this +License by making exceptions from one or more of its conditions. +Additional permissions that are applicable to the entire Program shall +be treated as though they were included in this License, to the extent +that they are valid under applicable law. If additional permissions +apply only to part of the Program, that part may be used separately +under those permissions, but the entire Program remains governed by +this License without regard to the additional permissions. + + When you convey a copy of a covered work, you may at your option +remove any additional permissions from that copy, or from any part of +it. (Additional permissions may be written to require their own +removal in certain cases when you modify the work.) You may place +additional permissions on material, added by you to a covered work, +for which you have or can give appropriate copyright permission. + + Notwithstanding any other provision of this License, for material you +add to a covered work, you may (if authorized by the copyright holders of +that material) supplement the terms of this License with terms: + + a) Disclaiming warranty or limiting liability differently from the + terms of sections 15 and 16 of this License; or + + b) Requiring preservation of specified reasonable legal notices or + author attributions in that material or in the Appropriate Legal + Notices displayed by works containing it; or + + c) Prohibiting misrepresentation of the origin of that material, or + requiring that modified versions of such material be marked in + reasonable ways as different from the original version; or + + d) Limiting the use for publicity purposes of names of licensors or + authors of the material; or + + e) Declining to grant rights under trademark law for use of some + trade names, trademarks, or service marks; or + + f) Requiring indemnification of licensors and authors of that + material by anyone who conveys the material (or modified versions of + it) with contractual assumptions of liability to the recipient, for + any liability that these contractual assumptions directly impose on + those licensors and authors. + + All other non-permissive additional terms are considered "further +restrictions" within the meaning of section 10. If the Program as you +received it, or any part of it, contains a notice stating that it is +governed by this License along with a term that is a further +restriction, you may remove that term. If a license document contains +a further restriction but permits relicensing or conveying under this +License, you may add to a covered work material governed by the terms +of that license document, provided that the further restriction does +not survive such relicensing or conveying. + + If you add terms to a covered work in accord with this section, you +must place, in the relevant source files, a statement of the +additional terms that apply to those files, or a notice indicating +where to find the applicable terms. + + Additional terms, permissive or non-permissive, may be stated in the +form of a separately written license, or stated as exceptions; +the above requirements apply either way. + + 8. Termination. + + You may not propagate or modify a covered work except as expressly +provided under this License. Any attempt otherwise to propagate or +modify it is void, and will automatically terminate your rights under +this License (including any patent licenses granted under the third +paragraph of section 11). + + However, if you cease all violation of this License, then your +license from a particular copyright holder is reinstated (a) +provisionally, unless and until the copyright holder explicitly and +finally terminates your license, and (b) permanently, if the copyright +holder fails to notify you of the violation by some reasonable means +prior to 60 days after the cessation. + + Moreover, your license from a particular copyright holder is +reinstated permanently if the copyright holder notifies you of the +violation by some reasonable means, this is the first time you have +received notice of violation of this License (for any work) from that +copyright holder, and you cure the violation prior to 30 days after +your receipt of the notice. + + Termination of your rights under this section does not terminate the +licenses of parties who have received copies or rights from you under +this License. If your rights have been terminated and not permanently +reinstated, you do not qualify to receive new licenses for the same +material under section 10. + + 9. Acceptance Not Required for Having Copies. + + You are not required to accept this License in order to receive or +run a copy of the Program. Ancillary propagation of a covered work +occurring solely as a consequence of using peer-to-peer transmission +to receive a copy likewise does not require acceptance. However, +nothing other than this License grants you permission to propagate or +modify any covered work. These actions infringe copyright if you do +not accept this License. Therefore, by modifying or propagating a +covered work, you indicate your acceptance of this License to do so. + + 10. Automatic Licensing of Downstream Recipients. + + Each time you convey a covered work, the recipient automatically +receives a license from the original licensors, to run, modify and +propagate that work, subject to this License. You are not responsible +for enforcing compliance by third parties with this License. + + An "entity transaction" is a transaction transferring control of an +organization, or substantially all assets of one, or subdividing an +organization, or merging organizations. If propagation of a covered +work results from an entity transaction, each party to that +transaction who receives a copy of the work also receives whatever +licenses to the work the party's predecessor in interest had or could +give under the previous paragraph, plus a right to possession of the +Corresponding Source of the work from the predecessor in interest, if +the predecessor has it or can get it with reasonable efforts. + + You may not impose any further restrictions on the exercise of the +rights granted or affirmed under this License. For example, you may +not impose a license fee, royalty, or other charge for exercise of +rights granted under this License, and you may not initiate litigation +(including a cross-claim or counterclaim in a lawsuit) alleging that +any patent claim is infringed by making, using, selling, offering for +sale, or importing the Program or any portion of it. + + 11. Patents. + + A "contributor" is a copyright holder who authorizes use under this +License of the Program or a work on which the Program is based. The +work thus licensed is called the contributor's "contributor version". + + A contributor's "essential patent claims" are all patent claims +owned or controlled by the contributor, whether already acquired or +hereafter acquired, that would be infringed by some manner, permitted +by this License, of making, using, or selling its contributor version, +but do not include claims that would be infringed only as a +consequence of further modification of the contributor version. For +purposes of this definition, "control" includes the right to grant +patent sublicenses in a manner consistent with the requirements of +this License. + + Each contributor grants you a non-exclusive, worldwide, royalty-free +patent license under the contributor's essential patent claims, to +make, use, sell, offer for sale, import and otherwise run, modify and +propagate the contents of its contributor version. + + In the following three paragraphs, a "patent license" is any express +agreement or commitment, however denominated, not to enforce a patent +(such as an express permission to practice a patent or covenant not to +sue for patent infringement). To "grant" such a patent license to a +party means to make such an agreement or commitment not to enforce a +patent against the party. + + If you convey a covered work, knowingly relying on a patent license, +and the Corresponding Source of the work is not available for anyone +to copy, free of charge and under the terms of this License, through a +publicly available network server or other readily accessible means, +then you must either (1) cause the Corresponding Source to be so +available, or (2) arrange to deprive yourself of the benefit of the +patent license for this particular work, or (3) arrange, in a manner +consistent with the requirements of this License, to extend the patent +license to downstream recipients. "Knowingly relying" means you have +actual knowledge that, but for the patent license, your conveying the +covered work in a country, or your recipient's use of the covered work +in a country, would infringe one or more identifiable patents in that +country that you have reason to believe are valid. + + If, pursuant to or in connection with a single transaction or +arrangement, you convey, or propagate by procuring conveyance of, a +covered work, and grant a patent license to some of the parties +receiving the covered work authorizing them to use, propagate, modify +or convey a specific copy of the covered work, then the patent license +you grant is automatically extended to all recipients of the covered +work and works based on it. + + A patent license is "discriminatory" if it does not include within +the scope of its coverage, prohibits the exercise of, or is +conditioned on the non-exercise of one or more of the rights that are +specifically granted under this License. You may not convey a covered +work if you are a party to an arrangement with a third party that is +in the business of distributing software, under which you make payment +to the third party based on the extent of your activity of conveying +the work, and under which the third party grants, to any of the +parties who would receive the covered work from you, a discriminatory +patent license (a) in connection with copies of the covered work +conveyed by you (or copies made from those copies), or (b) primarily +for and in connection with specific products or compilations that +contain the covered work, unless you entered into that arrangement, +or that patent license was granted, prior to 28 March 2007. + + Nothing in this License shall be construed as excluding or limiting +any implied license or other defenses to infringement that may +otherwise be available to you under applicable patent law. + + 12. No Surrender of Others' Freedom. + + If conditions are imposed on you (whether by court order, agreement or +otherwise) that contradict the conditions of this License, they do not +excuse you from the conditions of this License. If you cannot convey a +covered work so as to satisfy simultaneously your obligations under this +License and any other pertinent obligations, then as a consequence you may +not convey it at all. For example, if you agree to terms that obligate you +to collect a royalty for further conveying from those to whom you convey +the Program, the only way you could satisfy both those terms and this +License would be to refrain entirely from conveying the Program. + + 13. Use with the GNU Affero General Public License. + + Notwithstanding any other provision of this License, you have +permission to link or combine any covered work with a work licensed +under version 3 of the GNU Affero General Public License into a single +combined work, and to convey the resulting work. The terms of this +License will continue to apply to the part which is the covered work, +but the special requirements of the GNU Affero General Public License, +section 13, concerning interaction through a network will apply to the +combination as such. + + 14. Revised Versions of this License. + + The Free Software Foundation may publish revised and/or new versions of +the GNU General Public License from time to time. Such new versions will +be similar in spirit to the present version, but may differ in detail to +address new problems or concerns. + + Each version is given a distinguishing version number. If the +Program specifies that a certain numbered version of the GNU General +Public License "or any later version" applies to it, you have the +option of following the terms and conditions either of that numbered +version or of any later version published by the Free Software +Foundation. If the Program does not specify a version number of the +GNU General Public License, you may choose any version ever published +by the Free Software Foundation. + + If the Program specifies that a proxy can decide which future +versions of the GNU General Public License can be used, that proxy's +public statement of acceptance of a version permanently authorizes you +to choose that version for the Program. + + Later license versions may give you additional or different +permissions. However, no additional obligations are imposed on any +author or copyright holder as a result of your choosing to follow a +later version. + + 15. Disclaimer of Warranty. + + THERE IS NO WARRANTY FOR THE PROGRAM, TO THE EXTENT PERMITTED BY +APPLICABLE LAW. EXCEPT WHEN OTHERWISE STATED IN WRITING THE COPYRIGHT +HOLDERS AND/OR OTHER PARTIES PROVIDE THE PROGRAM "AS IS" WITHOUT WARRANTY +OF ANY KIND, EITHER EXPRESSED OR IMPLIED, INCLUDING, BUT NOT LIMITED TO, +THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR +PURPOSE. THE ENTIRE RISK AS TO THE QUALITY AND PERFORMANCE OF THE PROGRAM +IS WITH YOU. SHOULD THE PROGRAM PROVE DEFECTIVE, YOU ASSUME THE COST OF +ALL NECESSARY SERVICING, REPAIR OR CORRECTION. + + 16. Limitation of Liability. + + IN NO EVENT UNLESS REQUIRED BY APPLICABLE LAW OR AGREED TO IN WRITING +WILL ANY COPYRIGHT HOLDER, OR ANY OTHER PARTY WHO MODIFIES AND/OR CONVEYS +THE PROGRAM AS PERMITTED ABOVE, BE LIABLE TO YOU FOR DAMAGES, INCLUDING ANY +GENERAL, SPECIAL, INCIDENTAL OR CONSEQUENTIAL DAMAGES ARISING OUT OF THE +USE OR INABILITY TO USE THE PROGRAM (INCLUDING BUT NOT LIMITED TO LOSS OF +DATA OR DATA BEING RENDERED INACCURATE OR LOSSES SUSTAINED BY YOU OR THIRD +PARTIES OR A FAILURE OF THE PROGRAM TO OPERATE WITH ANY OTHER PROGRAMS), +EVEN IF SUCH HOLDER OR OTHER PARTY HAS BEEN ADVISED OF THE POSSIBILITY OF +SUCH DAMAGES. + + 17. Interpretation of Sections 15 and 16. + + If the disclaimer of warranty and limitation of liability provided +above cannot be given local legal effect according to their terms, +reviewing courts shall apply local law that most closely approximates +an absolute waiver of all civil liability in connection with the +Program, unless a warranty or assumption of liability accompanies a +copy of the Program in return for a fee. + + END OF TERMS AND CONDITIONS + + How to Apply These Terms to Your New Programs + + If you develop a new program, and you want it to be of the greatest +possible use to the public, the best way to achieve this is to make it +free software which everyone can redistribute and change under these terms. + + To do so, attach the following notices to the program. It is safest +to attach them to the start of each source file to most effectively +state the exclusion of warranty; and each file should have at least +the "copyright" line and a pointer to where the full notice is found. + + + Copyright (C) + + This program is free software: you can redistribute it and/or modify + it under the terms of the GNU General Public License as published by + the Free Software Foundation, either version 3 of the License, or + (at your option) any later version. + + This program is distributed in the hope that it will be useful, + but WITHOUT ANY WARRANTY; without even the implied warranty of + MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the + GNU General Public License for more details. + + You should have received a copy of the GNU General Public License + along with this program. If not, see . + +Also add information on how to contact you by electronic and paper mail. + + If the program does terminal interaction, make it output a short +notice like this when it starts in an interactive mode: + + Copyright (C) + This program comes with ABSOLUTELY NO WARRANTY; for details type `show w'. + This is free software, and you are welcome to redistribute it + under certain conditions; type `show c' for details. + +The hypothetical commands `show w' and `show c' should show the appropriate +parts of the General Public License. Of course, your program's commands +might be different; for a GUI interface, you would use an "about box". + + You should also get your employer (if you work as a programmer) or school, +if any, to sign a "copyright disclaimer" for the program, if necessary. +For more information on this, and how to apply and follow the GNU GPL, see +. + + The GNU General Public License does not permit incorporating your program +into proprietary programs. If your program is a subroutine library, you +may consider it more useful to permit linking proprietary applications with +the library. If this is what you want to do, use the GNU Lesser General +Public License instead of this License. But first, please read +. + +********************************************************************** +********************************************************************** diff --git a/vendor/tecnickcom/tc-lib-barcode/Makefile b/vendor/tecnickcom/tc-lib-barcode/Makefile new file mode 100644 index 0000000..6403e7d --- /dev/null +++ b/vendor/tecnickcom/tc-lib-barcode/Makefile @@ -0,0 +1,275 @@ +# makefile +# +# @since 2015-02-21 +# @category Library +# @package Barcode +# @author Nicola Asuni +# @copyright 2015-2024 Nicola Asuni - Tecnick.com LTD +# @license http://www.gnu.org/copyleft/lesser.html GNU-LGPL v3 (see LICENSE) +# @link https://github.com/tecnickcom/tc-lib-barcode +# +# This file is part of tc-lib-barcode software library. +# ---------------------------------------------------------------------------------------------------------------------- + +SHELL=/bin/bash +.SHELLFLAGS=-o pipefail -c + +# Project owner +OWNER=tecnickcom + +# Project vendor +VENDOR=${OWNER} + +# Project name +PROJECT=tc-lib-barcode + +# Project version +VERSION=$(shell cat VERSION) + +# Project release number (packaging build number) +RELEASE=$(shell cat RELEASE) + +# Name of RPM or DEB package +PKGNAME=php-${OWNER}-${PROJECT} + +# Data dir +DATADIR=usr/share + +# PHP home folder +PHPHOME=${DATADIR}/php/Com/Tecnick + +# Default installation path for code +LIBPATH=${PHPHOME}/Barcode/ + +# Path for configuration files (etc/$(PKGNAME)/) +CONFIGPATH= + +# Default installation path for documentation +DOCPATH=${DATADIR}/doc/$(PKGNAME)/ + +# Installation path for the code +PATHINSTBIN=$(DESTDIR)/$(LIBPATH) + +# Installation path for the configuration files +PATHINSTCFG=$(DESTDIR)/$(CONFIGPATH) + +# Installation path for documentation +PATHINSTDOC=$(DESTDIR)/$(DOCPATH) + +# Current directory +CURRENTDIR=$(dir $(realpath $(firstword $(MAKEFILE_LIST)))) + +# Target directory +TARGETDIR=$(CURRENTDIR)target + +# RPM Packaging path (where RPMs will be stored) +PATHRPMPKG=$(TARGETDIR)/RPM + +# DEB Packaging path (where DEBs will be stored) +PATHDEBPKG=$(TARGETDIR)/DEB + +# BZ2 Packaging path (where BZ2s will be stored) +PATHBZ2PKG=$(TARGETDIR)/BZ2 + +# Default port number for the example server +PORT?=8000 + +# PHP binary +PHP=$(shell which php) + +# Composer executable (disable APC to as a work-around of a bug) +COMPOSER=$(PHP) -d "apc.enable_cli=0" $(shell which composer) + +# phpDocumentor executable file +PHPDOC=$(shell which phpDocumentor) + +# --- MAKE TARGETS --- + +# Display general help about this command +.PHONY: help +help: + @echo "" + @echo "$(PROJECT) Makefile." + @echo "The following commands are available:" + @echo "" + @echo " make buildall : Build and test everything from scratch" + @echo " make bz2 : Package the library in a compressed bz2 archive" + @echo " make clean : Delete the vendor and target directories" + @echo " make codefix : Fix code style violations" + @echo " make deb : Build a DEB package for Debian-like Linux distributions" + @echo " make deps : Download all dependencies" + @echo " make doc : Generate source code documentation" + @echo " make lint : Test source code for coding standard violations" + @echo " make qa : Run all tests and reports" + @echo " make report : Generate various reports" + @echo " make rpm : Build an RPM package for RedHat-like Linux distributions" + @echo " make server : Start the development server" + @echo " make test : Run unit tests" + @echo "" + @echo "To test and build everything from scratch:" + @echo "make buildall" + @echo "" + +# alias for help target +.PHONY: all +all: help + +# Full build and test sequence +.PHONY: x +x: buildall + +# Full build and test sequence +.PHONY: buildall +buildall: deps codefix qa bz2 rpm deb + +# Package the library in a compressed bz2 archive +.PHONY: bz2 +bz2: + rm -rf $(PATHBZ2PKG) + make install DESTDIR=$(PATHBZ2PKG) + tar -jcvf $(PATHBZ2PKG)/$(PKGNAME)-$(VERSION)-$(RELEASE).tbz2 -C $(PATHBZ2PKG) $(DATADIR) + +# Delete the vendor and target directories +.PHONY: clean +clean: + rm -rf ./vendor $(TARGETDIR) + +# Fix code style violations +.PHONY: codefix +codefix: + ./vendor/bin/phpcbf --ignore="./vendor/" --standard=psr12 src test + +# Build a DEB package for Debian-like Linux distributions +.PHONY: deb +deb: + rm -rf $(PATHDEBPKG) + make install DESTDIR=$(PATHDEBPKG)/$(PKGNAME)-$(VERSION) + rm -f $(PATHDEBPKG)/$(PKGNAME)-$(VERSION)/$(DOCPATH)LICENSE + tar -zcvf $(PATHDEBPKG)/$(PKGNAME)_$(VERSION).orig.tar.gz -C $(PATHDEBPKG)/ $(PKGNAME)-$(VERSION) + cp -rf ./resources/debian $(PATHDEBPKG)/$(PKGNAME)-$(VERSION)/debian + find $(PATHDEBPKG)/$(PKGNAME)-$(VERSION)/debian/ -type f -exec sed -i "s/~#DATE#~/`date -R`/" {} \; + find $(PATHDEBPKG)/$(PKGNAME)-$(VERSION)/debian/ -type f -exec sed -i "s/~#VENDOR#~/$(VENDOR)/" {} \; + find $(PATHDEBPKG)/$(PKGNAME)-$(VERSION)/debian/ -type f -exec sed -i "s/~#PROJECT#~/$(PROJECT)/" {} \; + find $(PATHDEBPKG)/$(PKGNAME)-$(VERSION)/debian/ -type f -exec sed -i "s/~#PKGNAME#~/$(PKGNAME)/" {} \; + find $(PATHDEBPKG)/$(PKGNAME)-$(VERSION)/debian/ -type f -exec sed -i "s/~#VERSION#~/$(VERSION)/" {} \; + find $(PATHDEBPKG)/$(PKGNAME)-$(VERSION)/debian/ -type f -exec sed -i "s/~#RELEASE#~/$(RELEASE)/" {} \; + echo $(LIBPATH) > $(PATHDEBPKG)/$(PKGNAME)-$(VERSION)/debian/$(PKGNAME).dirs + echo "$(LIBPATH)* $(LIBPATH)" > $(PATHDEBPKG)/$(PKGNAME)-$(VERSION)/debian/install + echo $(DOCPATH) >> $(PATHDEBPKG)/$(PKGNAME)-$(VERSION)/debian/$(PKGNAME).dirs + echo "$(DOCPATH)* $(DOCPATH)" >> $(PATHDEBPKG)/$(PKGNAME)-$(VERSION)/debian/install +ifneq ($(strip $(CONFIGPATH)),) + echo $(CONFIGPATH) >> $(PATHDEBPKG)/$(PKGNAME)-$(VERSION)/debian/$(PKGNAME).dirs + echo "$(CONFIGPATH)* $(CONFIGPATH)" >> $(PATHDEBPKG)/$(PKGNAME)-$(VERSION)/debian/install +endif + echo "new-package-should-close-itp-bug" > $(PATHDEBPKG)/$(PKGNAME)-$(VERSION)/debian/$(PKGNAME).lintian-overrides + cd $(PATHDEBPKG)/$(PKGNAME)-$(VERSION) && debuild -us -uc + +# Clean all artifacts and download all dependencies +.PHONY: deps +deps: ensuretarget + rm -rf ./vendor/* + ($(COMPOSER) install -vvv --no-interaction) + curl --silent --show-error --fail --location --output ./vendor/phpstan.phar https://github.com/phpstan/phpstan/releases/download/2.1.2/phpstan.phar \ + && chmod +x ./vendor/phpstan.phar + +# Generate source code documentation +.PHONY: doc +doc: ensuretarget + rm -rf $(TARGETDIR)/doc + $(PHPDOC) -d ./src -t $(TARGETDIR)/doc/ + +# Create missing target directories for test and build artifacts +.PHONY: ensuretarget +ensuretarget: + mkdir -p $(TARGETDIR)/test + mkdir -p $(TARGETDIR)/report + mkdir -p $(TARGETDIR)/doc + +# Install this application +.PHONY: install +install: uninstall + mkdir -p $(PATHINSTBIN) + cp -rf ./src/* $(PATHINSTBIN) + cp -f ./resources/autoload.php $(PATHINSTBIN) + find $(PATHINSTBIN) -type d -exec chmod 755 {} \; + find $(PATHINSTBIN) -type f -exec chmod 644 {} \; + mkdir -p $(PATHINSTDOC) + cp -f ./LICENSE $(PATHINSTDOC) + cp -f ./README.md $(PATHINSTDOC) + cp -f ./VERSION $(PATHINSTDOC) + cp -f ./RELEASE $(PATHINSTDOC) + chmod -R 644 $(PATHINSTDOC)* +ifneq ($(strip $(CONFIGPATH)),) + mkdir -p $(PATHINSTCFG) + touch -c $(PATHINSTCFG)* + cp -ru ./resources/${CONFIGPATH}* $(PATHINSTCFG) + find $(PATHINSTCFG) -type d -exec chmod 755 {} \; + find $(PATHINSTCFG) -type f -exec chmod 644 {} \; +endif + +# Test source code for coding standard violations +.PHONY: lint +lint: + ./vendor/bin/phpcs --ignore="./vendor/" --standard=phpcs.xml src test + ./vendor/bin/phpmd src text codesize,unusedcode,naming,design --exclude */vendor/* + ./vendor/bin/phpmd test text unusedcode,naming,design --exclude */vendor/* + php -r 'exit((int)version_compare(PHP_MAJOR_VERSION, "7", ">"));' || ./vendor/phpstan.phar analyse + +# Run all tests and reports +.PHONY: qa +qa: ensuretarget lint test report + +# Generate various reports +.PHONY: report +report: ensuretarget + ./vendor/bin/pdepend --jdepend-xml=$(TARGETDIR)/report/dependencies.xml --summary-xml=$(TARGETDIR)/report/metrics.xml --jdepend-chart=$(TARGETDIR)/report/dependecies.svg --overview-pyramid=$(TARGETDIR)/report/overview-pyramid.svg --ignore=vendor ./src + #./vendor/bartlett/php-compatinfo/bin/phpcompatinfo --no-ansi analyser:run src/ > $(TARGETDIR)/report/phpcompatinfo.txt + +# Build the RPM package for RedHat-like Linux distributions +.PHONY: rpm +rpm: + rm -rf $(PATHRPMPKG) + rpmbuild \ + --define "_topdir $(PATHRPMPKG)" \ + --define "_vendor $(VENDOR)" \ + --define "_owner $(OWNER)" \ + --define "_project $(PROJECT)" \ + --define "_package $(PKGNAME)" \ + --define "_version $(VERSION)" \ + --define "_release $(RELEASE)" \ + --define "_current_directory $(CURRENTDIR)" \ + --define "_libpath /$(LIBPATH)" \ + --define "_docpath /$(DOCPATH)" \ + --define "_configpath /$(CONFIGPATH)" \ + -bb resources/rpm/rpm.spec + +# Start the development server +.PHONY: server +server: + $(PHP) -t example -S localhost:$(PORT) + +# Tag this GIT version +.PHONY: tag +tag: + git checkout main && \ + git tag -a ${VERSION} -m "Release ${VERSION}" && \ + git push origin --tags && \ + git pull + +# Run unit tests +.PHONY: test +test: + cp phpunit.xml.dist phpunit.xml + #./vendor/bin/phpunit --migrate-configuration || true + XDEBUG_MODE=coverage ./vendor/bin/phpunit --stderr test + +# Remove all installed files +.PHONY: uninstall +uninstall: + rm -rf $(PATHINSTBIN) + rm -rf $(PATHINSTDOC) + +# Increase the version patch number +.PHONY: versionup +versionup: + echo ${VERSION} | gawk -F. '{printf("%d.%d.%d\n",$$1,$$2,(($$3+1)));}' > VERSION diff --git a/vendor/tecnickcom/tc-lib-barcode/README.md b/vendor/tecnickcom/tc-lib-barcode/README.md new file mode 100644 index 0000000..1bd9d55 --- /dev/null +++ b/vendor/tecnickcom/tc-lib-barcode/README.md @@ -0,0 +1,176 @@ +# tc-lib-barcode +*PHP barcode library* + +[![Latest Stable Version](https://poser.pugx.org/tecnickcom/tc-lib-barcode/version)](https://packagist.org/packages/tecnickcom/tc-lib-barcode) +![Build](https://github.com/tecnickcom/tc-lib-barcode/actions/workflows/check.yml/badge.svg) +[![Coverage](https://codecov.io/gh/tecnickcom/tc-lib-barcode/graph/badge.svg?token=PW6r97iVuW)](https://codecov.io/gh/tecnickcom/tc-lib-barcode) +[![License](https://poser.pugx.org/tecnickcom/tc-lib-barcode/license)](https://packagist.org/packages/tecnickcom/tc-lib-barcode) +[![Downloads](https://poser.pugx.org/tecnickcom/tc-lib-barcode/downloads)](https://packagist.org/packages/tecnickcom/tc-lib-barcode) + +[![Donate via PayPal](https://img.shields.io/badge/donate-paypal-87ceeb.svg)](https://www.paypal.com/donate/?hosted_button_id=NZUEC5XS8MFBJ) +*Please consider supporting this project by making a donation via [PayPal](https://www.paypal.com/donate/?hosted_button_id=NZUEC5XS8MFBJ)* + +* **category** Library +* **package** \Com\Tecnick\Barcode +* **author** Nicola Asuni +* **copyright** 2001-2025 Nicola Asuni - Tecnick.com LTD +* **license** http://www.gnu.org/copyleft/lesser.html GNU-LGPL v3 (see LICENSE.TXT) +* **link** https://github.com/tecnickcom/tc-lib-barcode +* **SRC DOC** https://tcpdf.org/docs/srcdoc/tc-lib-barcode + +## Description + +This library includes utility PHP classes to generate linear and bidimensional barcodes: + +* C39 : CODE 39 - ANSI MH10.8M-1983 - USD-3 - 3 of 9 +* C39+ : CODE 39 with checksum +* C39E : CODE 39 EXTENDED +* C39E+ : CODE 39 EXTENDED + CHECKSUM +* C93 : CODE 93 - USS-93 +* S25 : Standard 2 of 5 +* S25+ : Standard 2 of 5 + CHECKSUM +* I25 : Interleaved 2 of 5 +* I25+ : Interleaved 2 of 5 + CHECKSUM +* C128 : CODE 128 +* C128A : CODE 128 A +* C128B : CODE 128 B +* C128C : CODE 128 C +* EAN2 : 2-Digits UPC-Based Extension +* EAN5 : 5-Digits UPC-Based Extension +* EAN8 : EAN 8 +* EAN13 : EAN 13 +* UPCA : UPC-A +* UPCE : UPC-E +* MSI : MSI (Variation of Plessey code) +* MSI+ : MSI + CHECKSUM (modulo 11) +* POSTNET : POSTNET +* PLANET : PLANET +* RMS4CC : RMS4CC (Royal Mail 4-state Customer Code) - CBC (Customer Bar Code) +* KIX : KIX (Klant index - Customer index) +* IMB : IMB - Intelligent Mail Barcode - Onecode - USPS-B-3200 +* IMBPRE : IMB - Intelligent Mail Barcode - Onecode - USPS-B-3200- pre-processed +* CODABAR : CODABAR +* CODE11 : CODE 11 +* PHARMA : PHARMACODE +* PHARMA2T : PHARMACODE TWO-TRACKS +* AZTEC : AZTEC Code (ISO/IEC 24778:2008) +* DATAMATRIX : DATAMATRIX (ISO/IEC 16022) +* PDF417 : PDF417 (ISO/IEC 15438:2006) +* QRCODE : QR-CODE +* RAW : 2D RAW MODE comma-separated rows +* RAW2 : 2D RAW MODE rows enclosed in square parentheses + +### Output Formats + +* PNG Image +* SVG Image +* HTML DIV +* Unicode String +* Binary String + +The initial source code has been derived from [TCPDF](). + + +## Getting started + +First, you need to install all development dependencies using [Composer](https://getcomposer.org/): + +```bash +$ curl -sS https://getcomposer.org/installer | php +$ mv composer.phar /usr/local/bin/composer +``` + +This project include a Makefile that allows you to test and build the project with simple commands. +To see all available options: + +```bash +make help +``` + +To install all the development dependencies: + +```bash +make deps +``` + +## Running all tests + +Before committing the code, please check if it passes all tests using + +```bash +make qa +``` + +All artifacts are generated in the target directory. + + +## Examples + +Examples are located in the `example` directory. + +Start a development server (requires PHP 8.0+) using the command: + +``` +make server +``` + +and point your browser to + + +### Simple Code Example + +Please check example/index.php for a full example. + +``` +// instantiate the barcode class +$barcode = new \Com\Tecnick\Barcode\Barcode(); + +// generate a barcode +$bobj = $barcode->getBarcodeObj( + 'QRCODE,H', // barcode type and additional comma-separated parameters + 'https://tecnick.com', // data string to encode + -4, // bar width (use absolute or negative value as multiplication factor) + -4, // bar height (use absolute or negative value as multiplication factor) + 'black', // foreground color + array(-2, -2, -2, -2) // padding (use absolute or negative values as multiplication factors) + )->setBackgroundColor('white'); // background color + +// output the barcode as HTML div (see other output formats in the documentation and examples) +echo $bobj->getHtmlDiv(); +``` + + +## Installation + +Create a composer.json in your projects root-directory: + +```json +{ + "require": { + "tecnickcom/tc-lib-barcode": "^2.3" + } +} +``` + +Or add to an existing project with: + +```bash +composer require tecnickcom/tc-lib-barcode ^2.3 +``` + +## Packaging + +This library is mainly intended to be used and included in other PHP projects using Composer. +However, since some production environments dictates the installation of any application as RPM or DEB packages, +this library includes make targets for building these packages (`make rpm` and `make deb`). +The packages are generated under the `target` directory. + +When this library is installed using an RPM or DEB package, you can use it your code by including the autoloader: +```php +require_once ('/usr/share/php/Com/Tecnick/Barcode/autoload.php'); +``` + + +## Developer(s) Contact + +* Nicola Asuni diff --git a/vendor/tecnickcom/tc-lib-barcode/RELEASE b/vendor/tecnickcom/tc-lib-barcode/RELEASE new file mode 100644 index 0000000..573541a --- /dev/null +++ b/vendor/tecnickcom/tc-lib-barcode/RELEASE @@ -0,0 +1 @@ +0 diff --git a/vendor/tecnickcom/tc-lib-barcode/SECURITY.md b/vendor/tecnickcom/tc-lib-barcode/SECURITY.md new file mode 100644 index 0000000..6150279 --- /dev/null +++ b/vendor/tecnickcom/tc-lib-barcode/SECURITY.md @@ -0,0 +1,5 @@ +# Security Policy + +## Reporting a Vulnerability + +Please report (suspected) security vulnerabilities to info@tecnick.com. diff --git a/vendor/tecnickcom/tc-lib-barcode/VERSION b/vendor/tecnickcom/tc-lib-barcode/VERSION new file mode 100644 index 0000000..f041bc6 --- /dev/null +++ b/vendor/tecnickcom/tc-lib-barcode/VERSION @@ -0,0 +1 @@ +2.4.8 diff --git a/vendor/tecnickcom/tc-lib-barcode/composer.json b/vendor/tecnickcom/tc-lib-barcode/composer.json new file mode 100644 index 0000000..1b2344c --- /dev/null +++ b/vendor/tecnickcom/tc-lib-barcode/composer.json @@ -0,0 +1,79 @@ +{ + "name": "tecnickcom/tc-lib-barcode", + "description": "PHP library to generate linear and bidimensional barcodes", + "type": "library", + "homepage": "http://www.tecnick.com", + "license": "LGPL-3.0-or-later", + "keywords": [ + "3 of 9", + "ANSI MH10.8M-1983", + "AZTEC", + "barcode", + "CBC", + "CODABAR", + "CODE 11", + "CODE 128 A B C", + "CODE 39", + "CODE 93", + "Datamatrix", + "EAN 13", + "EAN 8", + "ECC200", + "Intelligent Mail Barcode", + "Interleaved 2 of 5", + "ISO IEC 15438 2006", + "ISO IEC 16022", + "ISO IEC 24778 2008", + "KIX", + "Klant", + "MSI", + "Onecode", + "PDF417", + "PHARMACODE TWO-TRACKS", + "PHARMACODE", + "PLANET", + "POSTNET", + "QR-Code", + "RMS4CC", + "Royal Mail", + "Standard 2 of 5", + "tc-lib-barcode", + "UPC-A", + "UPC-E", + "UPC", + "USD-3", + "USPS-B-3200", + "USS-93" + ], + "authors": [ + { + "name": "Nicola Asuni", + "email": "info@tecnick.com", + "role": "lead" + } + ], + "require": { + "php": ">=8.1", + "ext-bcmath": "*", + "ext-date": "*", + "ext-gd": "*", + "ext-pcre": "*", + "tecnickcom/tc-lib-color": "^2.2" + }, + "require-dev": { + "pdepend/pdepend": "2.16.2", + "phpmd/phpmd": "2.15.0", + "phpunit/phpunit": "12.2.0 || 11.5.7 || 10.5.40", + "squizlabs/php_codesniffer": "3.13.0" + }, + "autoload": { + "psr-4": { + "Com\\Tecnick\\Barcode\\": "src" + } + }, + "autoload-dev": { + "psr-4": { + "Test\\": "test" + } + } +} diff --git a/vendor/tecnickcom/tc-lib-barcode/example/index.php b/vendor/tecnickcom/tc-lib-barcode/example/index.php new file mode 100644 index 0000000..821027f --- /dev/null +++ b/vendor/tecnickcom/tc-lib-barcode/example/index.php @@ -0,0 +1,121 @@ + + * @copyright 2015-2024 Nicola Asuni - Tecnick.com LTD + * @license http://www.gnu.org/copyleft/lesser.html GNU-LGPL v3 (see LICENSE.TXT) + * @link https://github.com/tecnickcom/tc-lib-barcode + * + * This file is part of tc-lib-barcode software library. + */ + +// autoloader when using Composer +require(__DIR__ . '/../vendor/autoload.php'); + +// autoloader when using RPM or DEB package installation +//require ('/usr/share/php/Com/Tecnick/Barcode/autoload.php'); + +// data to generate for each barcode type +$linear = [ + 'C128A' => ['0123456789', 'CODE 128 A'], + 'C128B' => ['0123456789', 'CODE 128 B'], + 'C128C' => ['0123456789', 'CODE 128 C'], + 'C128' => ['0123456789', 'CODE 128'], + 'C39E+' => ['0123456789', 'CODE 39 EXTENDED + CHECKSUM'], + 'C39E' => ['0123456789', 'CODE 39 EXTENDED'], + 'C39+' => ['0123456789', 'CODE 39 + CHECKSUM'], + 'C39' => ['0123456789', 'CODE 39 - ANSI MH10.8M-1983 - USD-3 - 3 of 9'], + 'C93' => ['0123456789', 'CODE 93 - USS-93'], + 'CODABAR' => ['0123456789', 'CODABAR'], + 'CODE11' => ['0123456789', 'CODE 11'], + 'EAN13' => ['0123456789', 'EAN 13'], + 'EAN2' => ['12', 'EAN 2-Digits UPC-Based Extension'], + 'EAN5' => ['12345', 'EAN 5-Digits UPC-Based Extension'], + 'EAN8' => ['1234567', 'EAN 8'], + 'I25+' => ['0123456789', 'Interleaved 2 of 5 + CHECKSUM'], + 'I25' => ['0123456789', 'Interleaved 2 of 5'], + 'IMB' => ['01234567094987654321-01234567891', 'IMB - Intelligent Mail Barcode - Onecode - USPS-B-3200'], + 'IMBPRE' => ['AADTFFDFTDADTAADAATFDTDDAAADDTDTTDAFADADDDTFFFDDTTTADFAAADFTDAADA', 'IMB pre-processed'], + 'KIX' => ['0123456789', 'KIX (Klant index - Customer index)'], + 'MSI+' => ['0123456789', 'MSI + CHECKSUM (modulo 11)'], + 'MSI' => ['0123456789', 'MSI (Variation of Plessey code)'], + 'PHARMA2T' => ['0123456789', 'PHARMACODE TWO-TRACKS'], + 'PHARMA' => ['0123456789', 'PHARMACODE'], + 'PLANET' => ['0123456789', 'PLANET'], + 'POSTNET' => ['0123456789', 'POSTNET'], + 'RMS4CC' => ['0123456789', 'RMS4CC (Royal Mail 4-state Customer Bar Code)'], + 'S25+' => ['0123456789', 'Standard 2 of 5 + CHECKSUM'], + 'S25' => ['0123456789', 'Standard 2 of 5'], + 'UPCA' => ['72527273070', 'UPC-A'], + 'UPCE' => ['725277', 'UPC-E'], +]; + +$square = [ + 'LRAW' => ['0101010101', '1D RAW MODE (comma-separated rows of 01 strings)'], + 'SRAW' => ['0101,1010', '2D RAW MODE (comma-separated rows of 01 strings)'], + 'AZTEC' => ['ABCDabcd01234', 'AZTEC (ISO/IEC 24778:2008)'], + 'AZTEC,50,A,A' => ['ABCDabcd01234', 'AZTEC (ISO/IEC 24778:2008)'], + 'PDF417' => ['0123456789', 'PDF417 (ISO/IEC 15438:2006)'], + 'QRCODE' => ['0123456789', 'QR-CODE'], + 'QRCODE,H,ST,0,0' => ['abcdefghijklmnopqrstuvwxy0123456789', 'QR-CODE WITH PARAMETERS'], + 'DATAMATRIX' => ['0123456789', 'DATAMATRIX (ISO/IEC 16022) SQUARE'], + 'DATAMATRIX,R' => ['0123456789012345678901234567890123456789', 'DATAMATRIX Rectangular (ISO/IEC 16022) RECTANGULAR'], + 'DATAMATRIX,S,GS1' => [chr(232) . '01095011010209171719050810ABCD1234' . chr(232) . '2110', 'GS1 DATAMATRIX (ISO/IEC 16022) SQUARE GS1'], + 'DATAMATRIX,R,GS1' => [chr(232) . '01095011010209171719050810ABCD1234' . chr(232) . '2110', 'GS1 DATAMATRIX (ISO/IEC 16022) RECTANGULAR GS1'], +]; + +$barcode = new \Com\Tecnick\Barcode\Barcode(); + +$examples = '

Linear

' . "\n"; +foreach ($linear as $type => $code) { + $bobj = $barcode->getBarcodeObj($type, $code[0], -3, -30, 'black', [0, 0, 0, 0]); + $examples .= '

[' . $type . '] ' . $code[1] . '

' . $bobj->getHtmlDiv() . '

' . "\n"; +} + +$examples .= '

Square

' . "\n"; +foreach ($square as $type => $code) { + $bobj = $barcode->getBarcodeObj($type, $code[0], -4, -4, 'black', [0, 0, 0, 0]); + $examples .= '

[' . $type . '] ' . $code[1] . '

' . $bobj->getHtmlDiv() . '

' . "\n"; +} + +$bobj = $barcode->getBarcodeObj('QRCODE,H', 'https://tecnick.com', -4, -4, 'black', [-2, -2, -2, -2])->setBackgroundColor('#f0f0f0'); + +echo " + + + + Usage example of tc-lib-barcode library + + + + +

Usage example of tc-lib-barcode library

+

This is an usage example of tc-lib-barcode library.

+

Output Formats

+

PNG Image

+

\"EmbeddedgetPngData()) . "\" />

+

SVG Image

+

" . $bobj->getSvgCode() . "

+

HTML DIV

+

" . $bobj->getHtmlDiv() . "

+

Unicode String

+
" . $bobj->getGrid(json_decode('"\u00A0"'), json_decode('"\u2584"')) . "
+

Binary String

+
" . $bobj->getGrid() . "
+

Barcode Types

+ " . $examples . " + + +"; diff --git a/vendor/tecnickcom/tc-lib-barcode/phpcompatinfo.json b/vendor/tecnickcom/tc-lib-barcode/phpcompatinfo.json new file mode 100644 index 0000000..dc01759 --- /dev/null +++ b/vendor/tecnickcom/tc-lib-barcode/phpcompatinfo.json @@ -0,0 +1,15 @@ +{ + "source-providers": [ + { + "in": "src as source", + "exclude": "vendor", + "name": "/\\.(php)$/" + } + ], + "plugins": [ + ], + "analysers": [ + ], + "services": [ + ] +} diff --git a/vendor/tecnickcom/tc-lib-barcode/phpcs.xml b/vendor/tecnickcom/tc-lib-barcode/phpcs.xml new file mode 100644 index 0000000..7c9da08 --- /dev/null +++ b/vendor/tecnickcom/tc-lib-barcode/phpcs.xml @@ -0,0 +1,7 @@ + + + PSR-12 for PHP less than 7.1 + + + + diff --git a/vendor/tecnickcom/tc-lib-barcode/phpstan.neon b/vendor/tecnickcom/tc-lib-barcode/phpstan.neon new file mode 100644 index 0000000..86bd47d --- /dev/null +++ b/vendor/tecnickcom/tc-lib-barcode/phpstan.neon @@ -0,0 +1,10 @@ +parameters: + level: max + paths: + - src + - test + excludePaths: + - vendor + ignoreErrors: + reportUnmatchedIgnoredErrors: false + treatPhpDocTypesAsCertain: false diff --git a/vendor/tecnickcom/tc-lib-barcode/phpunit.xml.dist b/vendor/tecnickcom/tc-lib-barcode/phpunit.xml.dist new file mode 100644 index 0000000..bf99188 --- /dev/null +++ b/vendor/tecnickcom/tc-lib-barcode/phpunit.xml.dist @@ -0,0 +1,31 @@ + + + + + ./test + + + + + src + + + + + + + + + + + + diff --git a/vendor/tecnickcom/tc-lib-barcode/resources/autoload.php b/vendor/tecnickcom/tc-lib-barcode/resources/autoload.php new file mode 100644 index 0000000..ba676b8 --- /dev/null +++ b/vendor/tecnickcom/tc-lib-barcode/resources/autoload.php @@ -0,0 +1,30 @@ + + * @copyright 2015-2024 Nicola Asuni - Tecnick.com LTD + * @license http://www.gnu.org/copyleft/lesser.html GNU-LGPL v3 (see LICENSE.TXT) + * @link https://github.com/tecnickcom/tc-lib-barcode + * + * This file is part of tc-lib-barcode software library. + */ +spl_autoload_register( + function ($class) { + $prefix = 'Com\\Tecnick\\'; + $len = strlen($prefix); + if (strncmp($prefix, $class, $len) !== 0) { + return; + } + $relative_class = substr($class, $len); + $file = dirname(__DIR__).'/'.str_replace('\\', '/', $relative_class).'.php'; + if (file_exists($file)) { + require $file; + } + } +); diff --git a/vendor/tecnickcom/tc-lib-barcode/resources/debian/changelog b/vendor/tecnickcom/tc-lib-barcode/resources/debian/changelog new file mode 100644 index 0000000..7767c79 --- /dev/null +++ b/vendor/tecnickcom/tc-lib-barcode/resources/debian/changelog @@ -0,0 +1,7 @@ +~#PKGNAME#~ (~#VERSION#~-~#RELEASE#~) UNRELEASED; urgency=low + + * Please check the + https://github.com/~#VENDOR#~/~#PROJECT#~ + commit history + + -- Nicola Asuni ~#DATE#~ diff --git a/vendor/tecnickcom/tc-lib-barcode/resources/debian/compat b/vendor/tecnickcom/tc-lib-barcode/resources/debian/compat new file mode 100644 index 0000000..f599e28 --- /dev/null +++ b/vendor/tecnickcom/tc-lib-barcode/resources/debian/compat @@ -0,0 +1 @@ +10 diff --git a/vendor/tecnickcom/tc-lib-barcode/resources/debian/control b/vendor/tecnickcom/tc-lib-barcode/resources/debian/control new file mode 100644 index 0000000..bed9136 --- /dev/null +++ b/vendor/tecnickcom/tc-lib-barcode/resources/debian/control @@ -0,0 +1,23 @@ +Source: ~#PKGNAME#~ +Maintainer: Nicola Asuni +Section: php +Priority: optional +Build-Depends: debhelper (>= 9) +Standards-Version: 3.9.7 +Homepage: https://github.com/~#VENDOR#~/~#PROJECT#~ +Vcs-Git: https://github.com/~#VENDOR#~/~#PROJECT#~.git + +Package: ~#PKGNAME#~ +Provides: php-~#PROJECT#~ +Architecture: all +Depends: php (>= 8.1.0), php-bcmath, php-date, php-gd, php-tecnickcom-tc-lib-color (<< 3.0.0), php-tecnickcom-tc-lib-color (>= 2.2.13), ${misc:Depends} +Description: PHP Barcode library + This library includes PHP classes to generate linear + and bidimensional barcodes: + CODE 39, ANSI MH10.8M-1983, USD-3, 3 of 9, CODE 93, + USS-93, Standard 2 of 5, Interleaved 2 of 5, CODE 128 A/B/C, + 2 and 5 Digits UPC-Based Extension, EAN 8, EAN 13, UPC-A, + UPC-E, MSI, POSTNET, PLANET, RMS4CC (Royal Mail 4-state Customer Code), + CBC (Customer Bar Code), KIX (Klant index - Customer index), + Intelligent Mail Barcode, Onecode, USPS-B-3200, CODABAR, CODE 11, + PHARMACODE, PHARMACODE TWO-TRACKS, AZTEC, Datamatrix ECC200, QR-Code, PDF417. diff --git a/vendor/tecnickcom/tc-lib-barcode/resources/debian/copyright b/vendor/tecnickcom/tc-lib-barcode/resources/debian/copyright new file mode 100644 index 0000000..68603ae --- /dev/null +++ b/vendor/tecnickcom/tc-lib-barcode/resources/debian/copyright @@ -0,0 +1,20 @@ +Format: http://www.debian.org/doc/packaging-manuals/copyright-format/1.0/ +Upstream-Name: ~#PROJECT#~ +Source: https://github.com/~#VENDOR#~/~#PROJECT#~ + +Files: * +Copyright: Copyright 2001-2024 Nicola Asuni +License: LGPL-3 + +License: LGPL-3 + This program is free software: you can redistribute it and/or modify + it under the terms of the GNU Lesser General Public License as + published by the Free Software Foundation, either version 3 of the + License, or (at your option) any later version. + This program is distributed in the hope that it will be useful, + but WITHOUT ANY WARRANTY; without even the implied warranty of + MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the + GNU General Public License for more details. + You should have received a copy of the GNU General Public License + along with this program. If not, see or + /usr/share/common-licenses/LGPL-3 diff --git a/vendor/tecnickcom/tc-lib-barcode/resources/debian/rules b/vendor/tecnickcom/tc-lib-barcode/resources/debian/rules new file mode 100644 index 0000000..cbe925d --- /dev/null +++ b/vendor/tecnickcom/tc-lib-barcode/resources/debian/rules @@ -0,0 +1,3 @@ +#!/usr/bin/make -f +%: + dh $@ diff --git a/vendor/tecnickcom/tc-lib-barcode/resources/debian/source/format b/vendor/tecnickcom/tc-lib-barcode/resources/debian/source/format new file mode 100644 index 0000000..163aaf8 --- /dev/null +++ b/vendor/tecnickcom/tc-lib-barcode/resources/debian/source/format @@ -0,0 +1 @@ +3.0 (quilt) diff --git a/vendor/tecnickcom/tc-lib-barcode/resources/phpmd/codesize.xml b/vendor/tecnickcom/tc-lib-barcode/resources/phpmd/codesize.xml new file mode 100644 index 0000000..2ecea04 --- /dev/null +++ b/vendor/tecnickcom/tc-lib-barcode/resources/phpmd/codesize.xml @@ -0,0 +1,22 @@ + + +Created with the PHP Coding Standard Generator. http://edorian.github.com/php-coding-standard-generator/ + + + + + + + + + + + + + + + diff --git a/vendor/tecnickcom/tc-lib-barcode/resources/phpmd/design.xml b/vendor/tecnickcom/tc-lib-barcode/resources/phpmd/design.xml new file mode 100644 index 0000000..cd5a262 --- /dev/null +++ b/vendor/tecnickcom/tc-lib-barcode/resources/phpmd/design.xml @@ -0,0 +1,18 @@ + + +Created with the PHP Coding Standard Generator. http://edorian.github.com/php-coding-standard-generator/ + + + + + + + + + + + diff --git a/vendor/tecnickcom/tc-lib-barcode/resources/rpm/rpm.spec b/vendor/tecnickcom/tc-lib-barcode/resources/rpm/rpm.spec new file mode 100644 index 0000000..e8093fb --- /dev/null +++ b/vendor/tecnickcom/tc-lib-barcode/resources/rpm/rpm.spec @@ -0,0 +1,63 @@ +# SPEC file + +%global c_vendor %{_vendor} +%global gh_owner %{_owner} +%global gh_project %{_project} + +Name: %{_package} +Version: %{_version} +Release: %{_release}%{?dist} +Summary: PHP library to generate linear and bidimensional barcodes + +Group: Development/Libraries +License: LGPLv3+ +URL: https://github.com/%{gh_owner}/%{gh_project} + +BuildRoot: %{_tmppath}/%{name}-%{version}-%{release}-%(%{__id_u} -n) +BuildArch: noarch + +Requires: php(language) >= 8.1.0 +Requires: php-composer(%{c_vendor}/tc-lib-color) < 3.0.0 +Requires: php-composer(%{c_vendor}/tc-lib-color) >= 2.2.13 +Requires: php-bcmath +Requires: php-date +Requires: php-gd +Requires: php-pcre + +Provides: php-composer(%{c_vendor}/%{gh_project}) = %{version} +Provides: php-%{gh_project} = %{version} + +%description +PHP classes to generate linear and bidimensional barcodes: +CODE 39, ANSI MH10.8M-1983, USD-3, 3 of 9, CODE 93, USS-93, +Standard 2 of 5, Interleaved 2 of 5, CODE 128 A/B/C, +2 and 5 Digits UPC-Based Extension, EAN 8, EAN 13, UPC-A, +UPC-E, MSI, POSTNET, PLANET, RMS4CC (Royal Mail 4-state Customer Code), +CBC (Customer Bar Code), KIX (Klant index - Customer index), +Intelligent Mail Barcode, Onecode, USPS-B-3200, CODABAR, CODE 11, +PHARMACODE, PHARMACODE TWO-TRACKS, AZTEC, Datamatrix ECC200, QR-Code, PDF417. + +Optional dependency: php-pecl-imagick + +%build +#(cd %{_current_directory} && make build) + +%install +rm -rf $RPM_BUILD_ROOT +(cd %{_current_directory} && make install DESTDIR=$RPM_BUILD_ROOT) + +%clean +rm -rf $RPM_BUILD_ROOT +#(cd %{_current_directory} && make clean) + +%files +%attr(-,root,root) %{_libpath} +%attr(-,root,root) %{_docpath} +%docdir %{_docpath} +#%config(noreplace) %{_configpath}* + +%changelog +* Thu Jul 02 2024 Nicola Asuni 1.2.0-1 +- Changed package name, add provides section +* Tue Feb 24 2024 Nicola Asuni 1.0.0-1 +- Initial Commit diff --git a/vendor/tecnickcom/tc-lib-barcode/src/Barcode.php b/vendor/tecnickcom/tc-lib-barcode/src/Barcode.php new file mode 100644 index 0000000..3b28bdc --- /dev/null +++ b/vendor/tecnickcom/tc-lib-barcode/src/Barcode.php @@ -0,0 +1,158 @@ + + * @copyright 2015-2024 Nicola Asuni - Tecnick.com LTD + * @license http://www.gnu.org/copyleft/lesser.html GNU-LGPL v3 (see LICENSE.TXT) + * @link https://github.com/tecnickcom/tc-lib-barcode + * + * This file is part of tc-lib-barcode software library. + */ + +namespace Com\Tecnick\Barcode; + +use Com\Tecnick\Barcode\Exception as BarcodeException; + +/** + * Com\Tecnick\Barcode\Barcode + * + * Barcode Barcode class + * + * @since 2015-02-21 + * @category Library + * @package Barcode + * @author Nicola Asuni + * @copyright 2010-2024 Nicola Asuni - Tecnick.com LTD + * @license http://www.gnu.org/copyleft/lesser.html GNU-LGPL v3 (see LICENSE.TXT) + * @link https://github.com/tecnickcom/tc-lib-barcode + */ +class Barcode +{ + /** + * List of supported Barcode Types with description. + * + * @var array + */ + public const BARCODETYPES = [ + 'C128' => 'CODE 128', + 'C128A' => 'CODE 128 A', + 'C128B' => 'CODE 128 B', + 'C128C' => 'CODE 128 C', + 'C39' => 'CODE 39 - ANSI MH10.8M-1983 - USD-3 - 3 of 9.', + 'C39+' => 'CODE 39 + CHECKSUM', + 'C39E' => 'CODE 39 EXTENDED', + 'C39E+' => 'CODE 39 EXTENDED + CHECKSUM', + 'C93' => 'CODE 93 - USS-93', + 'CODABAR' => 'CODABAR', + 'CODE11' => 'CODE 11', + 'EAN13' => 'EAN 13', + 'EAN2' => 'EAN 2-Digits UPC-Based Extension', + 'EAN5' => 'EAN 5-Digits UPC-Based Extension', + 'EAN8' => 'EAN 8', + 'I25' => 'Interleaved 2 of 5', + 'I25+' => 'Interleaved 2 of 5 + CHECKSUM', + 'IMB' => 'IMB - Intelligent Mail Barcode - Onecode - USPS-B-3200', + 'IMBPRE' => 'IMB - Intelligent Mail Barcode pre-processed', + 'KIX' => 'KIX (Klant index - Customer index)', + 'LRAW' => '1D RAW MODE (comma-separated rows of 01 strings)', + 'MSI' => 'MSI (Variation of Plessey code)', + 'MSI+' => 'MSI + CHECKSUM (modulo 11)', + 'PHARMA' => 'PHARMACODE', + 'PHARMA2T' => 'PHARMACODE TWO-TRACKS', + 'PLANET' => 'PLANET', + 'POSTNET' => 'POSTNET', + 'RMS4CC' => 'RMS4CC (Royal Mail 4-state Customer Bar Code)', + 'S25' => 'Standard 2 of 5', + 'S25+' => 'Standard 2 of 5 + CHECKSUM', + 'UPCA' => 'UPC-A', + 'UPCE' => 'UPC-E', + 'AZTEC' => 'AZTEC Code (ISO/IEC 24778:2008)', + 'DATAMATRIX' => 'DATAMATRIX (ISO/IEC 16022)', + 'PDF417' => 'PDF417 (ISO/IEC 15438:2006)', + 'QRCODE' => 'QR-CODE', + 'SRAW' => '2D RAW MODE (comma-separated rows of 01 strings)', + ]; + + /** + * Get the barcode object + * + * @param string $type Barcode type + * @param string $code Barcode content + * @param int $width Barcode width in user units (excluding padding). + * A negative value indicates the multiplication + * factor for each column. + * @param int $height Barcode height in user units (excluding padding). + * A negative value indicates the multiplication + * factor for each row. + * @param string $color Foreground color in Web notation + * (color name, or hexadecimal code, or CSS syntax) + * @param array{int, int, int, int} $padding Additional padding to add around the barcode + * (top, right, bottom, left) in user units. A + * negative value indicates the multiplication + * factor for each row or column. + * + * @throws BarcodeException in case of error + */ + public function getBarcodeObj( + string $type, + string $code, + int $width = -1, + int $height = -1, + string $color = 'black', + array $padding = [0, 0, 0, 0] + ): Model { + // extract extra parameters (if any) + $params = explode(',', $type); + $type = array_shift($params); + + $bclass = match ($type) { + 'C128' => 'Linear\\CodeOneTwoEight', // CODE 128 + 'C128A' => 'Linear\\CodeOneTwoEight\\CodeOneTwoEightA', // CODE 128 A + 'C128B' => 'Linear\\CodeOneTwoEight\\CodeOneTwoEightB', // CODE 128 B + 'C128C' => 'Linear\\CodeOneTwoEight\\CodeOneTwoEightC', // CODE 128 C + 'C39' => 'Linear\\CodeThreeNine', // CODE 39 - ANSI MH10.8M-1983 - USD-3 - 3 of 9. + 'C39+' => 'Linear\\CodeThreeNineCheck', // CODE 39 + CHECKSUM + 'C39E' => 'Linear\\CodeThreeNineExt', // CODE 39 EXTENDED + 'C39E+' => 'Linear\\CodeThreeNineExtCheck', // CODE 39 EXTENDED + CHECKSUM + 'C93' => 'Linear\\CodeNineThree', // CODE 93 - USS-93 + 'CODABAR' => 'Linear\\Codabar', // CODABAR + 'CODE11' => 'Linear\\CodeOneOne', // CODE 11 + 'EAN13' => 'Linear\\EanOneThree', // EAN 13 + 'EAN2' => 'Linear\\EanTwo', // EAN 2-Digits UPC-Based Extension + 'EAN5' => 'Linear\\EanFive', // EAN 5-Digits UPC-Based Extension + 'EAN8' => 'Linear\\EanEight', // EAN 8 + 'I25' => 'Linear\\InterleavedTwoOfFive', // Interleaved 2 of 5 + 'I25+' => 'Linear\\InterleavedTwoOfFiveCheck', // Interleaved 2 of 5 + CHECKSUM + 'IMB' => 'Linear\\Imb', // IMB - Intelligent Mail Barcode - Onecode - USPS-B-3200 + 'IMBPRE' => 'Linear\\ImbPre', // IMB - Intelligent Mail Barcode pre-processed + 'KIX' => 'Linear\\KlantIndex', // KIX (Klant index - Customer index) + 'LRAW' => 'Linear\\Raw', // 1D RAW MODE (comma-separated rows of 01 strings) + 'MSI' => 'Linear\\Msi', // MSI (Variation of Plessey code) + 'MSI+' => 'Linear\\MsiCheck', // MSI + CHECKSUM (modulo 11) + 'PHARMA' => 'Linear\\Pharma', // PHARMACODE + 'PHARMA2T' => 'Linear\\PharmaTwoTracks', // PHARMACODE TWO-TRACKS + 'PLANET' => 'Linear\\Planet', // PLANET + 'POSTNET' => 'Linear\\Postnet', // POSTNET + 'RMS4CC' => 'Linear\\RoyalMailFourCc', // RMS4CC (Royal Mail 4-state Customer Bar Code) + 'S25' => 'Linear\\StandardTwoOfFive', // Standard 2 of 5 + 'S25+' => 'Linear\\StandardTwoOfFiveCheck', // Standard 2 of 5 + CHECKSUM + 'UPCA' => 'Linear\\UpcA', // UPC-A + 'UPCE' => 'Linear\\UpcE', // UPC-E + 'AZTEC' => 'Square\\Aztec', // AZTEC Code (ISO/IEC 24778:2008) + 'DATAMATRIX' => 'Square\\Datamatrix', // DATAMATRIX (ISO/IEC 16022) + 'PDF417' => 'Square\\PdfFourOneSeven', // PDF417 (ISO/IEC 15438:2006) + 'QRCODE' => 'Square\\QrCode', // QR-CODE + 'SRAW' => 'Square\\Raw', // 2D RAW MODE (comma-separated rows of 01 strings) + default => throw new BarcodeException('Unsupported barcode type: ' . $type) + }; + + $class = '\\Com\\Tecnick\\Barcode\\Type\\' . $bclass; + /* @phpstan-ignore-next-line */ + return new $class($code, $width, $height, $color, $params, $padding); + } +} diff --git a/vendor/tecnickcom/tc-lib-barcode/src/Exception.php b/vendor/tecnickcom/tc-lib-barcode/src/Exception.php new file mode 100644 index 0000000..3a03a0d --- /dev/null +++ b/vendor/tecnickcom/tc-lib-barcode/src/Exception.php @@ -0,0 +1,34 @@ + + * @copyright 2010-2024 Nicola Asuni - Tecnick.com LTD + * @license http://www.gnu.org/copyleft/lesser.html GNU-LGPL v3 (see LICENSE.TXT) + * @link https://github.com/tecnickcom/tc-lib-barcode + * + * This file is part of tc-lib-barcode software library. + */ + +namespace Com\Tecnick\Barcode; + +/** + * Com\Tecnick\Barcode\Exception + * + * Custom Exception class + * + * @since 2015-02-21 + * @category Library + * @package Barcode + * @author Nicola Asuni + * @copyright 2010-2024 Nicola Asuni - Tecnick.com LTD + * @license http://www.gnu.org/copyleft/lesser.html GNU-LGPL v3 (see LICENSE.TXT) + * @link https://github.com/tecnickcom/tc-lib-barcode + */ +class Exception extends \Exception +{ +} diff --git a/vendor/tecnickcom/tc-lib-barcode/src/Model.php b/vendor/tecnickcom/tc-lib-barcode/src/Model.php new file mode 100644 index 0000000..2674583 --- /dev/null +++ b/vendor/tecnickcom/tc-lib-barcode/src/Model.php @@ -0,0 +1,199 @@ + + * @copyright 2015-2024 Nicola Asuni - Tecnick.com LTD + * @license http://www.gnu.org/copyleft/lesser.html GNU-LGPL v3 (see LICENSE.TXT) + * @link https://github.com/tecnickcom/tc-lib-barcode + * + * This file is part of tc-lib-barcode software library. + */ + +namespace Com\Tecnick\Barcode; + +use Com\Tecnick\Barcode\Exception as BarcodeException; +use Com\Tecnick\Color\Exception as ColorException; +use Com\Tecnick\Color\Model\Rgb; + +/** + * Com\Tecnick\Barcode\Type + * + * Barcode Type class + * + * @since 2015-02-21 + * @category Library + * @package Barcode + * @author Nicola Asuni + * @copyright 2015-2024 Nicola Asuni - Tecnick.com LTD + * @license http://www.gnu.org/copyleft/lesser.html GNU-LGPL v3 (see LICENSE.TXT) + * @link https://github.com/tecnickcom/tc-lib-barcode + */ +interface Model +{ + /** + * Set the size of the barcode to be exported + * + * @param int $width Barcode width in user units (excluding padding). + * A negative value indicates the multiplication + * factor for each column. + * @param int $height Barcode height in user units (excluding padding). + * A negative value indicates the multiplication + * factor for each row. + * @param array{int, int, int, int} $padding Additional padding to add around the barcode + * (top, right, bottom, left) in user units. A + * negative value indicates the number or rows + * or columns. + */ + public function setSize(int $width, int $height, array $padding = [0, 0, 0, 0]): static; + + /** + * Set the color of the bars. + * If the color is transparent or empty it will be set to the default black color. + * + * @param string $color Foreground color in Web notation (color name, or hexadecimal code, or CSS syntax) + * + * @throws ColorException in case of color error + * @throws BarcodeException in case of empty or transparent color + */ + public function setColor(string $color): static; + + /** + * Set the background color + * + * @param string $color Background color in Web notation (color name, or hexadecimal code, or CSS syntax) + * + * @throws ColorException in case of color error + */ + public function setBackgroundColor(string $color): static; + + /** + * Get the barcode raw array + * + * @return array{ + * 'type': string, + * 'format': string, + * 'params': array, + * 'code': string, + * 'extcode': string, + * 'ncols': int, + * 'nrows': int, + * 'width': int, + * 'height': int, + * 'width_ratio': float, + * 'height_ratio': float, + * 'padding': array{'T': int, 'R': int, 'B': int, 'L': int}, + * 'full_width': int, + * 'full_height': int, + * 'color_obj': Rgb, + * 'bg_color_obj': ?Rgb, + * 'bars': array, + * } + */ + public function getArray(): array; + + /** + * Get the extended code (code + checksum) + */ + public function getExtendedCode(): string; + + /** + * Get the barcode as SVG image object + * + * @param string|null $filename The file name without extension (optional). + * Only allows alphanumeric characters, underscores and hyphens. + * Defaults to a md5 hash of the data. + * The file extension is always '.svg'. + */ + public function getSvg(?string $filename = null): void; + + /** + * Get the barcode as inline SVG code. + * + * @return string Inline SVG code. + */ + public function getInlineSvgCode(): string; + + /** + * Get the barcode as SVG code, including the XML declaration. + * + * @return string SVG code + */ + public function getSvgCode(): string; + + /** + * Get an HTML representation of the barcode. + * + * @return string HTML code (DIV block) + */ + public function getHtmlDiv(): string; + + /** + * Get Barcode as PNG Image (requires GD or Imagick library) + * + * @param string|null $filename The file name without extension (optional). + * Only allows alphanumeric characters, underscores and hyphens. + * Defaults to a md5 hash of the data. + * The file extension is always '.png'. + */ + public function getPng(?string $filename = null): void; + + /** + * Get the barcode as PNG image (requires GD or Imagick library) + * + * @param bool $imagick If true try to use the Imagick extension + * + * @return string PNG image data + */ + public function getPngData(bool $imagick = true): string; + + /** + * Get the barcode as PNG image (requires Imagick library) + * + * @throws BarcodeException if the Imagick library is not installed + */ + public function getPngDataImagick(): string; + + /** + * Get the barcode as GD image object (requires GD library) + * + * @throws BarcodeException if the GD library is not installed + */ + public function getGd(): \GdImage; + + /** + * Get a raw barcode string representation using characters + * + * @param string $space_char Character or string to use for filling empty spaces + * @param string $bar_char Character or string to use for filling bars + */ + public function getGrid(string $space_char = '0', string $bar_char = '1'): string; + + /** + * Get a raw barcode grid array + * + * @param string $space_char Character or string to use for filling empty spaces + * @param string $bar_char Character or string to use for filling bars + * + * @return array> + */ + public function getGridArray(string $space_char = '0', string $bar_char = '1'): array; + + /** + * Get the array containing all the formatted bars coordinates + * + * @return array + */ + public function getBarsArrayXYXY(): array; + + /** + * Get the array containing all the formatted bars coordinates + * + * @return array + */ + public function getBarsArrayXYWH(): array; +} diff --git a/vendor/tecnickcom/tc-lib-barcode/src/Type.php b/vendor/tecnickcom/tc-lib-barcode/src/Type.php new file mode 100644 index 0000000..6a10d5c --- /dev/null +++ b/vendor/tecnickcom/tc-lib-barcode/src/Type.php @@ -0,0 +1,650 @@ + + * @copyright 2015-2024 Nicola Asuni - Tecnick.com LTD + * @license http://www.gnu.org/copyleft/lesser.html GNU-LGPL v3 (see LICENSE.TXT) + * @link https://github.com/tecnickcom/tc-lib-barcode + * + * This file is part of tc-lib-barcode software library. + */ + +namespace Com\Tecnick\Barcode; + +use Com\Tecnick\Barcode\Exception as BarcodeException; +use Com\Tecnick\Color\Exception as ColorException; +use Com\Tecnick\Color\Model\Rgb; +use Com\Tecnick\Color\Pdf; + +/** + * Com\Tecnick\Barcode\Type + * + * Barcode Type class + * + * @since 2015-02-21 + * @category Library + * @package Barcode + * @author Nicola Asuni + * @copyright 2015-2024 Nicola Asuni - Tecnick.com LTD + * @license http://www.gnu.org/copyleft/lesser.html GNU-LGPL v3 (see LICENSE.TXT) + * @link https://github.com/tecnickcom/tc-lib-barcode + * + * @SuppressWarnings("PHPMD.ExcessiveClassComplexity") + */ +abstract class Type extends \Com\Tecnick\Barcode\Type\Convert implements Model +{ + /** + * Initialize a new barcode object + * + * @param string $code Barcode content + * @param int $width Barcode width in user units (excluding padding). + * A negative value indicates the multiplication + * factor for each column. + * @param int $height Barcode height in user units (excluding padding). + * A negative value indicates the multiplication + * factor for each row. + * @param string $color Foreground color in Web notation + * (color name, or hexadecimal code, or CSS syntax) + * @param array $params Array containing extra parameters for the specified barcode type + * @param array{int, int, int, int} $padding Additional padding to add around the barcode + * (top, right, bottom, left) in user units. A + * negative value indicates the number or rows + * or columns. + * + * @throws BarcodeException in case of error + * @throws ColorException in case of color error + */ + public function __construct( + string $code, + int $width = -1, + int $height = -1, + string $color = 'black', + array $params = [], + array $padding = [0, 0, 0, 0] + ) { + $this->code = $code; + $this->extcode = $code; + $this->params = $params; + $this->setParameters(); + $this->setBars(); + $this->setSize($width, $height, $padding); + $this->setColor($color); + } + + /** + * Set extra (optional) parameters + */ + protected function setParameters(): void + { + } + + /** + * Set the bars array + */ + protected function setBars(): void + { + } + + /** + * Set the size of the barcode to be exported + * + * @param int $width Barcode width in user units (excluding padding). + * A negative value indicates the multiplication + * factor for each column. + * @param int $height Barcode height in user units (excluding padding). + * A negative value indicates the multiplication + * factor for each row. + * @param array{int, int, int, int} $padding Additional padding to add around the barcode + * (top, right, bottom, left) in user units. A + * negative value indicates the number or rows + * or columns. + */ + public function setSize( + int $width, + int $height, + array $padding = [0, 0, 0, 0] + ): static { + $this->width = $width; + if ($this->width <= 0) { + $this->width = (abs(min(-1, $this->width)) * $this->ncols); + } + + $this->height = $height; + if ($this->height <= 0) { + $this->height = (abs(min(-1, $this->height)) * $this->nrows); + } + + $this->width_ratio = ($this->width / $this->ncols); + $this->height_ratio = ($this->height / $this->nrows); + + $this->setPadding($padding); + + return $this; + } + + /** + * Set the barcode padding + * + * @param array{int, int, int, int} $padding Additional padding to add around the barcode + * (top, right, bottom, left) in user units. + * A negative value indicates the number or rows or columns. + * + * @throws BarcodeException in case of error + */ + protected function setPadding(array $padding): static + { + if (count($padding) != 4) { + throw new BarcodeException( + 'Invalid padding, expecting an array of 4 numbers (top, right, bottom, left)' + ); + } + + $map = [ + ['T', $this->height_ratio], + ['R', $this->width_ratio], + ['B', $this->height_ratio], + ['L', $this->width_ratio], + ]; + foreach ($padding as $key => $val) { + if ($val < 0) { + $val = (abs(min(-1, $val)) * $map[$key][1]); + } + + $this->padding[$map[$key][0]] = (int) $val; + } + + return $this; + } + + /** + * Set the color of the bars. + * If the color is transparent or empty it will be set to the default black color. + * + * @param string $color Foreground color in Web notation (color name, or hexadecimal code, or CSS syntax) + * + * @throws ColorException in case of color error + * @throws BarcodeException in case of empty or transparent color + */ + public function setColor(string $color): static + { + $colobj = $this->getRgbColorObject($color); + if (! $colobj instanceof \Com\Tecnick\Color\Model\Rgb) { + throw new BarcodeException('The foreground color cannot be empty or transparent'); + } + + $this->color_obj = $colobj; + return $this; + } + + /** + * Set the background color + * + * @param string $color Background color in Web notation (color name, or hexadecimal code, or CSS syntax) + * + * @throws ColorException in case of color error + */ + public function setBackgroundColor(string $color): static + { + $this->bg_color_obj = $this->getRgbColorObject($color); + return $this; + } + + /** + * Get the RGB Color object for the given color representation + * + * @param string $color Color in Web notation (color name, or hexadecimal code, or CSS syntax) + * + * @throws ColorException in case of color error + */ + protected function getRgbColorObject(string $color): ?Rgb + { + $pdf = new Pdf(); + $cobj = $pdf->getColorObject($color); + if ($cobj instanceof \Com\Tecnick\Color\Model) { + return new Rgb($cobj->toRgbArray()); + } + + return null; + } + + /** + * Get the barcode raw array + * + * @return array{ + * 'type': string, + * 'format': string, + * 'params': array, + * 'code': string, + * 'extcode': string, + * 'ncols': int, + * 'nrows': int, + * 'width': int, + * 'height': int, + * 'width_ratio': float, + * 'height_ratio': float, + * 'padding': array{'T': int, 'R': int, 'B': int, 'L': int}, + * 'full_width': int, + * 'full_height': int, + * 'color_obj': Rgb, + * 'bg_color_obj': ?Rgb, + * 'bars': array, + * } + */ + public function getArray(): array + { + return [ + 'type' => $this::TYPE, + 'format' => $this::FORMAT, + 'params' => $this->params, + 'code' => $this->code, + 'extcode' => $this->extcode, + 'ncols' => $this->ncols, + 'nrows' => $this->nrows, + 'width' => $this->width, + 'height' => $this->height, + 'width_ratio' => $this->width_ratio, + 'height_ratio' => $this->height_ratio, + 'padding' => $this->padding, + 'full_width' => ($this->width + $this->padding['L'] + $this->padding['R']), + 'full_height' => ($this->height + $this->padding['T'] + $this->padding['B']), + 'color_obj' => $this->color_obj, + 'bg_color_obj' => $this->bg_color_obj, + 'bars' => $this->bars, + ]; + } + + /** + * Get the extended code (code + checksum) + */ + public function getExtendedCode(): string + { + return $this->extcode; + } + + /** + * Sends the data as file to the browser. + * + * @param string $data The file data. + * @param string $mime The file MIME type (i.e. 'application/svg+xml' or 'image/png'). + * @param string $fileext The file extension (i.e. 'svg' or 'png'). + * @param string|null $filename The file name without extension (optional). + * Only allows alphanumeric characters, underscores and hyphens. + * Defaults to a md5 hash of the data. + * + * @return void + */ + protected function getHTTPFile( + string $data, + string $mime, + string $fileext, + ?string $filename = null, + ): void { + if (is_null($filename) || (preg_match('/^[a-zA-Z0-9_\-]{1,250}$/', $filename) !== 1)) { + $filename = md5($data); + } + + header('Content-Type: ' . $mime); + header('Cache-Control: private, must-revalidate, post-check=0, pre-check=0, max-age=1'); + header('Pragma: public'); + header('Expires: Thu, 04 jan 1973 00:00:00 GMT'); // Date in the past + header('Last-Modified: ' . gmdate('D, d M Y H:i:s') . ' GMT'); + header('Content-Disposition: inline; filename="' . $filename . '.' . $fileext . '";'); + if (empty($_SERVER['HTTP_ACCEPT_ENCODING'])) { + // the content length may vary if the server is using compression + header('Content-Length: ' . strlen($data)); + } + + echo $data; + } + + /** + * Get the barcode as SVG image object. + * + * @param string|null $filename The file name without extension (optional). + * Only allows alphanumeric characters, underscores and hyphens. + * Defaults to a md5 hash of the data. + * The file extension is always '.svg'. + */ + public function getSvg(?string $filename = null): void + { + $this->getHTTPFile($this->getSvgCode(), 'application/svg+xml', 'svg', $filename); + } + + /** + * Get the barcode as inline SVG code. + * + * @return string Inline SVG code. + */ + public function getInlineSvgCode(): string + { + // flags for htmlspecialchars + $hflag = ENT_NOQUOTES; + if (defined('ENT_XML1') && defined('ENT_DISALLOWED')) { + $hflag = ENT_XML1 | ENT_DISALLOWED; + } + + $width = sprintf('%F', ($this->width + $this->padding['L'] + $this->padding['R'])); + $height = sprintf('%F', ($this->height + $this->padding['T'] + $this->padding['B'])); + + $svg = '' . "\n" + . "\t" . '' . htmlspecialchars($this->code, $hflag, 'UTF-8') . '' . "\n"; + if ($this->bg_color_obj instanceof \Com\Tecnick\Color\Model\Rgb) { + $svg .= ' ' . "\n"; + } + + $svg .= ' ' . "\n"; + $bars = $this->getBarsArrayXYWH(); + foreach ($bars as $bar) { + $svg .= ' ' . "\n"; + } + + return $svg . (' ' . "\n" + . '' . "\n"); + } + + /** + * Get the barcode as SVG code, including the XML declaration. + * + * @return string SVG code + */ + public function getSvgCode(): string + { + return '' + . "\n" + . $this->getInlineSvgCode(); + } + + /** + * Get an HTML representation of the barcode. + * + * @return string HTML code (DIV block) + */ + public function getHtmlDiv(): string + { + $html = '
' . "\n"; + $bars = $this->getBarsArrayXYWH(); + foreach ($bars as $bar) { + $html .= '
 
' . "\n"; + } + + return $html . ('
' . "\n"); + } + + /** + * Get Barcode as PNG Image (requires GD or Imagick library) + * + * @param string|null $filename The file name without extension (optional). + * Only allows alphanumeric characters, underscores and hyphens. + * Defaults to a md5 hash of the data. + * The file extension is always '.png'. + */ + public function getPng(?string $filename = null): void + { + $this->getHTTPFile($this->getPngData(), 'image/png', 'png', $filename); + } + + /** + * Get the barcode as PNG image (requires GD or Imagick library) + * + * @param bool $imagick If true try to use the Imagick extension + * + * @return string PNG image data + */ + public function getPngData(bool $imagick = true): string + { + if ($imagick && extension_loaded('imagick')) { + return $this->getPngDataImagick(); + } + + $gdImage = $this->getGd(); + ob_start(); + imagepng($gdImage); + $data = ob_get_clean(); + if ($data === false) { + throw new BarcodeException('Unable to get PNG data'); + } + return $data; + } + + /** + * Get the barcode as PNG image (requires Imagick library) + * + * @throws BarcodeException if the Imagick library is not installed + */ + public function getPngDataImagick(): string + { + $imagick = new \Imagick(); + $width = (int) ceil($this->width + $this->padding['L'] + $this->padding['R']); + $height = (int) ceil($this->height + $this->padding['T'] + $this->padding['B']); + $imagick->newImage($width, $height, 'none', 'png'); + $imagickdraw = new \imagickdraw(); + if ($this->bg_color_obj instanceof \Com\Tecnick\Color\Model\Rgb) { + $rgbcolor = $this->bg_color_obj->getNormalizedArray(255); + $bg_color = new \imagickpixel('rgb(' . $rgbcolor['R'] . ',' . $rgbcolor['G'] . ',' . $rgbcolor['B'] . ')'); + $imagickdraw->setfillcolor($bg_color); + $imagickdraw->rectangle(0, 0, $width, $height); + } + + $rgbcolor = $this->color_obj->getNormalizedArray(255); + $bar_color = new \imagickpixel('rgb(' . $rgbcolor['R'] . ',' . $rgbcolor['G'] . ',' . $rgbcolor['B'] . ')'); + $imagickdraw->setfillcolor($bar_color); + $bars = $this->getBarsArrayXYXY(); + foreach ($bars as $bar) { + $imagickdraw->rectangle($bar[0], $bar[1], $bar[2], $bar[3]); + } + + $imagick->drawimage($imagickdraw); + return $imagick->getImageBlob(); + } + + /** + * Get the barcode as GD image object (requires GD library) + * + * @throws BarcodeException if the GD library is not installed + */ + public function getGd(): \GdImage + { + $width = max(1, (int) ceil($this->width + $this->padding['L'] + $this->padding['R'])); + $height = max(1, (int) ceil($this->height + $this->padding['T'] + $this->padding['B'])); + $img = imagecreate($width, $height); + if ($img === false) { + throw new BarcodeException('Unable to create GD image'); + } + + if (! $this->bg_color_obj instanceof \Com\Tecnick\Color\Model\Rgb) { + $bgobj = clone $this->color_obj; + $rgbcolor = $bgobj->invertColor()->getNormalizedArray(255); + $background_color = imagecolorallocate( + $img, + (int) round($rgbcolor['R']), // @phpstan-ignore argument.type + (int) round($rgbcolor['G']), // @phpstan-ignore argument.type + (int) round($rgbcolor['B']), // @phpstan-ignore argument.type + ); + if ($background_color === false) { + throw new BarcodeException('Unable to allocate default GD background color'); + } + imagecolortransparent($img, $background_color); + } else { + $rgbcolor = $this->bg_color_obj->getNormalizedArray(255); + $bg_color = imagecolorallocate( + $img, + (int) round($rgbcolor['R']), // @phpstan-ignore argument.type + (int) round($rgbcolor['G']), // @phpstan-ignore argument.type + (int) round($rgbcolor['B']), // @phpstan-ignore argument.type + ); + if ($bg_color === false) { + throw new BarcodeException('Unable to allocate GD background color'); + } + imagefilledrectangle($img, 0, 0, $width, $height, $bg_color); + } + + $rgbcolor = $this->color_obj->getNormalizedArray(255); + $bar_color = imagecolorallocate( + $img, + (int) round($rgbcolor['R']), // @phpstan-ignore argument.type + (int) round($rgbcolor['G']), // @phpstan-ignore argument.type + (int) round($rgbcolor['B']), // @phpstan-ignore argument.type + ); + if ($bar_color === false) { + throw new BarcodeException('Unable to allocate GD foreground color'); + } + $bars = $this->getBarsArrayXYXY(); + foreach ($bars as $bar) { + imagefilledrectangle( + $img, + (int) floor($bar[0]), + (int) floor($bar[1]), + (int) floor($bar[2]), + (int) floor($bar[3]), + $bar_color + ); + } + + return $img; + } + + /** + * Get a raw barcode string representation using characters + * + * @param string $space_char Character or string to use for filling empty spaces + * @param string $bar_char Character or string to use for filling bars + */ + public function getGrid( + string $space_char = '0', + string $bar_char = '1' + ): string { + $raw = $this->getGridArray($space_char, $bar_char); + $grid = ''; + foreach ($raw as $row) { + $grid .= implode('', $row) . "\n"; + } + + return $grid; + } + + /** + * Get the array containing all the formatted bars coordinates + * + * @return array + */ + public function getBarsArrayXYXY(): array + { + $rect = []; + foreach ($this->bars as $bar) { + if ($bar[2] <= 0) { + continue; + } + + if ($bar[3] <= 0) { + continue; + } + + $rect[] = $this->getBarRectXYXY($bar); + } + + if ($this->nrows > 1) { + // reprint rotated to cancel row gaps + $rot = $this->getRotatedBarArray(); + foreach ($rot as $bar) { + if ($bar[2] <= 0) { + continue; + } + + if ($bar[3] <= 0) { + continue; + } + + $rect[] = $this->getBarRectXYXY($bar); + } + } + + return $rect; + } + + /** + * Get the array containing all the formatted bars coordinates + * + * @return array + */ + public function getBarsArrayXYWH(): array + { + $rect = []; + foreach ($this->bars as $bar) { + if ($bar[2] <= 0) { + continue; + } + + if ($bar[3] <= 0) { + continue; + } + + $rect[] = $this->getBarRectXYWH($bar); + } + + if ($this->nrows > 1) { + // reprint rotated to cancel row gaps + $rot = $this->getRotatedBarArray(); + foreach ($rot as $bar) { + if ($bar[2] <= 0) { + continue; + } + + if ($bar[3] <= 0) { + continue; + } + + $rect[] = $this->getBarRectXYWH($bar); + } + } + + return $rect; + } +} diff --git a/vendor/tecnickcom/tc-lib-barcode/src/Type/Convert.php b/vendor/tecnickcom/tc-lib-barcode/src/Type/Convert.php new file mode 100644 index 0000000..617a7c8 --- /dev/null +++ b/vendor/tecnickcom/tc-lib-barcode/src/Type/Convert.php @@ -0,0 +1,336 @@ + + * @copyright 2010-2024 Nicola Asuni - Tecnick.com LTD + * @license http://www.gnu.org/copyleft/lesser.html GNU-LGPL v3 (see LICENSE.TXT) + * @link https://github.com/tecnickcom/tc-lib-barcode + * + * This file is part of tc-lib-barcode software library. + */ + +namespace Com\Tecnick\Barcode\Type; + +use Com\Tecnick\Barcode\Exception as BarcodeException; +use Com\Tecnick\Color\Model\Rgb as Color; + +/** + * Com\Tecnick\Barcode\Type\Convert + * + * Barcode Convert class + * + * @since 2015-02-21 + * @category Library + * @package Barcode + * @author Nicola Asuni + * @copyright 2010-2024 Nicola Asuni - Tecnick.com LTD + * @license http://www.gnu.org/copyleft/lesser.html GNU-LGPL v3 (see LICENSE.TXT) + * @link https://github.com/tecnickcom/tc-lib-barcode + */ +abstract class Convert +{ + /** + * Barcode type (linear or square) + * + * @var string + */ + protected const TYPE = ''; + + /** + * Barcode format + * + * @var string + */ + protected const FORMAT = ''; + + /** + * Array containing extra parameters for the specified barcode type + * + * @var array + */ + protected array $params = []; + + /** + * Code to convert (barcode content) + */ + protected string $code = ''; + + /** + * Resulting code after applying checksum etc. + */ + protected string $extcode = ''; + + /** + * Total number of columns + */ + protected int $ncols = 0; + + /** + * Total number of rows + */ + protected int $nrows = 1; + + /** + * Array containing the position and dimensions of each barcode bar + * (x, y, width, height) + * + * @var array + */ + protected array $bars = []; + + /** + * Barcode width + */ + protected int $width = 0; + + /** + * Barcode height + */ + protected int $height = 0; + + /** + * Additional padding to add around the barcode (top, right, bottom, left) in user units. + * A negative value indicates the multiplication factor for each row or column. + * + * @var array{'T': int, 'R': int, 'B': int, 'L': int} + */ + protected array $padding = [ + 'T' => 0, + 'R' => 0, + 'B' => 0, + 'L' => 0, + ]; + + /** + * Ratio between the barcode width and the number of rows + */ + protected float $width_ratio = 0; + + /** + * Ratio between the barcode height and the number of columns + */ + protected float $height_ratio = 0; + + /** + * Foreground Color object + */ + protected Color $color_obj; + + /** + * Backgorund Color object + */ + protected ?Color $bg_color_obj = null; + + /** + * Process binary sequence rows. + * + * @param array> $rows Binary sequence data to process + * + * @throws BarcodeException in case of error + */ + protected function processBinarySequence(array $rows): void + { + if ($rows === []) { + throw new BarcodeException('Empty input string'); + } + + $this->nrows = count($rows); + $this->ncols = is_array($rows[0]) ? count($rows[0]) : strlen($rows[0]); + + if ($this->ncols === 0) { + throw new BarcodeException('Empty columns'); + } + + $this->bars = []; + foreach ($rows as $posy => $row) { + if (! is_array($row)) { + $row = str_split($row, 1); + } + + $prevcol = ''; + $bar_width = 0; + $row[] = '0'; + for ($posx = 0; $posx <= $this->ncols; ++$posx) { + if ($row[$posx] != $prevcol) { + if ($prevcol == '1') { + $this->bars[] = [($posx - $bar_width), $posy, $bar_width, 1]; + } + + $bar_width = 0; + } + + ++$bar_width; + $prevcol = $row[$posx]; + } + } + } + + /** + * Extract rows from a binary sequence of comma-separated 01 strings. + * + * @return array + */ + protected function getRawCodeRows(string $data): array + { + $search = [ + '/[\s]*/s', // remove spaces and newlines + '/^[\[,]+/', // remove trailing brackets or commas + '/[\],]+$/', // remove trailing brackets or commas + '/[\]][\[]$/', // convert bracket -separated to comma-separated + ]; + + $replace = ['', '', '', '']; + + $code = preg_replace($search, $replace, $data); + if ($code === null) { + throw new BarcodeException('Invalid input string'); + } + + return explode(',', $code); + } + + /** + * Convert large integer number to hexadecimal representation. + * + * @param string $number Number to convert (as string) + * + * @return string hexadecimal representation + */ + protected function convertDecToHex(string $number): string + { + if ($number == 0) { + return '00'; + } + + $hex = []; + while ($number > 0) { + $hex[] = strtoupper(dechex((int) bcmod($number, '16'))); + $number = bcdiv($number, '16', 0); + } + + $hex = array_reverse($hex); + return implode('', $hex); + } + + /** + * Convert large hexadecimal number to decimal representation (string). + * + * @param string $hex Hexadecimal number to convert (as string) + * + * @return string hexadecimal representation + */ + protected function convertHexToDec(string $hex): string + { + $dec = '0'; + $bitval = '1'; + $len = strlen($hex); + for ($pos = ($len - 1); $pos >= 0; --$pos) { + $dec = bcadd($dec, bcmul((string) hexdec($hex[$pos]), $bitval)); + $bitval = bcmul($bitval, '16'); + } + + return $dec; + } + + /** + * Get a raw barcode grid array + * + * @param string $space_char Character or string to use for filling empty spaces + * @param string $bar_char Character or string to use for filling bars + * + * @return array> + */ + public function getGridArray( + string $space_char = '0', + string $bar_char = '1' + ): array { + $raw = array_fill(0, $this->nrows, array_fill(0, $this->ncols, $space_char)); + foreach ($this->bars as $bar) { + if ($bar[2] <= 0) { + continue; + } + + if ($bar[3] <= 0) { + continue; + } + + for ($vert = 0; $vert < $bar[3]; ++$vert) { + for ($horiz = 0; $horiz < $bar[2]; ++$horiz) { + $raw[($bar[1] + $vert)][($bar[0] + $horiz)] = $bar_char; + } + } + } + + return $raw; + } + + /** + * Returns the bars array ordered by columns + * + * @return array + */ + protected function getRotatedBarArray(): array + { + $grid = $this->getGridArray(); + $cols = array_map(null, ...$grid); + $bars = []; + foreach ($cols as $posx => $col) { + $prevrow = ''; + $bar_height = 0; + $col[] = '0'; + for ($posy = 0; $posy <= $this->nrows; ++$posy) { + if ($col[$posy] != $prevrow) { + if ($prevrow == '1') { + $bars[] = [$posx, ($posy - $bar_height), 1, $bar_height]; + } + + $bar_height = 0; + } + + ++$bar_height; + $prevrow = $col[$posy]; + } + } + + return $bars; + } + + /** + * Get the adjusted rectangular coordinates (x1,y1,x2,y2) for the specified bar + * + * @param array{int, int, int, int} $bar Raw bar coordinates + * + * @return array{float, float, float, float} Bar coordinates + */ + protected function getBarRectXYXY(array $bar): array + { + return [ + ($this->padding['L'] + ($bar[0] * $this->width_ratio)), + ($this->padding['T'] + ($bar[1] * $this->height_ratio)), + ($this->padding['L'] + (($bar[0] + $bar[2]) * $this->width_ratio) - 1), + ($this->padding['T'] + (($bar[1] + $bar[3]) * $this->height_ratio) - 1), + ]; + } + + /** + * Get the adjusted rectangular coordinates (x,y,w,h) for the specified bar + * + * @param array{int, int, int, int} $bar Raw bar coordinates + * + * @return array{float, float, float, float} Bar coordinates + */ + protected function getBarRectXYWH(array $bar): array + { + return [ + ($this->padding['L'] + ($bar[0] * $this->width_ratio)), + ($this->padding['T'] + ($bar[1] * $this->height_ratio)), + ($bar[2] * $this->width_ratio), + ($bar[3] * $this->height_ratio), + ]; + } +} diff --git a/vendor/tecnickcom/tc-lib-barcode/src/Type/Linear.php b/vendor/tecnickcom/tc-lib-barcode/src/Type/Linear.php new file mode 100644 index 0000000..7b2ca50 --- /dev/null +++ b/vendor/tecnickcom/tc-lib-barcode/src/Type/Linear.php @@ -0,0 +1,40 @@ + + * @copyright 2010-2024 Nicola Asuni - Tecnick.com LTD + * @license http://www.gnu.org/copyleft/lesser.html GNU-LGPL v3 (see LICENSE.TXT) + * @link https://github.com/tecnickcom/tc-lib-barcode + * + * This file is part of tc-lib-barcode software library. + */ + +namespace Com\Tecnick\Barcode\Type; + +/** + * Com\Tecnick\Barcode\Type\Linear + * + * Barcode type class + * + * @since 2015-02-21 + * @category Library + * @package Barcode + * @author Nicola Asuni + * @copyright 2010-2024 Nicola Asuni - Tecnick.com LTD + * @license http://www.gnu.org/copyleft/lesser.html GNU-LGPL v3 (see LICENSE.TXT) + * @link https://github.com/tecnickcom/tc-lib-barcode + */ +abstract class Linear extends \Com\Tecnick\Barcode\Type +{ + /** + * Barcode type + * + * @var string + */ + protected const TYPE = 'linear'; +} diff --git a/vendor/tecnickcom/tc-lib-barcode/src/Type/Linear/Codabar.php b/vendor/tecnickcom/tc-lib-barcode/src/Type/Linear/Codabar.php new file mode 100644 index 0000000..9305125 --- /dev/null +++ b/vendor/tecnickcom/tc-lib-barcode/src/Type/Linear/Codabar.php @@ -0,0 +1,109 @@ + + * @copyright 2010-2024 Nicola Asuni - Tecnick.com LTD + * @license http://www.gnu.org/copyleft/lesser.html GNU-LGPL v3 (see LICENSE.TXT) + * @link https://github.com/tecnickcom/tc-lib-barcode + * + * This file is part of tc-lib-barcode software library. + */ + +namespace Com\Tecnick\Barcode\Type\Linear; + +use Com\Tecnick\Barcode\Exception as BarcodeException; + +/** + * Com\Tecnick\Barcode\Type\Linear\Codabar; + * + * Codabar Barcode type class + * + * @since 2015-02-21 + * @category Library + * @package Barcode + * @author Nicola Asuni + * @copyright 2010-2024 Nicola Asuni - Tecnick.com LTD + * @license http://www.gnu.org/copyleft/lesser.html GNU-LGPL v3 (see LICENSE.TXT) + * @link https://github.com/tecnickcom/tc-lib-barcode + */ +class Codabar extends \Com\Tecnick\Barcode\Type\Linear +{ + /** + * Barcode format + * + * @var string + */ + protected const FORMAT = 'CODABAR'; + + /** + * Map characters to barcodes + * + * @var array + */ + protected const CHBAR = [ + '0' => '11111221', + '1' => '11112211', + '2' => '11121121', + '3' => '22111111', + '4' => '11211211', + '5' => '21111211', + '6' => '12111121', + '7' => '12112111', + '8' => '12211111', + '9' => '21121111', + '-' => '11122111', + '$' => '11221111', + ':' => '21112121', + '/' => '21211121', + '.' => '21212111', + '+' => '11222221', + 'A' => '11221211', + 'B' => '12121121', + 'C' => '11121221', + 'D' => '11122211', + ]; + + /** + * Format code + */ + protected function formatCode(): void + { + $this->extcode = 'A' . strtoupper($this->code) . 'A'; + } + + /** + * Set the bars array. + * + * @throws BarcodeException in case of error + */ + protected function setBars(): void + { + $this->ncols = 0; + $this->nrows = 1; + $this->bars = []; + $this->formatCode(); + $clen = strlen($this->extcode); + for ($chr = 0; $chr < $clen; ++$chr) { + $char = $this->extcode[$chr]; + if (! isset($this::CHBAR[$char])) { + throw new BarcodeException('Invalid character: chr(' . ord($char) . ')'); + } + + for ($pos = 0; $pos < 8; ++$pos) { + $bar_width = (int) $this::CHBAR[$char][$pos]; + if (($pos % 2) == 0) { + $this->bars[] = [$this->ncols, 0, $bar_width, 1]; + } + + $this->ncols += $bar_width; + } + } + + --$this->ncols; + } +} diff --git a/vendor/tecnickcom/tc-lib-barcode/src/Type/Linear/CodeNineThree.php b/vendor/tecnickcom/tc-lib-barcode/src/Type/Linear/CodeNineThree.php new file mode 100644 index 0000000..381967b --- /dev/null +++ b/vendor/tecnickcom/tc-lib-barcode/src/Type/Linear/CodeNineThree.php @@ -0,0 +1,372 @@ + + * @copyright 2010-2024 Nicola Asuni - Tecnick.com LTD + * @license http://www.gnu.org/copyleft/lesser.html GNU-LGPL v3 (see LICENSE.TXT) + * @link https://github.com/tecnickcom/tc-lib-barcode + * + * This file is part of tc-lib-barcode software library. + */ + +namespace Com\Tecnick\Barcode\Type\Linear; + +use Com\Tecnick\Barcode\Exception as BarcodeException; + +/** + * Com\Tecnick\Barcode\Type\Linear\CodeNineThree; + * + * CodeNineThree Barcode type class + * CODE 93 - USS-93 + * + * @since 2015-02-21 + * @category Library + * @package Barcode + * @author Nicola Asuni + * @copyright 2010-2024 Nicola Asuni - Tecnick.com LTD + * @license http://www.gnu.org/copyleft/lesser.html GNU-LGPL v3 (see LICENSE.TXT) + * @link https://github.com/tecnickcom/tc-lib-barcode + */ +class CodeNineThree extends \Com\Tecnick\Barcode\Type\Linear\CodeThreeNineExtCheck +{ + /** + * Barcode format + * + * @var string + */ + protected const FORMAT = 'C93'; + + /** + * Map characters to barcodes + * + * @var array + */ + protected const CHBAR = [ + 32 => '311211', // space + 36 => '321111', // $ + 37 => '211131', // % + 42 => '111141', // start-stop + 43 => '113121', // + + 45 => '121131', // - + 46 => '311112', // . + 47 => '112131', // / + 48 => '131112', // 0 + 49 => '111213', // 1 + 50 => '111312', // 2 + 51 => '111411', // 3 + 52 => '121113', // 4 + 53 => '121212', // 5 + 54 => '121311', // 6 + 55 => '111114', // 7 + 56 => '131211', // 8 + 57 => '141111', // 9 + 65 => '211113', // A + 66 => '211212', // B + 67 => '211311', // C + 68 => '221112', // D + 69 => '221211', // E + 70 => '231111', // F + 71 => '112113', // G + 72 => '112212', // H + 73 => '112311', // I + 74 => '122112', // J + 75 => '132111', // K + 76 => '111123', // L + 77 => '111222', // M + 78 => '111321', // N + 79 => '121122', // O + 80 => '131121', // P + 81 => '212112', // Q + 82 => '212211', // R + 83 => '211122', // S + 84 => '211221', // T + 85 => '221121', // U + 86 => '222111', // V + 87 => '112122', // W + 88 => '112221', // X + 89 => '122121', // Y + 90 => '123111', // Z + 128 => '121221', // ($) + 129 => '311121', // (/) + 130 => '122211', // (+) + 131 => '312111', // (%) + ]; + + /** + * Map for extended characters + * + * @var array + */ + protected const EXTCODES = [ + "\x83U", + "\x80A", + "\x80B", + "\x80C", + "\x80D", + "\x80E", + "\x80F", + "\x80G", + "\x80H", + "\x80I", + "\x80J", + "\x80K", + "\x80L", + "\x80M", + "\x80N", + "\x80O", + "\x80P", + "\x80Q", + "\x80R", + "\x80S", + "\x80T", + "\x80U", + "\x80V", + "\x80W", + "\x80X", + "\x80Y", + "\x80Z", + "\x83A", + "\x83B", + "\x83C", + "\x83D", + "\x83E", + " ", + "\x81A", + "\x81B", + "\x81C", + "\x81D", + "\x81E", + + "\x81F", + "\x81G", + "\x81H", + "\x81I", + "\x81J", + "\x81K", + "\x81L", + "-", + ".", + "\x81O", + "0", + "1", + "2", + "3", + "4", + "5", + "6", + "7", + "8", + "9", + "\x81Z", + "\x83F", + "\x83G", + "\x83H", + "\x83I", + "\x83J", + "\x83V", + "A", + "B", + "C", + "D", + "E", + "F", + "G", + "H", + "I", + "J", + "K", + "L", + "M", + "N", + "O", + "P", + "Q", + "R", + "S", + "T", + "U", + "V", + "W", + "X", + "Y", + "Z", + "\x83K", + "\x83L", + "\x83M", + "\x83N", + "\x83O", + "\x83W", + "\x82A", + "\x82B", + "\x82C", + "\x82D", + "\x82E", + "\x82F", + "\x82G", + "\x82H", + "\x82I", + "\x82J", + "\x82K", + "\x82L", + "\x82M", + "\x82N", + "\x82O", + "\x82P", + "\x82Q", + "\x82R", + "\x82S", + "\x82T", + "\x82U", + "\x82V", + "\x82W", + "\x82X", + "\x82Y", + "\x82Z", + "\x83P", + "\x83Q", + "\x83R", + "\x83S", + "\x83T", + ]; + + /** + * Characters used for checksum + * + * @var array + */ + protected const CHKSUM = [ + '0', + '1', + '2', + '3', + '4', + '5', + '6', + '7', + '8', + '9', + 'A', + 'B', + 'C', + 'D', + 'E', + 'F', + 'G', + 'H', + 'I', + 'J', + 'K', + 'L', + 'M', + 'N', + 'O', + 'P', + 'Q', + 'R', + 'S', + 'T', + 'U', + 'V', + 'W', + 'X', + 'Y', + 'Z', + '-', + '.', + ' ', + '$', + '/', + '+', + '%', + '<', + '=', + '>', + '?', + ]; + + /** + * Calculate CODE 93 checksum (modulo 47). + * + * @param string $code Code to represent. + * + * @return string char checksum. + */ + protected function getChecksum(string $code): string + { + // translate special characters + $code = strtr($code, chr(128) . chr(131) . chr(129) . chr(130), '<=>?'); + $clen = strlen($code); + // calculate check digit C + $pck = 1; + $check = 0; + for ($idx = ($clen - 1); $idx >= 0; --$idx) { + $key = array_keys($this::CHKSUM, $code[$idx]); + $check += ($key[0] * $pck); + ++$pck; + if ($pck > 20) { + $pck = 1; + } + } + + $check %= 47; + $chk = $this::CHKSUM[$check]; + $code .= $chk; + // calculate check digit K + $pck = 1; + $check = 0; + for ($idx = $clen; $idx >= 0; --$idx) { + $key = array_keys($this::CHKSUM, $code[$idx]); + $check += ($key[0] * $pck); + ++$pck; + if ($pck > 15) { + $pck = 1; + } + } + + $check %= 47; + $key = $this::CHKSUM[$check]; + $checksum = $chk . $key; + // restore special characters + $checksum = strtr( + $checksum, + '<=>?', + chr(128) . chr(131) . chr(129) . chr(130) + ); + return $checksum; + } + + /** + * Set the bars array. + * + * @throws BarcodeException in case of error + * + * @SuppressWarnings("PHPMD.ExcessiveMethodLength") + */ + protected function setBars(): void + { + $this->ncols = 0; + $this->nrows = 1; + $this->bars = []; + $this->formatCode(); + $clen = strlen($this->extcode); + for ($chr = 0; $chr < $clen; ++$chr) { + $char = ord($this->extcode[$chr]); + for ($pos = 0; $pos < 6; ++$pos) { + $bar_width = (int) $this::CHBAR[$char][$pos]; + if (($pos % 2) == 0) { + $this->bars[] = [$this->ncols, 0, $bar_width, 1]; + } + + $this->ncols += $bar_width; + } + } + + $this->bars[] = [$this->ncols, 0, 1, 1]; + ++$this->ncols; + } +} diff --git a/vendor/tecnickcom/tc-lib-barcode/src/Type/Linear/CodeOneOne.php b/vendor/tecnickcom/tc-lib-barcode/src/Type/Linear/CodeOneOne.php new file mode 100644 index 0000000..ce091f3 --- /dev/null +++ b/vendor/tecnickcom/tc-lib-barcode/src/Type/Linear/CodeOneOne.php @@ -0,0 +1,154 @@ + + * @copyright 2010-2024 Nicola Asuni - Tecnick.com LTD + * @license http://www.gnu.org/copyleft/lesser.html GNU-LGPL v3 (see LICENSE.TXT) + * @link https://github.com/tecnickcom/tc-lib-barcode + * + * This file is part of tc-lib-barcode software library. + */ + +namespace Com\Tecnick\Barcode\Type\Linear; + +use Com\Tecnick\Barcode\Exception as BarcodeException; + +/** + * Com\Tecnick\Barcode\Type\Linear\CodeOneOne; + * + * CodeOneOne Barcode type class + * CODE 11 + * + * @since 2015-02-21 + * @category Library + * @package Barcode + * @author Nicola Asuni + * @copyright 2010-2024 Nicola Asuni - Tecnick.com LTD + * @license http://www.gnu.org/copyleft/lesser.html GNU-LGPL v3 (see LICENSE.TXT) + * @link https://github.com/tecnickcom/tc-lib-barcode + */ +class CodeOneOne extends \Com\Tecnick\Barcode\Type\Linear +{ + /** + * Barcode format + * + * @var string + */ + protected const FORMAT = 'CODE11'; + + /** + * Map characters to barcodes + * + * @var array + */ + protected const CHBAR = [ + '0' => '111121', + '1' => '211121', + '2' => '121121', + '3' => '221111', + '4' => '112121', + '5' => '212111', + '6' => '122111', + '7' => '111221', + '8' => '211211', + '9' => '211111', + '-' => '112111', + 'S' => '112211', + ]; + + /** + * Calculate the checksum. + * + * @param string $code Code to represent. + * + * @return string char checksum. + */ + protected function getChecksum(string $code): string + { + $len = strlen($code); + // calculate check digit C + $ptr = 1; + $ccheck = 0; + for ($pos = ($len - 1); $pos >= 0; --$pos) { + $digit = $code[$pos]; + $dval = $digit == '-' ? 10 : (int) $digit; + + $ccheck += ($dval * $ptr); + ++$ptr; + if ($ptr > 10) { + $ptr = 1; + } + } + + $ccheck %= 11; + if ($ccheck == 10) { + $ccheck = '-'; + } + + if ($len <= 10) { + return ((string) $ccheck); + } + + // calculate check digit K + $code .= $ccheck; + $ptr = 1; + $kcheck = 0; + for ($pos = $len; $pos >= 0; --$pos) { + $digit = $code[$pos]; + $dval = $digit == '-' ? 10 : (int) $digit; + + $kcheck += ($dval * $ptr); + ++$ptr; + if ($ptr > 9) { + $ptr = 1; + } + } + + $kcheck %= 11; + return ((string) $ccheck . $kcheck); + } + + /** + * Format code + */ + protected function formatCode(): void + { + $this->extcode = 'S' . $this->code . $this->getChecksum($this->code) . 'S'; + } + + /** + * Set the bars array. + * + * @throws BarcodeException in case of error + */ + protected function setBars(): void + { + $this->ncols = 0; + $this->nrows = 1; + $this->bars = []; + $this->formatCode(); + $clen = strlen($this->extcode); + for ($chr = 0; $chr < $clen; ++$chr) { + $char = $this->extcode[$chr]; + if (! isset($this::CHBAR[$char])) { + throw new BarcodeException('Invalid character: chr(' . ord($char) . ')'); + } + + for ($pos = 0; $pos < 6; ++$pos) { + $bar_width = (int) $this::CHBAR[$char][$pos]; + if ((($pos % 2) == 0) && ($bar_width > 0)) { + $this->bars[] = [$this->ncols, 0, $bar_width, 1]; + } + + $this->ncols += $bar_width; + } + } + + --$this->ncols; + } +} diff --git a/vendor/tecnickcom/tc-lib-barcode/src/Type/Linear/CodeOneTwoEight.php b/vendor/tecnickcom/tc-lib-barcode/src/Type/Linear/CodeOneTwoEight.php new file mode 100644 index 0000000..3bfbc42 --- /dev/null +++ b/vendor/tecnickcom/tc-lib-barcode/src/Type/Linear/CodeOneTwoEight.php @@ -0,0 +1,249 @@ + + * @copyright 2010-2024 Nicola Asuni - Tecnick.com LTD + * @license http://www.gnu.org/copyleft/lesser.html GNU-LGPL v3 (see LICENSE.TXT) + * @link https://github.com/tecnickcom/tc-lib-barcode + * + * This file is part of tc-lib-barcode software library. + */ + +namespace Com\Tecnick\Barcode\Type\Linear; + +use Com\Tecnick\Barcode\Exception as BarcodeException; + +/** + * Com\Tecnick\Barcode\Type\Linear\CodeOneTwoEight; + * + * CodeOneTwoEight Barcode type class + * CODE 128 + * + * @since 2015-02-21 + * @category Library + * @package Barcode + * @author Nicola Asuni + * @copyright 2010-2024 Nicola Asuni - Tecnick.com LTD + * @license http://www.gnu.org/copyleft/lesser.html GNU-LGPL v3 (see LICENSE.TXT) + * @link https://github.com/tecnickcom/tc-lib-barcode + */ +class CodeOneTwoEight extends \Com\Tecnick\Barcode\Type\Linear\CodeOneTwoEight\Process +{ + /** + * Get the coe point array + * + * @return array + * + * @throws BarcodeException in case of error + */ + protected function getCodeData(): array + { + $code = $this->code; + // array of symbols + $code_data = []; + // split code into sequences + $sequence = $this->getNumericSequence($code); + // process the sequence + $startid = 0; + foreach ($sequence as $key => $seq) { + $processMethod = 'processSequence' . $seq[0]; + $this->$processMethod($sequence, $code_data, $startid, $key, $seq); + } + + return $this->finalizeCodeData($code_data, $startid); + } + + /** + * Process the A sequence + * + * @param array> $sequence Sequence to process + * @param array $code_data Array of codepoints to alter + * @param int $startid Start ID + * @param int $key Sequence current key + * @param array{string, string, int} $seq Sequence current value + * + * @throws BarcodeException in case of error + */ + protected function processSequenceA( + array &$sequence, + array &$code_data, + int &$startid, + int $key, + array $seq + ): void { + if ($key == 0) { + $startid = 103; + } elseif ($sequence[($key - 1)][0] != 'A') { + if ( + ($seq[2] == 1) + && ($key > 0) + && ($sequence[($key - 1)][0] == 'B') + && (! isset($sequence[($key - 1)][3])) + ) { + // single character shift + $code_data[] = 98; + // mark shift + $sequence[$key][3] = ''; + } elseif (! isset($sequence[($key - 1)][3])) { + $code_data[] = 101; + } + } + + $this->getCodeDataA($code_data, $seq[1], (int) $seq[2]); + } + + /** + * Process the B sequence + * + * @param array> $sequence Sequence to process + * @param array $code_data Array of codepoints to alter + * @param int $startid Start ID + * @param int $key Sequence current key + * @param array{string, string, int} $seq Sequence current value + * + * @throws BarcodeException in case of error + */ + protected function processSequenceB( + array &$sequence, + array &$code_data, + int &$startid, + int $key, + array $seq + ): void { + if ($key == 0) { + $this->processSequenceBA($sequence, $code_data, $startid, $key, $seq); + } elseif ($sequence[($key - 1)][0] != 'B') { + $this->processSequenceBB($sequence, $code_data, $key, $seq); + } + + $this->getCodeDataB($code_data, $seq[1], (int) $seq[2]); + } + + /** + * Process the B-A sequence + * + * @param array> $sequence Sequence to process + * @param array $code_data Array of codepoints to alter + * @param int $startid Start ID + * @param int $key Sequence current key + * @param array{string, string, int} $seq Sequence current value + * + * @throws BarcodeException in case of error + */ + protected function processSequenceBA( + array &$sequence, + array &$code_data, + int &$startid, + int $key, + array $seq + ): void { + $tmpchr = ord($seq[1][0]); + if ( + ($seq[2] == 1) + && ($tmpchr >= 241) + && ($tmpchr <= 244) + && isset($sequence[($key + 1)]) + && ($sequence[($key + 1)][0] != 'B') + ) { + switch ($sequence[($key + 1)][0]) { + case 'A': + $startid = 103; + $sequence[$key][0] = 'A'; + $code_data[] = $this::FNC_A[$tmpchr]; + break; + case 'C': + $startid = 105; + $sequence[$key][0] = 'C'; + $code_data[] = $this::FNC_A[$tmpchr]; + break; + } + } else { + $startid = 104; + } + } + + /** + * Process the B-B sequence + * + * @param array> $sequence Sequence to process + * @param array $code_data Array of codepoints to alter + * @param int $key Sequence current key + * @param array{string, string, int} $seq Sequence current value + */ + protected function processSequenceBB( + array &$sequence, + array &$code_data, + int $key, + array $seq + ): void { + if ( + ($seq[2] == 1) + && ($key > 0) + && ($sequence[($key - 1)][0] == 'A') + && (! isset($sequence[($key - 1)][3])) + ) { + // single character shift + $code_data[] = 98; + // mark shift + $sequence[$key][3] = ''; + } elseif (! isset($sequence[($key - 1)][3])) { + $code_data[] = 100; + } + } + + /** + * Process the C sequence + * + * @param array> $sequence Sequence to process + * @param array $code_data Array of codepoints to alter + * @param int $startid Start ID + * @param int $key Sequence current key + * @param array{string, string, int} $seq Sequence current value + * + * @throws BarcodeException in case of error + */ + protected function processSequenceC( + array &$sequence, + array &$code_data, + int &$startid, + int $key, + array $seq + ): void { + if ($key == 0) { + $startid = 105; + } elseif ($sequence[($key - 1)][0] != 'C') { + $code_data[] = 99; + } + + $this->getCodeDataC($code_data, $seq[1]); + } + + /** + * Set the bars array. + * + * @throws BarcodeException in case of error + */ + protected function setBars(): void + { + $code_data = $this->getCodeData(); + $this->ncols = 0; + $this->nrows = 1; + $this->bars = []; + foreach ($code_data as $val) { + $seq = $this::CHBAR[$val]; + for ($pos = 0; $pos < 6; ++$pos) { + $bar_width = (int) $seq[$pos]; + if ((($pos % 2) == 0) && ($bar_width > 0)) { + $this->bars[] = [$this->ncols, 0, $bar_width, 1]; + } + + $this->ncols += $bar_width; + } + } + } +} diff --git a/vendor/tecnickcom/tc-lib-barcode/src/Type/Linear/CodeOneTwoEight/CodeOneTwoEightA.php b/vendor/tecnickcom/tc-lib-barcode/src/Type/Linear/CodeOneTwoEight/CodeOneTwoEightA.php new file mode 100644 index 0000000..95e6fc7 --- /dev/null +++ b/vendor/tecnickcom/tc-lib-barcode/src/Type/Linear/CodeOneTwoEight/CodeOneTwoEightA.php @@ -0,0 +1,59 @@ + + * @copyright 2010-2024 Nicola Asuni - Tecnick.com LTD + * @license http://www.gnu.org/copyleft/lesser.html GNU-LGPL v3 (see LICENSE.TXT) + * @link https://github.com/tecnickcom/tc-lib-barcode + * + * This file is part of tc-lib-barcode software library. + */ + +namespace Com\Tecnick\Barcode\Type\Linear\CodeOneTwoEight; + +use Com\Tecnick\Barcode\Exception as BarcodeException; + +/** + * Com\Tecnick\Barcode\Type\Linear\CodeOneTwoEight\A; + * + * CodeOneTwoEightA Barcode type class + * CODE 128 A + * + * @since 2015-02-21 + * @category Library + * @package Barcode + * @author Nicola Asuni + * @copyright 2010-2024 Nicola Asuni - Tecnick.com LTD + * @license http://www.gnu.org/copyleft/lesser.html GNU-LGPL v3 (see LICENSE.TXT) + * @link https://github.com/tecnickcom/tc-lib-barcode + */ +class CodeOneTwoEightA extends \Com\Tecnick\Barcode\Type\Linear\CodeOneTwoEight +{ + /** + * Barcode format + * + * @var string + */ + protected const FORMAT = 'C128A'; + + /** + * Get the code point array + * + * @return array + * + * @throws BarcodeException in case of error + */ + protected function getCodeData(): array + { + $code = $this->code; + $len = strlen($code); + $code_data = []; + $this->getCodeDataA($code_data, $code, $len); + return $this->finalizeCodeData($code_data, 103); + } +} diff --git a/vendor/tecnickcom/tc-lib-barcode/src/Type/Linear/CodeOneTwoEight/CodeOneTwoEightB.php b/vendor/tecnickcom/tc-lib-barcode/src/Type/Linear/CodeOneTwoEight/CodeOneTwoEightB.php new file mode 100644 index 0000000..63ec35c --- /dev/null +++ b/vendor/tecnickcom/tc-lib-barcode/src/Type/Linear/CodeOneTwoEight/CodeOneTwoEightB.php @@ -0,0 +1,59 @@ + + * @copyright 2010-2024 Nicola Asuni - Tecnick.com LTD + * @license http://www.gnu.org/copyleft/lesser.html GNU-LGPL v3 (see LICENSE.TXT) + * @link https://github.com/tecnickcom/tc-lib-barcode + * + * This file is part of tc-lib-barcode software library. + */ + +namespace Com\Tecnick\Barcode\Type\Linear\CodeOneTwoEight; + +use Com\Tecnick\Barcode\Exception as BarcodeException; + +/** + * Com\Tecnick\Barcode\Type\Linear\CodeOneTwoEight\B; + * + * CodeOneTwoEightB Barcode type class + * CODE 128 B + * + * @since 2015-02-21 + * @category Library + * @package Barcode + * @author Nicola Asuni + * @copyright 2010-2024 Nicola Asuni - Tecnick.com LTD + * @license http://www.gnu.org/copyleft/lesser.html GNU-LGPL v3 (see LICENSE.TXT) + * @link https://github.com/tecnickcom/tc-lib-barcode + */ +class CodeOneTwoEightB extends \Com\Tecnick\Barcode\Type\Linear\CodeOneTwoEight +{ + /** + * Barcode format + * + * @var string + */ + protected const FORMAT = 'C128B'; + + /** + * Get the code point array + * + * @return array + * + * @throws BarcodeException in case of error + */ + protected function getCodeData(): array + { + $code = $this->code; + $len = strlen($code); + $code_data = []; + $this->getCodeDataB($code_data, $code, $len); + return $this->finalizeCodeData($code_data, 104); + } +} diff --git a/vendor/tecnickcom/tc-lib-barcode/src/Type/Linear/CodeOneTwoEight/CodeOneTwoEightC.php b/vendor/tecnickcom/tc-lib-barcode/src/Type/Linear/CodeOneTwoEight/CodeOneTwoEightC.php new file mode 100644 index 0000000..951f35e --- /dev/null +++ b/vendor/tecnickcom/tc-lib-barcode/src/Type/Linear/CodeOneTwoEight/CodeOneTwoEightC.php @@ -0,0 +1,63 @@ + + * @copyright 2010-2024 Nicola Asuni - Tecnick.com LTD + * @license http://www.gnu.org/copyleft/lesser.html GNU-LGPL v3 (see LICENSE.TXT) + * @link https://github.com/tecnickcom/tc-lib-barcode + * + * This file is part of tc-lib-barcode software library. + */ + +namespace Com\Tecnick\Barcode\Type\Linear\CodeOneTwoEight; + +use Com\Tecnick\Barcode\Exception as BarcodeException; + +/** + * Com\Tecnick\Barcode\Type\Linear\CodeOneTwoEight\C; + * + * CodeOneTwoEightC Barcode type class + * CODE 128 C + * + * @since 2015-02-21 + * @category Library + * @package Barcode + * @author Nicola Asuni + * @copyright 2010-2024 Nicola Asuni - Tecnick.com LTD + * @license http://www.gnu.org/copyleft/lesser.html GNU-LGPL v3 (see LICENSE.TXT) + * @link https://github.com/tecnickcom/tc-lib-barcode + */ +class CodeOneTwoEightC extends \Com\Tecnick\Barcode\Type\Linear\CodeOneTwoEight +{ + /** + * Barcode format + * + * @var string + */ + protected const FORMAT = 'C128C'; + + /** + * Get the code point array + * + * @return array + * + * @throws BarcodeException in case of error + */ + protected function getCodeData(): array + { + $code = $this->code; + $code_data = []; + if (ord($code[0]) == 241) { + $code_data[] = 102; + $code = substr($code, 1); + } + + $this->getCodeDataC($code_data, $code); + return $this->finalizeCodeData($code_data, 105); + } +} diff --git a/vendor/tecnickcom/tc-lib-barcode/src/Type/Linear/CodeOneTwoEight/Process.php b/vendor/tecnickcom/tc-lib-barcode/src/Type/Linear/CodeOneTwoEight/Process.php new file mode 100644 index 0000000..df96623 --- /dev/null +++ b/vendor/tecnickcom/tc-lib-barcode/src/Type/Linear/CodeOneTwoEight/Process.php @@ -0,0 +1,432 @@ + + * @copyright 2010-2024 Nicola Asuni - Tecnick.com LTD + * @license http://www.gnu.org/copyleft/lesser.html GNU-LGPL v3 (see LICENSE.TXT) + * @link https://github.com/tecnickcom/tc-lib-barcode + * + * This file is part of tc-lib-barcode software library. + */ + +namespace Com\Tecnick\Barcode\Type\Linear\CodeOneTwoEight; + +use Com\Tecnick\Barcode\Exception as BarcodeException; + +/** + * Com\Tecnick\Barcode\Type\Linear\CodeOneTwoEight\Process; + * + * Process methods for CodeOneTwoEight Barcode type class + * CODE 128 + * + * @since 2015-02-21 + * @category Library + * @package Barcode + * @author Nicola Asuni + * @copyright 2010-2024 Nicola Asuni - Tecnick.com LTD + * @license http://www.gnu.org/copyleft/lesser.html GNU-LGPL v3 (see LICENSE.TXT) + * @link https://github.com/tecnickcom/tc-lib-barcode + */ +abstract class Process extends \Com\Tecnick\Barcode\Type\Linear +{ + /** + * Barcode format + * + * @var string + */ + protected const FORMAT = 'C128'; + + /** + * Map characters to barcodes + * + * @var array + */ + protected const CHBAR = [ + '212222', // 00 + '222122', // 01 + '222221', // 02 + '121223', // 03 + '121322', // 04 + '131222', // 05 + '122213', // 06 + '122312', // 07 + '132212', // 08 + '221213', // 09 + '221312', // 10 + '231212', // 11 + '112232', // 12 + '122132', // 13 + '122231', // 14 + '113222', // 15 + '123122', // 16 + '123221', // 17 + '223211', // 18 + '221132', // 19 + '221231', // 20 + '213212', // 21 + '223112', // 22 + '312131', // 23 + '311222', // 24 + '321122', // 25 + '321221', // 26 + '312212', // 27 + '322112', // 28 + '322211', // 29 + '212123', // 30 + '212321', // 31 + '232121', // 32 + '111323', // 33 + '131123', // 34 + '131321', // 35 + '112313', // 36 + '132113', // 37 + '132311', // 38 + '211313', // 39 + '231113', // 40 + '231311', // 41 + '112133', // 42 + '112331', // 43 + '132131', // 44 + '113123', // 45 + '113321', // 46 + '133121', // 47 + '313121', // 48 + '211331', // 49 + '231131', // 50 + '213113', // 51 + '213311', // 52 + '213131', // 53 + '311123', // 54 + '311321', // 55 + '331121', // 56 + '312113', // 57 + '312311', // 58 + '332111', // 59 + '314111', // 60 + '221411', // 61 + '431111', // 62 + '111224', // 63 + '111422', // 64 + '121124', // 65 + '121421', // 66 + '141122', // 67 + '141221', // 68 + '112214', // 69 + '112412', // 70 + '122114', // 71 + '122411', // 72 + '142112', // 73 + '142211', // 74 + '241211', // 75 + '221114', // 76 + '413111', // 77 + '241112', // 78 + '134111', // 79 + '111242', // 80 + '121142', // 81 + '121241', // 82 + '114212', // 83 + '124112', // 84 + '124211', // 85 + '411212', // 86 + '421112', // 87 + '421211', // 88 + '212141', // 89 + '214121', // 90 + '412121', // 91 + '111143', // 92 + '111341', // 93 + '131141', // 94 + '114113', // 95 + '114311', // 96 + '411113', // 97 + '411311', // 98 + '113141', // 99 + '114131', // 100 + '311141', // 101 + '411131', // 102 + '211412', // 103 START A + '211214', // 104 START B + '211232', // 105 START C + '233111', // STOP + '200000', // END + ]; + + /** + * Map ASCII characters for code A (ASCII 00 - 95) + * // 128A (Code Set A) - ASCII characters 00 to 95 (0-9, A-Z and control codes), special characters + * + * @var string + */ + protected const KEYS_A = ' !"#$%&\'()*+,-./' + . '0123456789' + . ':;<=>?@' + . 'ABCDEFGHIJKLMNOPQRSTUVWXYZ' + . '[\\]^_' + . "\x00\x01\x02\x03\x04\x05\x06\x07\x08\x09\x0A\x0B\x0C\x0D\x0E\x0F" + . "\x10\x11\x12\x13\x14\x15\x16\x17\x18\x19\x1A\x1B\x1C\x1D\x1E\x1F"; + + /** + * Map ASCII characters for code B (ASCII 32 - 127) + * // 128B (Code Set B) - ASCII characters 32 to 127 (0-9, A-Z, a-z), special characters + * + * @var string + */ + protected const KEYS_B = ' !"#$%&\'()*+,-./' + . '0123456789' + . ':;<=>?@' + . 'ABCDEFGHIJKLMNOPQRSTUVWXYZ' + . '[\\]^_`' + . 'abcdefghijklmnopqrstuvwxyz' + . '{|}~' + . "\x7F"; + + /** + * Map special FNC codes for Code Set A (FNC 1-4) + * + * @var array + */ + protected const FNC_A = [ + 241 => 102, + 242 => 97, + 243 => 96, + 244 => 101, + ]; + + /** + * Map special FNC codes for Code Set B (FNC 1-4) + * + * @var array + */ + protected const FNC_B = [ + 241 => 102, + 242 => 97, + 243 => 96, + 244 => 100, + ]; + + /** + * Get the numeric sequence (if any) + * + * @param string $code Code to parse + * + * @return array + * + * @throws BarcodeException in case of error + */ + protected function getNumericSequence(string $code): array + { + $sequence = []; + $len = strlen($code); + // get numeric sequences (if any) + $numseq = []; + preg_match_all('/(\d{4,})/', $code, $numseq, PREG_OFFSET_CAPTURE); + if (! empty($numseq[1])) { + $end_offset = 0; + foreach ($numseq[1] as $val) { + // offset to the start of numeric substr + $offset = $val[1]; + + // numeric sequence + $slen = strlen($val[0]); + if ($slen % 2 != 0) { + // the length must be even + --$slen; + // add 1 to start of offset so numbers are c type encoded "from the end" + ++$offset; + } + + if ($offset > $end_offset) { + // non numeric sequence + $sequence = array_merge( + $sequence, + $this->get128ABsequence(substr($code, $end_offset, ($offset - $end_offset))) + ); + } + + $sequence[] = ['C', substr($code, $offset, $slen), $slen]; + $end_offset = $offset + $slen; + } + + if ($end_offset < $len) { + $sequence = array_merge($sequence, $this->get128ABsequence(substr($code, $end_offset))); + } + } else { + // text code (non C mode) + $sequence = array_merge($sequence, $this->get128ABsequence($code)); + } + + return $sequence; + } + + /** + * Split text code in A/B sequence for 128 code + * + * @param string $code Code to split + * + * @return array + */ + protected function get128ABsequence(string $code): array + { + $len = strlen($code); + $sequence = []; + // get A sequences (if any) + $aseq = []; + preg_match_all('/([\x00-\x1f])/', $code, $aseq, PREG_OFFSET_CAPTURE); + if (! empty($aseq[1])) { + // get the entire A sequence (excluding FNC1-FNC4) + preg_match_all('/([\x00-\x5f]+)/', $code, $aseq, PREG_OFFSET_CAPTURE); + $end_offset = 0; + foreach ($aseq[1] as $val) { + $offset = $val[1]; + if ($offset > $end_offset) { + // B sequence + $sequence[] = ['B', substr($code, $end_offset, ($offset - $end_offset)), ($offset - $end_offset)]; + } + + // A sequence + $slen = strlen($val[0]); + $sequence[] = ['A', substr($code, $offset, $slen), $slen]; + $end_offset = $offset + $slen; + } + + if ($end_offset < $len) { + $sequence[] = ['B', substr($code, $end_offset), ($len - $end_offset)]; + } + } else { + // only B sequence + $sequence[] = ['B', $code, $len]; + } + + return $sequence; + } + + /** + * Get the A code point array + * + * @param array $code_data Array of codepoints to alter + * @param string $code Code to process + * @param int $len Number of characters to process + * + * @throws BarcodeException in case of error + */ + protected function getCodeDataA( + array &$code_data, + string $code, + int $len + ): void { + for ($pos = 0; $pos < $len; ++$pos) { + $char = $code[$pos]; + $char_id = ord($char); + if (($char_id >= 241) && ($char_id <= 244)) { + $code_data[] = $this::FNC_A[$char_id]; + } elseif ($char_id <= 95) { + $cdpos = strpos($this::KEYS_A, $char); + $code_data[] = is_int($cdpos) ? $cdpos : 0; + } else { + throw new BarcodeException('Invalid character sequence'); + } + } + } + + /** + * Get the B code point array + * + * @param array $code_data Array of codepoints to alter + * @param string $code Code to process + * @param int $len Number of characters to process + * + * @throws BarcodeException in case of error + */ + protected function getCodeDataB( + array &$code_data, + string $code, + int $len + ): void { + for ($pos = 0; $pos < $len; ++$pos) { + $char = $code[$pos]; + $char_id = ord($char); + if (($char_id >= 241) && ($char_id <= 244)) { + $code_data[] = $this::FNC_B[$char_id]; + } elseif (($char_id >= 32) && ($char_id <= 127)) { + $cdpos = strpos($this::KEYS_B, $char); + $code_data[] = is_int($cdpos) ? $cdpos : 0; + } else { + throw new BarcodeException('Invalid character sequence: ' . $char_id); + } + } + } + + /** + * Get the C code point array + * + * @param array $code_data Array of codepoints to alter + * @param string $code Code to process + * + * @throws BarcodeException in case of error + */ + protected function getCodeDataC( + array &$code_data, + string $code + ): void { + // code blocks separated by FNC1 (chr 241) + $blocks = explode(chr(241), $code); + + foreach ($blocks as $block) { + $len = strlen($block); + + if ($len % 2 != 0) { + throw new BarcodeException('The length of each FNC1-separated code block must be even'); + } + + for ($pos = 0; $pos < $len; $pos += 2) { + $chrnum = $block[$pos] . $block[($pos + 1)]; + if (preg_match('/(\d{2})/', $chrnum) > 0) { + $code_data[] = (int) $chrnum; + } else { + throw new BarcodeException('Invalid character sequence'); + } + } + + $code_data[] = 102; + } + + // remove last 102 code + array_pop($code_data); + } + + /** + * Finalize code data + * + * @param array $code_data Array of codepoints to alter + * @param int $startid Start ID code + * + * @return array Array of codepoints + */ + protected function finalizeCodeData( + array $code_data, + int $startid + ): array { + // calculate check character + $sum = $startid; + foreach ($code_data as $key => $val) { + $sum += ($val * ($key + 1)); + } + + // add check character + $code_data[] = ($sum % 103); + + // add stop sequence + $code_data[] = 106; + $code_data[] = 107; + // add start code at the beginning + array_unshift($code_data, $startid); + + return $code_data; + } +} diff --git a/vendor/tecnickcom/tc-lib-barcode/src/Type/Linear/CodeThreeNine.php b/vendor/tecnickcom/tc-lib-barcode/src/Type/Linear/CodeThreeNine.php new file mode 100644 index 0000000..99ac704 --- /dev/null +++ b/vendor/tecnickcom/tc-lib-barcode/src/Type/Linear/CodeThreeNine.php @@ -0,0 +1,49 @@ + + * @copyright 2010-2024 Nicola Asuni - Tecnick.com LTD + * @license http://www.gnu.org/copyleft/lesser.html GNU-LGPL v3 (see LICENSE.TXT) + * @link https://github.com/tecnickcom/tc-lib-barcode + * + * This file is part of tc-lib-barcode software library. + */ + +namespace Com\Tecnick\Barcode\Type\Linear; + +/** + * Com\Tecnick\Barcode\CodeThreeNine + * + * CodeThreeNine Barcode type class + * CODE 39 + * + * @since 2015-02-21 + * @category Library + * @package Barcode + * @author Nicola Asuni + * @copyright 2010-2024 Nicola Asuni - Tecnick.com LTD + * @license http://www.gnu.org/copyleft/lesser.html GNU-LGPL v3 (see LICENSE.TXT) + * @link https://github.com/tecnickcom/tc-lib-barcode + */ +class CodeThreeNine extends \Com\Tecnick\Barcode\Type\Linear\CodeThreeNineExtCheck +{ + /** + * Barcode format + * + * @var string + */ + protected const FORMAT = 'C39'; + + /** + * Format code + */ + protected function formatCode(): void + { + $this->extcode = '*' . strtoupper($this->code) . '*'; + } +} diff --git a/vendor/tecnickcom/tc-lib-barcode/src/Type/Linear/CodeThreeNineCheck.php b/vendor/tecnickcom/tc-lib-barcode/src/Type/Linear/CodeThreeNineCheck.php new file mode 100644 index 0000000..5f83df0 --- /dev/null +++ b/vendor/tecnickcom/tc-lib-barcode/src/Type/Linear/CodeThreeNineCheck.php @@ -0,0 +1,50 @@ + + * @copyright 2010-2024 Nicola Asuni - Tecnick.com LTD + * @license http://www.gnu.org/copyleft/lesser.html GNU-LGPL v3 (see LICENSE.TXT) + * @link https://github.com/tecnickcom/tc-lib-barcode + * + * This file is part of tc-lib-barcode software library. + */ + +namespace Com\Tecnick\Barcode\Type\Linear; + +/** + * Com\Tecnick\Barcode\CodeThreeNineCheck + * + * CodeThreeNineCheck Barcode type class + * CODE 39 + CHECKSUM + * + * @since 2015-02-21 + * @category Library + * @package Barcode + * @author Nicola Asuni + * @copyright 2010-2024 Nicola Asuni - Tecnick.com LTD + * @license http://www.gnu.org/copyleft/lesser.html GNU-LGPL v3 (see LICENSE.TXT) + * @link https://github.com/tecnickcom/tc-lib-barcode + */ +class CodeThreeNineCheck extends \Com\Tecnick\Barcode\Type\Linear\CodeThreeNineExtCheck +{ + /** + * Barcode format + * + * @var string + */ + protected const FORMAT = 'C39+'; + + /** + * Format code + */ + protected function formatCode(): void + { + $code = strtoupper($this->code); + $this->extcode = '*' . $code . $this->getChecksum($code) . '*'; + } +} diff --git a/vendor/tecnickcom/tc-lib-barcode/src/Type/Linear/CodeThreeNineExt.php b/vendor/tecnickcom/tc-lib-barcode/src/Type/Linear/CodeThreeNineExt.php new file mode 100644 index 0000000..29f089e --- /dev/null +++ b/vendor/tecnickcom/tc-lib-barcode/src/Type/Linear/CodeThreeNineExt.php @@ -0,0 +1,49 @@ + + * @copyright 2010-2024 Nicola Asuni - Tecnick.com LTD + * @license http://www.gnu.org/copyleft/lesser.html GNU-LGPL v3 (see LICENSE.TXT) + * @link https://github.com/tecnickcom/tc-lib-barcode + * + * This file is part of tc-lib-barcode software library. + */ + +namespace Com\Tecnick\Barcode\Type\Linear; + +/** + * Com\Tecnick\Barcode\CodeThreeNineExt + * + * CodeThreeNineExt Barcode type class + * CODE 39 EXTENDED + * + * @since 2015-02-21 + * @category Library + * @package Barcode + * @author Nicola Asuni + * @copyright 2010-2024 Nicola Asuni - Tecnick.com LTD + * @license http://www.gnu.org/copyleft/lesser.html GNU-LGPL v3 (see LICENSE.TXT) + * @link https://github.com/tecnickcom/tc-lib-barcode + */ +class CodeThreeNineExt extends \Com\Tecnick\Barcode\Type\Linear\CodeThreeNineExtCheck +{ + /** + * Barcode format + * + * @var string + */ + protected const FORMAT = 'C39E'; + + /** + * Format code + */ + protected function formatCode(): void + { + $this->extcode = '*' . $this->getExtendCode(strtoupper($this->code)) . '*'; + } +} diff --git a/vendor/tecnickcom/tc-lib-barcode/src/Type/Linear/CodeThreeNineExtCheck.php b/vendor/tecnickcom/tc-lib-barcode/src/Type/Linear/CodeThreeNineExtCheck.php new file mode 100644 index 0000000..f2e8861 --- /dev/null +++ b/vendor/tecnickcom/tc-lib-barcode/src/Type/Linear/CodeThreeNineExtCheck.php @@ -0,0 +1,368 @@ + + * @copyright 2010-2024 Nicola Asuni - Tecnick.com LTD + * @license http://www.gnu.org/copyleft/lesser.html GNU-LGPL v3 (see LICENSE.TXT) + * @link https://github.com/tecnickcom/tc-lib-barcode + * + * This file is part of tc-lib-barcode software library. + */ + +namespace Com\Tecnick\Barcode\Type\Linear; + +use Com\Tecnick\Barcode\Exception as BarcodeException; + +/** + * Com\Tecnick\Barcode\Type\Linear\CodeThreeNineExtCheck + * + * CodeThreeNineExtCheck Barcode type class + * CODE 39 EXTENDED + CHECKSUM + * + * @since 2015-02-21 + * @category Library + * @package Barcode + * @author Nicola Asuni + * @copyright 2010-2024 Nicola Asuni - Tecnick.com LTD + * @license http://www.gnu.org/copyleft/lesser.html GNU-LGPL v3 (see LICENSE.TXT) + * @link https://github.com/tecnickcom/tc-lib-barcode + */ +class CodeThreeNineExtCheck extends \Com\Tecnick\Barcode\Type\Linear +{ + /** + * Barcode format + * + * @var string + */ + protected const FORMAT = 'C39E+'; + + /** + * Map characters to barcodes + * + * @var array + */ + protected const CHBAR = [ + '0' => '111331311', + '1' => '311311113', + '2' => '113311113', + '3' => '313311111', + '4' => '111331113', + '5' => '311331111', + '6' => '113331111', + '7' => '111311313', + '8' => '311311311', + '9' => '113311311', + 'A' => '311113113', + 'B' => '113113113', + 'C' => '313113111', + 'D' => '111133113', + 'E' => '311133111', + 'F' => '113133111', + 'G' => '111113313', + 'H' => '311113311', + 'I' => '113113311', + 'J' => '111133311', + 'K' => '311111133', + 'L' => '113111133', + 'M' => '313111131', + 'N' => '111131133', + 'O' => '311131131', + 'P' => '113131131', + 'Q' => '111111333', + 'R' => '311111331', + 'S' => '113111331', + 'T' => '111131331', + 'U' => '331111113', + 'V' => '133111113', + 'W' => '333111111', + 'X' => '131131113', + 'Y' => '331131111', + 'Z' => '133131111', + '-' => '131111313', + '.' => '331111311', + ' ' => '133111311', + '$' => '131313111', + '/' => '131311131', + '+' => '131113131', + '%' => '111313131', + '*' => '131131311', + ]; + + /** + * Map for extended characters + * + * @var array + */ + protected const EXTCODES = [ + '%U', + '$A', + '$B', + '$C', + '$D', + '$E', + '$F', + '$G', + '$H', + '$I', + '$J', + '$K', + '$L', + '$M', + '$N', + '$O', + '$P', + '$Q', + '$R', + '$S', + '$T', + '$U', + '$V', + '$W', + '$X', + '$Y', + '$Z', + '%A', + '%B', + '%C', + '%D', + '%E', + ' ', + '/A', + '/B', + '/C', + '/D', + '/E', + '/F', + '/G', + '/H', + '/I', + '/J', + '/K', + '/L', + '-', + '.', + '/O', + '0', + '1', + '2', + '3', + '4', + '5', + '6', + '7', + '8', + '9', + '/Z', + '%F', + '%G', + '%H', + '%I', + '%J', + '%V', + 'A', + 'B', + 'C', + 'D', + 'E', + 'F', + 'G', + 'H', + 'I', + 'J', + 'K', + 'L', + 'M', + 'N', + 'O', + 'P', + 'Q', + 'R', + 'S', + 'T', + 'U', + 'V', + 'W', + 'X', + 'Y', + 'Z', + '%K', + '%L', + '%M', + '%N', + '%O', + '%W', + '+A', + '+B', + '+C', + '+D', + '+E', + '+F', + '+G', + '+H', + '+I', + '+J', + '+K', + '+L', + '+M', + '+N', + '+O', + '+P', + '+Q', + '+R', + '+S', + '+T', + '+U', + '+V', + '+W', + '+X', + '+Y', + '+Z', + '%P', + '%Q', + '%R', + '%S', + '%T', + ]; + + /** + * Characters used for checksum + * + * @var array + */ + protected const CHKSUM = [ + '0', + '1', + '2', + '3', + '4', + '5', + '6', + '7', + '8', + '9', + 'A', + 'B', + 'C', + 'D', + 'E', + 'F', + 'G', + 'H', + 'I', + 'J', + 'K', + 'L', + 'M', + 'N', + 'O', + 'P', + 'Q', + 'R', + 'S', + 'T', + 'U', + 'V', + 'W', + 'X', + 'Y', + 'Z', + '-', + '.', + ' ', + '$', + '/', + '+', + '%', + ]; + + /** + * Encode a string to be used for CODE 39 Extended mode. + * + * @param string $code Code to extend + * + * @throws BarcodeException in case of error + */ + protected function getExtendCode(string $code): string + { + $ext = ''; + $clen = strlen($code); + for ($chr = 0; $chr < $clen; ++$chr) { + $item = ord($code[$chr]); + if ($item > 127) { + throw new BarcodeException('Invalid character: chr(' . $item . ')'); + } + + $ext .= $this::EXTCODES[$item]; + } + + return $ext; + } + + /** + * Calculate CODE 39 checksum (modulo 43). + * + * @param string $code Code to represent. + * + * @return string char checksum. + */ + protected function getChecksum(string $code): string + { + $sum = 0; + $clen = strlen($code); + for ($chr = 0; $chr < $clen; ++$chr) { + $key = array_keys($this::CHKSUM, $code[$chr]); + $sum += $key[0]; + } + + $idx = ($sum % 43); + return $this::CHKSUM[$idx]; + } + + /** + * Format code + */ + protected function formatCode(): void + { + $code = $this->getExtendCode(strtoupper($this->code)); + $this->extcode = '*' . $code . $this->getChecksum($code) . '*'; + } + + /** + * Set the bars array. + * + * @throws BarcodeException in case of error + */ + protected function setBars(): void + { + $this->ncols = 0; + $this->nrows = 1; + $this->bars = []; + $this->formatCode(); + $clen = strlen($this->extcode); + for ($chr = 0; $chr < $clen; ++$chr) { + $char = $this->extcode[$chr]; + if (! isset($this::CHBAR[$char])) { + throw new BarcodeException('Invalid character: chr(' . ord($char) . ')'); + } + + for ($pos = 0; $pos < 9; ++$pos) { + $bar_width = (int) $this::CHBAR[$char][$pos]; + if ((($pos % 2) == 0) && ($bar_width > 0)) { + $this->bars[] = [$this->ncols, 0, $bar_width, 1]; + } + + $this->ncols += $bar_width; + } + + // intercharacter gap + ++$this->ncols; + } + + --$this->ncols; + } +} diff --git a/vendor/tecnickcom/tc-lib-barcode/src/Type/Linear/EanEight.php b/vendor/tecnickcom/tc-lib-barcode/src/Type/Linear/EanEight.php new file mode 100644 index 0000000..d7fc405 --- /dev/null +++ b/vendor/tecnickcom/tc-lib-barcode/src/Type/Linear/EanEight.php @@ -0,0 +1,71 @@ + + * @copyright 2010-2024 Nicola Asuni - Tecnick.com LTD + * @license http://www.gnu.org/copyleft/lesser.html GNU-LGPL v3 (see LICENSE.TXT) + * @link https://github.com/tecnickcom/tc-lib-barcode + * + * This file is part of tc-lib-barcode software library. + */ + +namespace Com\Tecnick\Barcode\Type\Linear; + +use Com\Tecnick\Barcode\Exception as BarcodeException; + +/** + * Com\Tecnick\Barcode\Type\Linear\EanEight; + * + * EanEight Barcode type class + * EAN 8 + * + * @since 2015-02-21 + * @category Library + * @package Barcode + * @author Nicola Asuni + * @copyright 2010-2024 Nicola Asuni - Tecnick.com LTD + * @license http://www.gnu.org/copyleft/lesser.html GNU-LGPL v3 (see LICENSE.TXT) + * @link https://github.com/tecnickcom/tc-lib-barcode + */ +class EanEight extends \Com\Tecnick\Barcode\Type\Linear\EanOneThree +{ + /** + * Barcode format + * + * @var string + */ + protected const FORMAT = 'EAN8'; + + /** + * Fixed code length + */ + protected int $code_length = 8; + + /** + * Set the bars array. + * + * @throws BarcodeException in case of error + */ + protected function setBars(): void + { + $this->formatCode(); + $seq = '101'; // left guard bar + $half_len = (int) ceil($this->code_length / 2); + for ($pos = 0; $pos < $half_len; ++$pos) { + $seq .= $this::CHBAR['A'][$this->extcode[$pos]]; + } + + $seq .= '01010'; // center guard bar + for ($pos = $half_len; $pos < $this->code_length; ++$pos) { + $seq .= $this::CHBAR['C'][$this->extcode[$pos]]; + } + + $seq .= '101'; // right guard bar + $this->processBinarySequence($this->getRawCodeRows($seq)); + } +} diff --git a/vendor/tecnickcom/tc-lib-barcode/src/Type/Linear/EanFive.php b/vendor/tecnickcom/tc-lib-barcode/src/Type/Linear/EanFive.php new file mode 100644 index 0000000..0d29d16 --- /dev/null +++ b/vendor/tecnickcom/tc-lib-barcode/src/Type/Linear/EanFive.php @@ -0,0 +1,77 @@ + + * @copyright 2010-2024 Nicola Asuni - Tecnick.com LTD + * @license http://www.gnu.org/copyleft/lesser.html GNU-LGPL v3 (see LICENSE.TXT) + * @link https://github.com/tecnickcom/tc-lib-barcode + * + * This file is part of tc-lib-barcode software library. + */ + +namespace Com\Tecnick\Barcode\Type\Linear; + +/** + * Com\Tecnick\Barcode\Type\Linear\EanFive; + * + * EanFive Barcode type class + * EAN 5-Digits UPC-Based Extension + * + * @since 2015-02-21 + * @category Library + * @package Barcode + * @author Nicola Asuni + * @copyright 2010-2024 Nicola Asuni - Tecnick.com LTD + * @license http://www.gnu.org/copyleft/lesser.html GNU-LGPL v3 (see LICENSE.TXT) + * @link https://github.com/tecnickcom/tc-lib-barcode + */ +class EanFive extends \Com\Tecnick\Barcode\Type\Linear\EanTwo +{ + /** + * Barcode format + * + * @var string + */ + protected const FORMAT = 'EAN5'; + + /** + * Fixed code length + */ + protected int $code_length = 5; + + /** + * Map parities + * + * @var array> + */ + protected const PARITIES = [ + '0' => ['B', 'B', 'A', 'A', 'A'], + '1' => ['B', 'A', 'B', 'A', 'A'], + '2' => ['B', 'A', 'A', 'B', 'A'], + '3' => ['B', 'A', 'A', 'A', 'B'], + '4' => ['A', 'B', 'B', 'A', 'A'], + '5' => ['A', 'A', 'B', 'B', 'A'], + '6' => ['A', 'A', 'A', 'B', 'B'], + '7' => ['A', 'B', 'A', 'B', 'A'], + '8' => ['A', 'B', 'A', 'A', 'B'], + '9' => ['A', 'A', 'B', 'A', 'B'], + ]; + + /** + * Calculate checksum + * + * @param string $code Code to represent. + * + * @return int char checksum. + */ + protected function getChecksum(string $code): int + { + return (((3 * ((int) $code[0] + (int) $code[2] + (int) $code[4])) + + (9 * ((int) $code[1] + (int) $code[3]))) % 10); + } +} diff --git a/vendor/tecnickcom/tc-lib-barcode/src/Type/Linear/EanOneThree.php b/vendor/tecnickcom/tc-lib-barcode/src/Type/Linear/EanOneThree.php new file mode 100644 index 0000000..28b88fa --- /dev/null +++ b/vendor/tecnickcom/tc-lib-barcode/src/Type/Linear/EanOneThree.php @@ -0,0 +1,204 @@ + + * @copyright 2010-2024 Nicola Asuni - Tecnick.com LTD + * @license http://www.gnu.org/copyleft/lesser.html GNU-LGPL v3 (see LICENSE.TXT) + * @link https://github.com/tecnickcom/tc-lib-barcode + * + * This file is part of tc-lib-barcode software library. + */ + +namespace Com\Tecnick\Barcode\Type\Linear; + +use Com\Tecnick\Barcode\Exception as BarcodeException; + +/** + * Com\Tecnick\Barcode\Type\Linear\EanOneThree; + * + * EanOneThree Barcode type class + * EAN 13 + * + * @since 2015-02-21 + * @category Library + * @package Barcode + * @author Nicola Asuni + * @copyright 2010-2024 Nicola Asuni - Tecnick.com LTD + * @license http://www.gnu.org/copyleft/lesser.html GNU-LGPL v3 (see LICENSE.TXT) + * @link https://github.com/tecnickcom/tc-lib-barcode + */ +class EanOneThree extends \Com\Tecnick\Barcode\Type\Linear +{ + /** + * Barcode format + * + * @var string + */ + protected const FORMAT = 'EAN13'; + + /** + * Fixed code length + */ + protected int $code_length = 13; + + /** + * Check digit + */ + protected int $check = 0; + + /** + * Map characters to barcodes + * + * @var array> + */ + protected const CHBAR = [ + 'A' => [ + // left odd parity + '0' => '0001101', + '1' => '0011001', + '2' => '0010011', + '3' => '0111101', + '4' => '0100011', + '5' => '0110001', + '6' => '0101111', + '7' => '0111011', + '8' => '0110111', + '9' => '0001011', + ], + 'B' => [ + // left even parity + '0' => '0100111', + '1' => '0110011', + '2' => '0011011', + '3' => '0100001', + '4' => '0011101', + '5' => '0111001', + '6' => '0000101', + '7' => '0010001', + '8' => '0001001', + '9' => '0010111', + ], + 'C' => [ + // right + '0' => '1110010', + '1' => '1100110', + '2' => '1101100', + '3' => '1000010', + '4' => '1011100', + '5' => '1001110', + '6' => '1010000', + '7' => '1000100', + '8' => '1001000', + '9' => '1110100', + ], + ]; + + /** + * Map parities + * + * @var array + */ + protected const PARITIES = [ + '0' => 'AAAAAA', + '1' => 'AABABB', + '2' => 'AABBAB', + '3' => 'AABBBA', + '4' => 'ABAABB', + '5' => 'ABBAAB', + '6' => 'ABBBAA', + '7' => 'ABABAB', + '8' => 'ABABBA', + '9' => 'ABBABA', + ]; + + /** + * Calculate checksum + * + * @param string $code Code to represent. + * + * @return int char checksum. + * + * @throws BarcodeException in case of error + */ + protected function getChecksum(string $code): int + { + $data_len = ($this->code_length - 1); + $code_len = strlen($code); + $sum_a = 0; + for ($pos = 1; $pos < $data_len; $pos += 2) { + $sum_a += (int) $code[$pos]; + } + + if ($this->code_length > 12) { + $sum_a *= 3; + } + + $sum_b = 0; + for ($pos = 0; $pos < $data_len; $pos += 2) { + $sum_b += (int) ($code[$pos]); + } + + if ($this->code_length < 13) { + $sum_b *= 3; + } + + $this->check = ($sum_a + $sum_b) % 10; + if ($this->check > 0) { + $this->check = (10 - $this->check); + } + + if ($code_len == $data_len) { + // add check digit + return $this->check; + } + + if ($this->check !== (int) $code[$data_len]) { + // wrong check digit + throw new BarcodeException('Invalid check digit: ' . $this->check); + } + + return 0; + } + + /** + * Format code + */ + protected function formatCode(): void + { + $code = str_pad($this->code, ($this->code_length - 1), '0', STR_PAD_LEFT); + $this->extcode = $code . $this->getChecksum($code); + } + + /** + * Set the bars array. + * + * @throws BarcodeException in case of error + */ + protected function setBars(): void + { + if (! is_numeric($this->code)) { + throw new BarcodeException('Input code must be a number'); + } + + $this->formatCode(); + $seq = '101'; // left guard bar + $half_len = (int) ceil($this->code_length / 2); + $parity = $this::PARITIES[$this->extcode[0]]; + for ($pos = 1; $pos < $half_len; ++$pos) { + $seq .= $this::CHBAR[$parity[($pos - 1)]][$this->extcode[$pos]]; + } + + $seq .= '01010'; // center guard bar + for ($pos = $half_len; $pos < $this->code_length; ++$pos) { + $seq .= $this::CHBAR['C'][$this->extcode[$pos]]; + } + + $seq .= '101'; // right guard bar + $this->processBinarySequence($this->getRawCodeRows($seq)); + } +} diff --git a/vendor/tecnickcom/tc-lib-barcode/src/Type/Linear/EanTwo.php b/vendor/tecnickcom/tc-lib-barcode/src/Type/Linear/EanTwo.php new file mode 100644 index 0000000..c2b1c0f --- /dev/null +++ b/vendor/tecnickcom/tc-lib-barcode/src/Type/Linear/EanTwo.php @@ -0,0 +1,135 @@ + + * @copyright 2010-2024 Nicola Asuni - Tecnick.com LTD + * @license http://www.gnu.org/copyleft/lesser.html GNU-LGPL v3 (see LICENSE.TXT) + * @link https://github.com/tecnickcom/tc-lib-barcode + * + * This file is part of tc-lib-barcode software library. + */ + +namespace Com\Tecnick\Barcode\Type\Linear; + +use Com\Tecnick\Barcode\Exception as BarcodeException; + +/** + * Com\Tecnick\Barcode\Type\Linear\EanTwo; + * + * EanTwo Barcode type class + * EAN 2-Digits UPC-Based Extension + * + * @since 2015-02-21 + * @category Library + * @package Barcode + * @author Nicola Asuni + * @copyright 2010-2024 Nicola Asuni - Tecnick.com LTD + * @license http://www.gnu.org/copyleft/lesser.html GNU-LGPL v3 (see LICENSE.TXT) + * @link https://github.com/tecnickcom/tc-lib-barcode + */ +class EanTwo extends \Com\Tecnick\Barcode\Type\Linear +{ + /** + * Barcode format + * + * @var string + */ + protected const FORMAT = 'EAN2'; + + /** + * Fixed code length + */ + protected int $code_length = 2; + + /** + * Map characters to barcodes + * + * @var array> + */ + protected const CHBAR = [ + 'A' => [ + // left odd parity + '0' => '0001101', + '1' => '0011001', + '2' => '0010011', + '3' => '0111101', + '4' => '0100011', + '5' => '0110001', + '6' => '0101111', + '7' => '0111011', + '8' => '0110111', + '9' => '0001011', + ], + 'B' => [ + // left even parity + '0' => '0100111', + '1' => '0110011', + '2' => '0011011', + '3' => '0100001', + '4' => '0011101', + '5' => '0111001', + '6' => '0000101', + '7' => '0010001', + '8' => '0001001', + '9' => '0010111', + ], + ]; + + /** + * Map parities + * + * @var array> + */ + protected const PARITIES = [ + '0' => ['A', 'A'], + '1' => ['A', 'B'], + '2' => ['B', 'A'], + '3' => ['B', 'B'], + ]; + + /** + * Calculate checksum + * + * @param string $code Code to represent. + * + * @return int char checksum. + */ + protected function getChecksum(string $code): int + { + return ((int) $code % 4); + } + + /** + * Format code + */ + protected function formatCode(): void + { + $this->extcode = str_pad($this->code, $this->code_length, '0', STR_PAD_LEFT); + } + + /** + * Set the bars array. + * + * @throws BarcodeException in case of error + */ + protected function setBars(): void + { + $this->formatCode(); + $chk = $this->getChecksum($this->extcode); + $parity = $this::PARITIES[$chk]; + $seq = '1011'; // left guard bar + $seq .= $this::CHBAR[$parity[0]][$this->extcode[0]]; + $len = strlen($this->extcode); + for ($pos = 1; $pos < $len; ++$pos) { + $seq .= '01'; // separator + $seq .= $this::CHBAR[$parity[$pos]][$this->extcode[$pos]]; + } + + $this->processBinarySequence($this->getRawCodeRows($seq)); + } +} diff --git a/vendor/tecnickcom/tc-lib-barcode/src/Type/Linear/Imb.php b/vendor/tecnickcom/tc-lib-barcode/src/Type/Linear/Imb.php new file mode 100644 index 0000000..406427d --- /dev/null +++ b/vendor/tecnickcom/tc-lib-barcode/src/Type/Linear/Imb.php @@ -0,0 +1,575 @@ + + * @copyright 2015-2024 Nicola Asuni - Tecnick.com LTD + * @license http://www.gnu.org/copyleft/lesser.html GNU-LGPL v3 (see LICENSE.TXT) + * @link https://github.com/tecnickcom/tc-lib-barcode + * + * This file is part of tc-lib-barcode software library. + */ + +namespace Com\Tecnick\Barcode\Type\Linear; + +use Com\Tecnick\Barcode\Exception as BarcodeException; + +/** + * Com\Tecnick\Barcode\Type\Linear\Imb; + * + * Imb Barcode type class + * IMB - Intelligent Mail Barcode - Onecode - USPS-B-3200 + * + * Intelligent Mail barcode is a 65-bar code for use on mail in the United States. + * The fields are described as follows: + * * The Barcode Identifier shall be assigned by USPS to encode the presort identification that is currently + * printed in human readable form on the optional endorsement line (OEL) as well as for future USPS use. + * This shall be two digits, with the second digit in the range of 0–4. The allowable encoding ranges shall be + * 00–04, 10–14, 20–24, 30–34, 40–44, 50–54, 60–64, 70–74, 80–84, and 90–94. + * * The Service Type Identifier shall be assigned by USPS for any combination of services requested on the mailpiece. + * The allowable encoding range shall be 000http://it2.php.net/manual/en/function.dechex.php–999. + * Each 3-digit value shall correspond to a particular mail class with a particular combination of service(s). + * Each service program, such as OneCode Confirm and OneCode ACS, shall provide the list of Service Type Identifier + * values. + * * The Mailer or Customer Identifier shall be assigned by USPS as a unique, 6 or 9 digit number that identifies + * a business entity. The allowable encoding range for the 6 digit Mailer ID shall be 000000- 899999, while the + * allowable encoding range for the 9 digit Mailer ID shall be 900000000-999999999. The Serial or + * Sequence Number shall be assigned by the mailer for uniquely identifying and tracking mailpieces. + * The allowable encoding range shall be 000000000–999999999 when used with a 6 digit Mailer ID and 000000-999999 + * when used with a 9 digit Mailer ID. e. The Delivery Point ZIP Code shall be assigned by the mailer for routing + * the mailpiece. This shall replace POSTNET for routing the mailpiece to its final delivery point. + * The length may be 0, 5, 9, or 11 digits. The allowable encoding ranges shall be no ZIP Code, 00000–99999, + * 000000000–999999999, and 00000000000–99999999999. An hyphen '-' is required before the zip/delivery point. + * + * @since 2015-02-21 + * @category Library + * @package Barcode + * @author Nicola Asuni + * @copyright 2015-2024 Nicola Asuni - Tecnick.com LTD + * @license http://www.gnu.org/copyleft/lesser.html GNU-LGPL v3 (see LICENSE.TXT) + * @link https://github.com/tecnickcom/tc-lib-barcode + */ +class Imb extends \Com\Tecnick\Barcode\Type\Linear +{ + /** + * Barcode format + * + * @var string + */ + protected const FORMAT = 'IMB'; + + /** + * ASC characters + * + * @var array + */ + protected const ASC_CHR = [ + 4, + 0, + 2, + 6, + 3, + 5, + 1, + 9, + 8, + 7, + 1, + 2, + 0, + 6, + 4, + 8, + 2, + 9, + 5, + 3, + 0, + 1, + 3, + 7, + 4, + 6, + 8, + 9, + 2, + 0, + 5, + 1, + 9, + 4, + 3, + 8, + 6, + 7, + 1, + 2, + 4, + 3, + 9, + 5, + 7, + 8, + 3, + 0, + 2, + 1, + 4, + 0, + 9, + 1, + 7, + 0, + 2, + 4, + 6, + 3, + 7, + 1, + 9, + 5, + 8, + ]; + + /** + * DSC characters + * + * @var array + */ + protected const DSC_CHR = [ + 7, + 1, + 9, + 5, + 8, + 0, + 2, + 4, + 6, + 3, + 5, + 8, + 9, + 7, + 3, + 0, + 6, + 1, + 7, + 4, + 6, + 8, + 9, + 2, + 5, + 1, + 7, + 5, + 4, + 3, + 8, + 7, + 6, + 0, + 2, + 5, + 4, + 9, + 3, + 0, + 1, + 6, + 8, + 2, + 0, + 4, + 5, + 9, + 6, + 7, + 5, + 2, + 6, + 3, + 8, + 5, + 1, + 9, + 8, + 7, + 4, + 0, + 2, + 6, + 3, + ]; + + /** + * ASC positions + * + * @var array + */ + protected const ASC_POS = [ + 3, + 0, + 8, + 11, + 1, + 12, + 8, + 11, + 10, + 6, + 4, + 12, + 2, + 7, + 9, + 6, + 7, + 9, + 2, + 8, + 4, + 0, + 12, + 7, + 10, + 9, + 0, + 7, + 10, + 5, + 7, + 9, + 6, + 8, + 2, + 12, + 1, + 4, + 2, + 0, + 1, + 5, + 4, + 6, + 12, + 1, + 0, + 9, + 4, + 7, + 5, + 10, + 2, + 6, + 9, + 11, + 2, + 12, + 6, + 7, + 5, + 11, + 0, + 3, + 2, + ]; + + /** + * DSC positions + * + * @var array + */ + protected const DSC_POS = [ + 2, + 10, + 12, + 5, + 9, + 1, + 5, + 4, + 3, + 9, + 11, + 5, + 10, + 1, + 6, + 3, + 4, + 1, + 10, + 0, + 2, + 11, + 8, + 6, + 1, + 12, + 3, + 8, + 6, + 4, + 4, + 11, + 0, + 6, + 1, + 9, + 11, + 5, + 3, + 7, + 3, + 10, + 7, + 11, + 8, + 2, + 10, + 3, + 5, + 8, + 0, + 3, + 12, + 11, + 8, + 4, + 5, + 1, + 3, + 0, + 7, + 12, + 9, + 8, + 10, + ]; + + /** + * Reverse unsigned short value + * + * @param int $num Value to reversr + * + * @return int reversed value + */ + protected function getReversedUnsignedShort(int $num): int + { + $rev = 0; + for ($pos = 0; $pos < 16; ++$pos) { + $rev <<= 1; + $rev |= ($num & 1); + $num >>= 1; + } + + return $rev; + } + + /** + * Get the Frame Check Sequence + * + * @param array $code_arr Array of hexadecimal values (13 bytes holding 102 bits right justified). + * + * @return int 11 bit Frame Check Sequence as integer (decimal base) + */ + protected function getFrameCheckSequence(array $code_arr): int + { + $genpoly = 0x0F35; // generator polynomial + $fcs = 0x07FF; // Frame Check Sequence + // do most significant byte skipping the 2 most significant bits + $data = hexdec($code_arr[0]) << 5; + for ($bit = 2; $bit < 8; ++$bit) { + $fcs = (($fcs ^ $data) & 0x400) !== 0 ? ($fcs << 1) ^ $genpoly : $fcs << 1; + + $fcs &= 0x7FF; + $data <<= 1; + } + + // do rest of bytes + for ($byte = 1; $byte < 13; ++$byte) { + $data = hexdec($code_arr[$byte]) << 3; + for ($bit = 0; $bit < 8; ++$bit) { + $fcs = (($fcs ^ $data) & 0x400) !== 0 ? ($fcs << 1) ^ $genpoly : $fcs << 1; + + $fcs &= 0x7FF; + $data <<= 1; + } + } + + return $fcs; + } + + /** + * Get the Nof13 tables + * + * @param int $type Table type: 2 for 2of13 table, 5 for 5of13table + * @param int $size Table size (78 for n=2 and 1287 for n=5) + * + * @return array requested table + */ + protected function getTables(int $type, int $size): array + { + $table = []; + $lli = 0; // LUT lower index + $lui = $size - 1; // LUT upper index + for ($count = 0; $count < 8192; ++$count) { + $bit_count = 0; + for ($bit_index = 0; $bit_index < 13; ++$bit_index) { + $bit_count += (int) (($count & (1 << $bit_index)) != 0); + } + + // if we don't have the right number of bits on, go on to the next value + if ($bit_count === $type) { + $reverse = ($this->getReversedUnsignedShort($count) >> 3); + // if the reverse is less than count, we have already visited this pair before + if ($reverse >= $count) { + // If count is symmetric, place it at the first free slot from the end of the list. + // Otherwise, place it at the first free slot from the beginning of the list AND place + // $reverse ath the next free slot from the beginning of the list + if ($reverse == $count) { + $table[$lui] = $count; + --$lui; + } else { + $table[$lli] = $count; + ++$lli; + $table[$lli] = $reverse; + ++$lli; + } + } + } + } + + return $table; + } + + /** + * Get the routing code binary block + * + * @param numeric-string $routing_code the routing code + * + * @throws BarcodeException in case of error + */ + protected function getRoutingCode(string $routing_code): string + { + // Conversion of Routing Code + return match (strlen($routing_code)) { + 0 => '0', + 5 => bcadd($routing_code, '1'), + 9 => bcadd($routing_code, '100001'), + 11 => bcadd($routing_code, '1000100001'), + default => throw new BarcodeException('Invalid routing code'), + }; + } + + /** + * Get the processed array of characters + * + * @return array + * + * @throws BarcodeException in case of error + */ + protected function getCharsArray(): array + { + $this->ncols = 0; + $this->nrows = 3; + $this->bars = []; + $code_arr = explode('-', $this->code); + $tracking_number = $code_arr[0]; + $binary_code = '0'; + if (isset($code_arr[1])) { + $binary_code = $this->getRoutingCode($code_arr[1]); // @phpstan-ignore argument.type + } + + $binary_code = bcmul($binary_code, '10'); // @phpstan-ignore argument.type + $binary_code = bcadd($binary_code, $tracking_number[0]); // @phpstan-ignore argument.type + $binary_code = bcmul($binary_code, '5'); // @phpstan-ignore argument.type + $binary_code = bcadd($binary_code, $tracking_number[1]); // @phpstan-ignore argument.type + $binary_code .= substr($tracking_number, 2, 18); + // convert to hexadecimal + $binary_code = $this->convertDecToHex($binary_code); + // pad to get 13 bytes + $binary_code = str_pad($binary_code, 26, '0', STR_PAD_LEFT); + // convert string to array of bytes + $binary_code_arr = chunk_split($binary_code, 2, "\r"); + $binary_code_arr = substr($binary_code_arr, 0, -1); + $binary_code_arr = explode("\r", $binary_code_arr); + // calculate frame check sequence + $fcs = $this->getFrameCheckSequence($binary_code_arr); + // exclude first 2 bits from first byte + $first_byte = sprintf('%2s', dechex((int) (hexdec($binary_code_arr[0]) << 2) >> 2)); + $binary_code_102bit = $first_byte . substr($binary_code, 2); + // convert binary data to codewords + $codewords = []; + $data = $this->convertHexToDec($binary_code_102bit); + $codewords[0] = bcmod($data, '636') * 2; + $data = bcdiv($data, '636'); + for ($pos = 1; $pos < 9; ++$pos) { + $codewords[$pos] = bcmod($data, '1365'); + $data = bcdiv($data, '1365'); + } + + $codewords[9] = $data; + if (($fcs >> 10) == 1) { + $codewords[9] += 659; + } + + // generate lookup tables + $table2of13 = $this->getTables(2, 78); + $table5of13 = $this->getTables(5, 1287); + // convert codewords to characters + $characters = []; + $bitmask = 512; + foreach ($codewords as $codeword) { + $chrcode = $codeword <= 1286 ? $table5of13[$codeword] : $table2of13[($codeword - 1287)]; + + if (($fcs & $bitmask) > 0) { + // bitwise invert + $chrcode = ((~(int) $chrcode) & 8191); + } + + $characters[] = $chrcode; + $bitmask /= 2; + } + + return array_reverse($characters); + } + + /** + * Set the bars array. + * + * @throws BarcodeException in case of error + */ + protected function setBars(): void + { + $chars = $this->getCharsArray(); + for ($pos = 0; $pos < 65; ++$pos) { + $asc = (($chars[self::ASC_CHR[$pos]] & 2 ** self::ASC_POS[$pos]) > 0); + $dsc = (($chars[self::DSC_CHR[$pos]] & 2 ** self::DSC_POS[$pos]) > 0); + if ($asc && $dsc) { + // full bar (F) + $this->bars[] = [$this->ncols, 0, 1, 3]; + } elseif ($asc) { + // ascender (A) + $this->bars[] = [$this->ncols, 0, 1, 2]; + } elseif ($dsc) { + // descender (D) + $this->bars[] = [$this->ncols, 1, 1, 2]; + } else { + // tracker (T) + $this->bars[] = [$this->ncols, 1, 1, 1]; + } + + $this->ncols += 2; + } + + --$this->ncols; + } +} diff --git a/vendor/tecnickcom/tc-lib-barcode/src/Type/Linear/ImbPre.php b/vendor/tecnickcom/tc-lib-barcode/src/Type/Linear/ImbPre.php new file mode 100644 index 0000000..ea06d29 --- /dev/null +++ b/vendor/tecnickcom/tc-lib-barcode/src/Type/Linear/ImbPre.php @@ -0,0 +1,84 @@ + + * @copyright 2010-2024 Nicola Asuni - Tecnick.com LTD + * @license http://www.gnu.org/copyleft/lesser.html GNU-LGPL v3 (see LICENSE.TXT) + * @link https://github.com/tecnickcom/tc-lib-barcode + * + * This file is part of tc-lib-barcode software library. + */ + +namespace Com\Tecnick\Barcode\Type\Linear; + +use Com\Tecnick\Barcode\Exception as BarcodeException; + +/** + * Com\Tecnick\Barcode\Type\Linear\ImbPre; + * + * ImbPre Barcode type class + * IMB - Intelligent Mail Barcode pre-processed (USPS-B-3200) + * + * @since 2015-02-21 + * @category Library + * @package Barcode + * @author Nicola Asuni + * @copyright 2010-2024 Nicola Asuni - Tecnick.com LTD + * @license http://www.gnu.org/copyleft/lesser.html GNU-LGPL v3 (see LICENSE.TXT) + * @link https://github.com/tecnickcom/tc-lib-barcode + */ +class ImbPre extends \Com\Tecnick\Barcode\Type\Linear +{ + /** + * Barcode format + * + * @var string + */ + protected const FORMAT = 'IMBPRE'; + + /** + * Set the bars array. + * + * @throws BarcodeException in case of error + */ + protected function setBars(): void + { + $code = strtolower($this->code); + if (preg_match('/^[fadt]{65}$/', $code) != 1) { + throw new BarcodeException('Invalid character sequence'); + } + + $this->ncols = 0; + $this->nrows = 3; + $this->bars = []; + for ($pos = 0; $pos < 65; ++$pos) { + switch ($code[$pos]) { + case 'f': + // full bar + $this->bars[] = [$this->ncols, 0, 1, 3]; + break; + case 'a': + // ascender + $this->bars[] = [$this->ncols, 0, 1, 2]; + break; + case 'd': + // descender + $this->bars[] = [$this->ncols, 1, 1, 2]; + break; + case 't': + // tracker (short) + $this->bars[] = [$this->ncols, 1, 1, 1]; + break; + } + + $this->ncols += 2; + } + + --$this->ncols; + } +} diff --git a/vendor/tecnickcom/tc-lib-barcode/src/Type/Linear/InterleavedTwoOfFive.php b/vendor/tecnickcom/tc-lib-barcode/src/Type/Linear/InterleavedTwoOfFive.php new file mode 100644 index 0000000..3eb001d --- /dev/null +++ b/vendor/tecnickcom/tc-lib-barcode/src/Type/Linear/InterleavedTwoOfFive.php @@ -0,0 +1,49 @@ + + * @copyright 2010-2024 Nicola Asuni - Tecnick.com LTD + * @license http://www.gnu.org/copyleft/lesser.html GNU-LGPL v3 (see LICENSE.TXT) + * @link https://github.com/tecnickcom/tc-lib-barcode + * + * This file is part of tc-lib-barcode software library. + */ + +namespace Com\Tecnick\Barcode\Type\Linear; + +/** + * Com\Tecnick\Barcode\Type\Linear\InterleavedTwoOfFive; + * + * InterleavedTwoOfFive Barcode type class + * Interleaved 2 of 5 + * + * @since 2015-02-21 + * @category Library + * @package Barcode + * @author Nicola Asuni + * @copyright 2010-2024 Nicola Asuni - Tecnick.com LTD + * @license http://www.gnu.org/copyleft/lesser.html GNU-LGPL v3 (see LICENSE.TXT) + * @link https://github.com/tecnickcom/tc-lib-barcode + */ +class InterleavedTwoOfFive extends \Com\Tecnick\Barcode\Type\Linear\InterleavedTwoOfFiveCheck +{ + /** + * Barcode format + * + * @var string + */ + protected const FORMAT = 'I25'; + + /** + * Format code + */ + protected function formatCode(): void + { + $this->extcode = $this->code; + } +} diff --git a/vendor/tecnickcom/tc-lib-barcode/src/Type/Linear/InterleavedTwoOfFiveCheck.php b/vendor/tecnickcom/tc-lib-barcode/src/Type/Linear/InterleavedTwoOfFiveCheck.php new file mode 100644 index 0000000..11b19ac --- /dev/null +++ b/vendor/tecnickcom/tc-lib-barcode/src/Type/Linear/InterleavedTwoOfFiveCheck.php @@ -0,0 +1,118 @@ + + * @copyright 2010-2024 Nicola Asuni - Tecnick.com LTD + * @license http://www.gnu.org/copyleft/lesser.html GNU-LGPL v3 (see LICENSE.TXT) + * @link https://github.com/tecnickcom/tc-lib-barcode + * + * This file is part of tc-lib-barcode software library. + */ + +namespace Com\Tecnick\Barcode\Type\Linear; + +use Com\Tecnick\Barcode\Exception as BarcodeException; + +/** + * Com\Tecnick\Barcode\Type\Linear\InterleavedTwoOfFiveCheck; + * + * InterleavedTwoOfFiveCheck Barcode type class + * Interleaved 2 of 5 + CHECKSUM + * + * @since 2015-02-21 + * @category Library + * @package Barcode + * @author Nicola Asuni + * @copyright 2010-2024 Nicola Asuni - Tecnick.com LTD + * @license http://www.gnu.org/copyleft/lesser.html GNU-LGPL v3 (see LICENSE.TXT) + * @link https://github.com/tecnickcom/tc-lib-barcode + */ +class InterleavedTwoOfFiveCheck extends \Com\Tecnick\Barcode\Type\Linear\StandardTwoOfFiveCheck +{ + /** + * Barcode format + * + * @var string + */ + protected const FORMAT = 'I25+'; + + /** + * Map characters to barcodes + * + * @var array + */ + protected const CHBAR = [ + '0' => '11221', + '1' => '21112', + '2' => '12112', + '3' => '22111', + '4' => '11212', + '5' => '21211', + '6' => '12211', + '7' => '11122', + '8' => '21121', + '9' => '12121', + 'A' => '11', + 'Z' => '21', + ]; + + /** + * Format code + */ + protected function formatCode(): void + { + $this->extcode = $this->code . $this->getChecksum($this->code); + } + + /** + * Set the bars array. + * + * @throws BarcodeException in case of error + */ + protected function setBars(): void + { + $this->formatCode(); + if (strlen($this->extcode) % 2 != 0) { + // add leading zero if code-length is odd + $this->extcode = '0' . $this->extcode; + } + + // add start and stop codes + $this->extcode = 'AA' . strtolower($this->extcode) . 'ZA'; + $this->ncols = 0; + $this->nrows = 1; + $this->bars = []; + $clen = strlen($this->extcode); + for ($idx = 0; $idx < $clen; $idx += 2) { + $char_bar = $this->extcode[$idx]; + $char_space = $this->extcode[($idx + 1)]; + if ((! isset($this::CHBAR[$char_bar])) || (! isset($this::CHBAR[$char_space]))) { + throw new BarcodeException('Invalid character sequence: ' . $char_bar . $char_space); + } + + // create a bar-space sequence + $seq = ''; + $chrlen = strlen($this::CHBAR[$char_bar]); + for ($pos = 0; $pos < $chrlen; ++$pos) { + $seq .= $this::CHBAR[$char_bar][$pos] . $this::CHBAR[$char_space][$pos]; + } + + $seqlen = strlen($seq); + for ($pos = 0; $pos < $seqlen; ++$pos) { + $bar_width = (int) $seq[$pos]; + if ((($pos % 2) == 0) && ($bar_width > 0)) { + $this->bars[] = [$this->ncols, 0, $bar_width, 1]; + } + + $this->ncols += $bar_width; + } + } + + --$this->ncols; + } +} diff --git a/vendor/tecnickcom/tc-lib-barcode/src/Type/Linear/KlantIndex.php b/vendor/tecnickcom/tc-lib-barcode/src/Type/Linear/KlantIndex.php new file mode 100644 index 0000000..bf5d0c4 --- /dev/null +++ b/vendor/tecnickcom/tc-lib-barcode/src/Type/Linear/KlantIndex.php @@ -0,0 +1,64 @@ + + * @copyright 2010-2024 Nicola Asuni - Tecnick.com LTD + * @license http://www.gnu.org/copyleft/lesser.html GNU-LGPL v3 (see LICENSE.TXT) + * @link https://github.com/tecnickcom/tc-lib-barcode + * + * This file is part of tc-lib-barcode software library. + */ + +namespace Com\Tecnick\Barcode\Type\Linear; + +use Com\Tecnick\Barcode\Exception as BarcodeException; + +/** + * Com\Tecnick\Barcode\Type\Linear\KlantIndex; + * + * KlantIndex Barcode type class + * KIX (Klant index - Customer index) + * + * @since 2015-02-21 + * @category Library + * @package Barcode + * @author Nicola Asuni + * @copyright 2010-2024 Nicola Asuni - Tecnick.com LTD + * @license http://www.gnu.org/copyleft/lesser.html GNU-LGPL v3 (see LICENSE.TXT) + * @link https://github.com/tecnickcom/tc-lib-barcode + */ +class KlantIndex extends \Com\Tecnick\Barcode\Type\Linear\RoyalMailFourCc +{ + /** + * Barcode format + * + * @var string + */ + protected const FORMAT = 'KIX'; + + /** + * Format code + */ + protected function formatCode(): void + { + $this->extcode = strtoupper($this->code); + } + + /** + * Set the bars array. + * + * @throws BarcodeException in case of error + */ + protected function setBars(): void + { + $this->ncols = 0; + $this->nrows = 3; + $this->bars = []; + $this->getCoreBars(); + } +} diff --git a/vendor/tecnickcom/tc-lib-barcode/src/Type/Linear/Msi.php b/vendor/tecnickcom/tc-lib-barcode/src/Type/Linear/Msi.php new file mode 100644 index 0000000..9dd5746 --- /dev/null +++ b/vendor/tecnickcom/tc-lib-barcode/src/Type/Linear/Msi.php @@ -0,0 +1,49 @@ + + * @copyright 2010-2024 Nicola Asuni - Tecnick.com LTD + * @license http://www.gnu.org/copyleft/lesser.html GNU-LGPL v3 (see LICENSE.TXT) + * @link https://github.com/tecnickcom/tc-lib-barcode + * + * This file is part of tc-lib-barcode software library. + */ + +namespace Com\Tecnick\Barcode\Type\Linear; + +/** + * Com\Tecnick\Barcode\Type\Linear\Msi; + * + * Msi Barcode type class + * MSI (Variation of Plessey code) + * + * @since 2015-02-21 + * @category Library + * @package Barcode + * @author Nicola Asuni + * @copyright 2010-2024 Nicola Asuni - Tecnick.com LTD + * @license http://www.gnu.org/copyleft/lesser.html GNU-LGPL v3 (see LICENSE.TXT) + * @link https://github.com/tecnickcom/tc-lib-barcode + */ +class Msi extends \Com\Tecnick\Barcode\Type\Linear\MsiCheck +{ + /** + * Barcode format + * + * @var string + */ + protected const FORMAT = 'MSI'; + + /** + * Format code + */ + protected function formatCode(): void + { + $this->extcode = $this->code; + } +} diff --git a/vendor/tecnickcom/tc-lib-barcode/src/Type/Linear/MsiCheck.php b/vendor/tecnickcom/tc-lib-barcode/src/Type/Linear/MsiCheck.php new file mode 100644 index 0000000..19c737c --- /dev/null +++ b/vendor/tecnickcom/tc-lib-barcode/src/Type/Linear/MsiCheck.php @@ -0,0 +1,131 @@ + + * @copyright 2010-2024 Nicola Asuni - Tecnick.com LTD + * @license http://www.gnu.org/copyleft/lesser.html GNU-LGPL v3 (see LICENSE.TXT) + * @link https://github.com/tecnickcom/tc-lib-barcode + * + * This file is part of tc-lib-barcode software library. + */ + +namespace Com\Tecnick\Barcode\Type\Linear; + +use Com\Tecnick\Barcode\Exception as BarcodeException; + +/** + * Com\Tecnick\Barcode\Type\Linear\MsiCheck; + * + * MsiCheck Barcode type class + * MSI + CHECKSUM (modulo 11) + * + * @since 2015-02-21 + * @category Library + * @package Barcode + * @author Nicola Asuni + * @copyright 2010-2024 Nicola Asuni - Tecnick.com LTD + * @license http://www.gnu.org/copyleft/lesser.html GNU-LGPL v3 (see LICENSE.TXT) + * @link https://github.com/tecnickcom/tc-lib-barcode + */ +class MsiCheck extends \Com\Tecnick\Barcode\Type\Linear +{ + /** + * Barcode format + * + * @var string + */ + protected const FORMAT = 'MSI+'; + + /** + * Map characters to barcodes + * + * @var array + */ + protected const CHBAR = [ + '0' => '100100100100', + '1' => '100100100110', + '2' => '100100110100', + '3' => '100100110110', + '4' => '100110100100', + '5' => '100110100110', + '6' => '100110110100', + '7' => '100110110110', + '8' => '110100100100', + '9' => '110100100110', + 'A' => '110100110100', + 'B' => '110100110110', + 'C' => '110110100100', + 'D' => '110110100110', + 'E' => '110110110100', + 'F' => '110110110110', + ]; + + /** + * Calculate the checksum + * + * @param string $code Code to represent. + * + * @return int char checksum. + */ + protected function getChecksum(string $code): int + { + $clen = strlen($code); + $pix = 2; + $check = 0; + for ($pos = ($clen - 1); $pos >= 0; --$pos) { + $hex = $code[$pos]; + if (! ctype_xdigit($hex)) { + continue; + } + + $check += (hexdec($hex) * $pix); + ++$pix; + if ($pix > 7) { + $pix = 2; + } + } + + $check %= 11; + if ($check > 0) { + return 11 - $check; + } + + return $check; + } + + /** + * Format code + */ + protected function formatCode(): void + { + $this->extcode = $this->code . $this->getChecksum($this->code); + } + + /** + * Set the bars array. + * + * @throws BarcodeException in case of error + */ + protected function setBars(): void + { + $this->formatCode(); + $seq = '110'; // left guard + $clen = strlen($this->extcode); + for ($pos = 0; $pos < $clen; ++$pos) { + $digit = $this->extcode[$pos]; + if (! isset($this::CHBAR[$digit])) { + throw new BarcodeException('Invalid character: chr(' . ord($digit) . ')'); + } + + $seq .= $this::CHBAR[$digit]; + } + + $seq .= '1001'; // right guard + $this->processBinarySequence($this->getRawCodeRows($seq)); + } +} diff --git a/vendor/tecnickcom/tc-lib-barcode/src/Type/Linear/Pharma.php b/vendor/tecnickcom/tc-lib-barcode/src/Type/Linear/Pharma.php new file mode 100644 index 0000000..7dee0ef --- /dev/null +++ b/vendor/tecnickcom/tc-lib-barcode/src/Type/Linear/Pharma.php @@ -0,0 +1,69 @@ + + * @copyright 2010-2024 Nicola Asuni - Tecnick.com LTD + * @license http://www.gnu.org/copyleft/lesser.html GNU-LGPL v3 (see LICENSE.TXT) + * @link https://github.com/tecnickcom/tc-lib-barcode + * + * This file is part of tc-lib-barcode software library. + */ + +namespace Com\Tecnick\Barcode\Type\Linear; + +use Com\Tecnick\Barcode\Exception as BarcodeException; + +/** + * Com\Tecnick\Barcode\Type\Linear\Pharma; + * + * Pharma Barcode type class + * PHARMACODE + * + * @since 2015-02-21 + * @category Library + * @package Barcode + * @author Nicola Asuni + * @copyright 2010-2024 Nicola Asuni - Tecnick.com LTD + * @license http://www.gnu.org/copyleft/lesser.html GNU-LGPL v3 (see LICENSE.TXT) + * @link https://github.com/tecnickcom/tc-lib-barcode + */ +class Pharma extends \Com\Tecnick\Barcode\Type\Linear +{ + /** + * Barcode format + * + * @var string + */ + protected const FORMAT = 'PHARMA'; + + /** + * Set the bars array. + * + * @throws BarcodeException in case of error + */ + protected function setBars(): void + { + $seq = ''; + $code = (int) $this->code; + while ($code > 0) { + if (($code % 2) == 0) { + $seq .= '11100'; + $code -= 2; + } else { + $seq .= '100'; + --$code; + } + + $code /= 2; + } + + $seq = substr($seq, 0, -2); + $seq = strrev($seq); + $this->processBinarySequence($this->getRawCodeRows($seq)); + } +} diff --git a/vendor/tecnickcom/tc-lib-barcode/src/Type/Linear/PharmaTwoTracks.php b/vendor/tecnickcom/tc-lib-barcode/src/Type/Linear/PharmaTwoTracks.php new file mode 100644 index 0000000..6b64ca6 --- /dev/null +++ b/vendor/tecnickcom/tc-lib-barcode/src/Type/Linear/PharmaTwoTracks.php @@ -0,0 +1,93 @@ + + * @copyright 2010-2024 Nicola Asuni - Tecnick.com LTD + * @license http://www.gnu.org/copyleft/lesser.html GNU-LGPL v3 (see LICENSE.TXT) + * @link https://github.com/tecnickcom/tc-lib-barcode + * + * This file is part of tc-lib-barcode software library. + */ + +namespace Com\Tecnick\Barcode\Type\Linear; + +use Com\Tecnick\Barcode\Exception as BarcodeException; + +/** + * Com\Tecnick\Barcode\Type\Linear\PharmaTwoTracks; + * + * PharmaTwoTracks Barcode type class + * PHARMACODE TWO-TRACKS + * + * @since 2015-02-21 + * @category Library + * @package Barcode + * @author Nicola Asuni + * @copyright 2010-2024 Nicola Asuni - Tecnick.com LTD + * @license http://www.gnu.org/copyleft/lesser.html GNU-LGPL v3 (see LICENSE.TXT) + * @link https://github.com/tecnickcom/tc-lib-barcode + */ +class PharmaTwoTracks extends \Com\Tecnick\Barcode\Type\Linear +{ + /** + * Barcode format + * + * @var string + */ + protected const FORMAT = 'PHARMA2T'; + + /** + * Set the bars array. + * + * @throws BarcodeException in case of error + */ + protected function setBars(): void + { + $seq = ''; + $code = (int) $this->code; + + do { + switch ($code % 3) { + case 0: + $seq .= '3'; + $code = (($code - 3) / 3); + break; + case 1: + $seq .= '1'; + $code = (($code - 1) / 3); + break; + case 2: + $seq .= '2'; + $code = (($code - 2) / 3); + } + } while ($code != 0); + + $seq = strrev($seq); + $this->ncols = 0; + $this->nrows = 2; + $this->bars = []; + $len = strlen($seq); + for ($pos = 0; $pos < $len; ++$pos) { + switch ($seq[$pos]) { + case '1': + $this->bars[] = [$this->ncols, 1, 1, 1]; + break; + case '2': + $this->bars[] = [$this->ncols, 0, 1, 1]; + break; + case '3': + $this->bars[] = [$this->ncols, 0, 1, 2]; + break; + } + + $this->ncols += 2; + } + + --$this->ncols; + } +} diff --git a/vendor/tecnickcom/tc-lib-barcode/src/Type/Linear/Planet.php b/vendor/tecnickcom/tc-lib-barcode/src/Type/Linear/Planet.php new file mode 100644 index 0000000..794c658 --- /dev/null +++ b/vendor/tecnickcom/tc-lib-barcode/src/Type/Linear/Planet.php @@ -0,0 +1,59 @@ + + * @copyright 2010-2024 Nicola Asuni - Tecnick.com LTD + * @license http://www.gnu.org/copyleft/lesser.html GNU-LGPL v3 (see LICENSE.TXT) + * @link https://github.com/tecnickcom/tc-lib-barcode + * + * This file is part of tc-lib-barcode software library. + */ + +namespace Com\Tecnick\Barcode\Type\Linear; + +/** + * Com\Tecnick\Barcode\Type\Linear\Planet; + * + * Planet Barcode type class + * PLANET + * + * @since 2015-02-21 + * @category Library + * @package Barcode + * @author Nicola Asuni + * @copyright 2010-2024 Nicola Asuni - Tecnick.com LTD + * @license http://www.gnu.org/copyleft/lesser.html GNU-LGPL v3 (see LICENSE.TXT) + * @link https://github.com/tecnickcom/tc-lib-barcode + */ +class Planet extends \Com\Tecnick\Barcode\Type\Linear\Postnet +{ + /** + * Barcode format + * + * @var string + */ + protected const FORMAT = 'PLANET'; + + /** + * Map characters to barcodes + * + * @var array + */ + protected const CHBAR = [ + '0' => '11222', + '1' => '22211', + '2' => '22121', + '3' => '22112', + '4' => '21221', + '5' => '21212', + '6' => '21122', + '7' => '12221', + '8' => '12212', + '9' => '12122', + ]; +} diff --git a/vendor/tecnickcom/tc-lib-barcode/src/Type/Linear/Postnet.php b/vendor/tecnickcom/tc-lib-barcode/src/Type/Linear/Postnet.php new file mode 100644 index 0000000..fcfc591 --- /dev/null +++ b/vendor/tecnickcom/tc-lib-barcode/src/Type/Linear/Postnet.php @@ -0,0 +1,129 @@ + + * @copyright 2010-2024 Nicola Asuni - Tecnick.com LTD + * @license http://www.gnu.org/copyleft/lesser.html GNU-LGPL v3 (see LICENSE.TXT) + * @link https://github.com/tecnickcom/tc-lib-barcode + * + * This file is part of tc-lib-barcode software library. + */ + +namespace Com\Tecnick\Barcode\Type\Linear; + +use Com\Tecnick\Barcode\Exception as BarcodeException; + +/** + * Com\Tecnick\Barcode\Type\Linear\Postnet; + * + * Postnet Barcode type class + * POSTNET + * + * @since 2015-02-21 + * @category Library + * @package Barcode + * @author Nicola Asuni + * @copyright 2010-2024 Nicola Asuni - Tecnick.com LTD + * @license http://www.gnu.org/copyleft/lesser.html GNU-LGPL v3 (see LICENSE.TXT) + * @link https://github.com/tecnickcom/tc-lib-barcode + */ +class Postnet extends \Com\Tecnick\Barcode\Type\Linear +{ + /** + * Barcode format + * + * @var string + */ + protected const FORMAT = 'POSTNET'; + + /** + * Map characters to barcodes + * + * @var array + */ + protected const CHBAR = [ + '0' => '22111', + '1' => '11122', + '2' => '11212', + '3' => '11221', + '4' => '12112', + '5' => '12121', + '6' => '12211', + '7' => '21112', + '8' => '21121', + '9' => '21211', + ]; + + /** + * Calculate the checksum. + * + * @param string $code Code to represent. + * + * @return int char checksum. + */ + protected function getChecksum(string $code): int + { + $sum = 0; + $len = strlen($code); + for ($pos = 0; $pos < $len; ++$pos) { + $sum += (int) $code[$pos]; + } + + $check = ($sum % 10); + if ($check > 0) { + return 10 - $check; + } + + return $check; + } + + /** + * Format code + */ + protected function formatCode(): void + { + $code = preg_replace('/[-\s]+/', '', $this->code); + if ($code === null) { + throw new BarcodeException('Code not valid'); + } + $this->extcode = $code . $this->getChecksum($code); + } + + /** + * Set the bars array. + * + * @throws BarcodeException in case of error + */ + protected function setBars(): void + { + $this->ncols = 0; + $this->nrows = 2; + $this->bars = []; + $this->formatCode(); + $clen = strlen($this->extcode); + // start bar + $this->bars[] = [$this->ncols, 0, 1, 2]; + $this->ncols += 2; + for ($chr = 0; $chr < $clen; ++$chr) { + $char = $this->extcode[$chr]; + if (! isset($this::CHBAR[$char])) { + throw new BarcodeException('Invalid character: chr(' . ord($char) . ')'); + } + + for ($pos = 0; $pos < 5; ++$pos) { + $bar_height = (int) $this::CHBAR[$char][$pos]; + $this->bars[] = [$this->ncols, (int) floor(1 / $bar_height), 1, $bar_height]; + $this->ncols += 2; + } + } + + // end bar + $this->bars[] = [$this->ncols, 0, 1, 2]; + ++$this->ncols; + } +} diff --git a/vendor/tecnickcom/tc-lib-barcode/src/Type/Linear/Raw.php b/vendor/tecnickcom/tc-lib-barcode/src/Type/Linear/Raw.php new file mode 100644 index 0000000..f198c62 --- /dev/null +++ b/vendor/tecnickcom/tc-lib-barcode/src/Type/Linear/Raw.php @@ -0,0 +1,48 @@ + + * @copyright 2010-2024 Nicola Asuni - Tecnick.com LTD + * @license http://www.gnu.org/copyleft/lesser.html GNU-LGPL v3 (see LICENSE.TXT) + * @link https://github.com/tecnickcom/tc-lib-barcode + * + * This file is part of tc-lib-barcode software library. + */ + +namespace Com\Tecnick\Barcode\Type\Linear; + +/** + * Com\Tecnick\Barcode\Type\Linear\Raw + * + * Raw Barcode type class + * RAW MODE (comma-separated rows) + * + * @since 2015-02-21 + * @category Library + * @package Barcode + * @author Nicola Asuni + * @copyright 2010-2024 Nicola Asuni - Tecnick.com LTD + * @license http://www.gnu.org/copyleft/lesser.html GNU-LGPL v3 (see LICENSE.TXT) + * @link https://github.com/tecnickcom/tc-lib-barcode + */ +class Raw extends \Com\Tecnick\Barcode\Type\Raw +{ + /** + * Barcode type + * + * @var string + */ + protected const TYPE = 'linear'; + + /** + * Barcode format + * + * @var string + */ + protected const FORMAT = 'LRAW'; +} diff --git a/vendor/tecnickcom/tc-lib-barcode/src/Type/Linear/RoyalMailFourCc.php b/vendor/tecnickcom/tc-lib-barcode/src/Type/Linear/RoyalMailFourCc.php new file mode 100644 index 0000000..ee7c4c4 --- /dev/null +++ b/vendor/tecnickcom/tc-lib-barcode/src/Type/Linear/RoyalMailFourCc.php @@ -0,0 +1,224 @@ + + * @copyright 2010-2024 Nicola Asuni - Tecnick.com LTD + * @license http://www.gnu.org/copyleft/lesser.html GNU-LGPL v3 (see LICENSE.TXT) + * @link https://github.com/tecnickcom/tc-lib-barcode + * + * This file is part of tc-lib-barcode software library. + */ + +namespace Com\Tecnick\Barcode\Type\Linear; + +use Com\Tecnick\Barcode\Exception as BarcodeException; + +/** + * Com\Tecnick\Barcode\Type\Linear\RoyalMailFourCc; + * + * RoyalMailFourCC Barcode type class + * RMS4CC (Royal Mail 4-state Customer Bar Code) + * + * @since 2015-02-21 + * @category Library + * @package Barcode + * @author Nicola Asuni + * @copyright 2010-2024 Nicola Asuni - Tecnick.com LTD + * @license http://www.gnu.org/copyleft/lesser.html GNU-LGPL v3 (see LICENSE.TXT) + * @link https://github.com/tecnickcom/tc-lib-barcode + */ +class RoyalMailFourCc extends \Com\Tecnick\Barcode\Type\Linear +{ + /** + * Barcode format + * + * @var string + */ + protected const FORMAT = 'RMS4CC'; + + /** + * Map characters to barcodes + * + * @var array + */ + protected const CHBAR = [ + '0' => '3322', + '1' => '3412', + '2' => '3421', + '3' => '4312', + '4' => '4321', + '5' => '4411', + '6' => '3142', + '7' => '3232', + '8' => '3241', + '9' => '4132', + 'A' => '4141', + 'B' => '4231', + 'C' => '3124', + 'D' => '3214', + 'E' => '3223', + 'F' => '4114', + 'G' => '4123', + 'H' => '4213', + 'I' => '1342', + 'J' => '1432', + 'K' => '1441', + 'L' => '2332', + 'M' => '2341', + 'N' => '2431', + 'O' => '1324', + 'P' => '1414', + 'Q' => '1423', + 'R' => '2314', + 'S' => '2323', + 'T' => '2413', + 'U' => '1144', + 'V' => '1234', + 'W' => '1243', + 'X' => '2134', + 'Y' => '2143', + 'Z' => '2233', + ]; + + /** + * Characters used for checksum + * + * @var array + */ + protected const CHKSUM = [ + '0' => '11', + '1' => '12', + '2' => '13', + '3' => '14', + '4' => '15', + '5' => '10', + '6' => '21', + '7' => '22', + '8' => '23', + '9' => '24', + 'A' => '25', + 'B' => '20', + 'C' => '31', + 'D' => '32', + 'E' => '33', + 'F' => '34', + 'G' => '35', + 'H' => '30', + 'I' => '41', + 'J' => '42', + 'K' => '43', + 'L' => '44', + 'M' => '45', + 'N' => '40', + 'O' => '51', + 'P' => '52', + 'Q' => '53', + 'R' => '54', + 'S' => '55', + 'T' => '50', + 'U' => '01', + 'V' => '02', + 'W' => '03', + 'X' => '04', + 'Y' => '05', + 'Z' => '00', + ]; + + /** + * Calculate the checksum. + * + * @param string $code code to represent. + * + * @return int char checksum. + * + * @throws BarcodeException in case of error + */ + protected function getChecksum(string $code): int + { + $row = 0; + $col = 0; + $len = strlen($code); + for ($pos = 0; $pos < $len; ++$pos) { + $char = $code[$pos]; + if (! isset($this::CHKSUM[$char])) { + throw new BarcodeException('Invalid character: chr(' . ord($char) . ')'); + } + + $row += (int) $this::CHKSUM[$char][0]; + $col += (int) $this::CHKSUM[$char][1]; + } + + $row %= 6; + $col %= 6; + $check = array_keys($this::CHKSUM, $row . $col); + return $check[0]; + } + + /** + * Format code + */ + protected function formatCode(): void + { + $code = strtoupper($this->code); + $this->extcode = $code . $this->getChecksum($code); + } + + /** + * Get the central bars + * + * @throws BarcodeException in case of error + */ + protected function getCoreBars(): void + { + $this->formatCode(); + $clen = strlen($this->extcode); + for ($chr = 0; $chr < $clen; ++$chr) { + $char = $this->extcode[$chr]; + for ($pos = 0; $pos < 4; ++$pos) { + switch ($this::CHBAR[$char][$pos]) { + case '1': + $this->bars[] = [$this->ncols, 0, 1, 2]; + break; + case '2': + $this->bars[] = [$this->ncols, 0, 1, 3]; + break; + case '3': + $this->bars[] = [$this->ncols, 1, 1, 1]; + break; + case '4': + $this->bars[] = [$this->ncols, 1, 1, 2]; + break; + } + + $this->ncols += 2; + } + } + } + + /** + * Set the bars array. + * + * @throws BarcodeException in case of error + */ + protected function setBars(): void + { + $this->ncols = 0; + $this->nrows = 3; + $this->bars = []; + + // start bar + $this->bars[] = [$this->ncols, 0, 1, 2]; + $this->ncols += 2; + + $this->getCoreBars(); + + // stop bar + $this->bars[] = [$this->ncols, 0, 1, 3]; + ++$this->ncols; + } +} diff --git a/vendor/tecnickcom/tc-lib-barcode/src/Type/Linear/StandardTwoOfFive.php b/vendor/tecnickcom/tc-lib-barcode/src/Type/Linear/StandardTwoOfFive.php new file mode 100644 index 0000000..9f9ac67 --- /dev/null +++ b/vendor/tecnickcom/tc-lib-barcode/src/Type/Linear/StandardTwoOfFive.php @@ -0,0 +1,49 @@ + + * @copyright 2010-2024 Nicola Asuni - Tecnick.com LTD + * @license http://www.gnu.org/copyleft/lesser.html GNU-LGPL v3 (see LICENSE.TXT) + * @link https://github.com/tecnickcom/tc-lib-barcode + * + * This file is part of tc-lib-barcode software library. + */ + +namespace Com\Tecnick\Barcode\Type\Linear; + +/** + * Com\Tecnick\Barcode\Type\Linear\StandardTwoOfFive; + * + * StandardTwoOfFive Barcode type class + * Standard 2 of 5 + * + * @since 2015-02-21 + * @category Library + * @package Barcode + * @author Nicola Asuni + * @copyright 2010-2024 Nicola Asuni - Tecnick.com LTD + * @license http://www.gnu.org/copyleft/lesser.html GNU-LGPL v3 (see LICENSE.TXT) + * @link https://github.com/tecnickcom/tc-lib-barcode + */ +class StandardTwoOfFive extends \Com\Tecnick\Barcode\Type\Linear\StandardTwoOfFiveCheck +{ + /** + * Barcode format + * + * @var string + */ + protected const FORMAT = 'S25'; + + /** + * Format code + */ + protected function formatCode(): void + { + $this->extcode = $this->code; + } +} diff --git a/vendor/tecnickcom/tc-lib-barcode/src/Type/Linear/StandardTwoOfFiveCheck.php b/vendor/tecnickcom/tc-lib-barcode/src/Type/Linear/StandardTwoOfFiveCheck.php new file mode 100644 index 0000000..4517959 --- /dev/null +++ b/vendor/tecnickcom/tc-lib-barcode/src/Type/Linear/StandardTwoOfFiveCheck.php @@ -0,0 +1,125 @@ + + * @copyright 2010-2024 Nicola Asuni - Tecnick.com LTD + * @license http://www.gnu.org/copyleft/lesser.html GNU-LGPL v3 (see LICENSE.TXT) + * @link https://github.com/tecnickcom/tc-lib-barcode + * + * This file is part of tc-lib-barcode software library. + */ + +namespace Com\Tecnick\Barcode\Type\Linear; + +use Com\Tecnick\Barcode\Exception as BarcodeException; + +/** + * Com\Tecnick\Barcode\Type\Linear\StandardTwoOfFiveCheck; + * + * StandardTwoOfFiveCheck Barcode type class + * Standard 2 of 5 + CHECKSUM + * + * @since 2015-02-21 + * @category Library + * @package Barcode + * @author Nicola Asuni + * @copyright 2010-2024 Nicola Asuni - Tecnick.com LTD + * @license http://www.gnu.org/copyleft/lesser.html GNU-LGPL v3 (see LICENSE.TXT) + * @link https://github.com/tecnickcom/tc-lib-barcode + */ +class StandardTwoOfFiveCheck extends \Com\Tecnick\Barcode\Type\Linear +{ + /** + * Barcode format + * + * @var string + */ + protected const FORMAT = 'S25+'; + + /** + * Map characters to barcodes + * + * @var array + */ + protected const CHBAR = [ + '0' => '10101110111010', + '1' => '11101010101110', + '2' => '10111010101110', + '3' => '11101110101010', + '4' => '10101110101110', + '5' => '11101011101010', + '6' => '10111011101010', + '7' => '10101011101110', + '8' => '11101010111010', + '9' => '10111010111010', + ]; + + /** + * Calculate the checksum + * + * @param string $code Code to represent. + * + * @return int char checksum. + */ + protected function getChecksum(string $code): int + { + $clen = strlen($code); + $sum = 0; + for ($idx = 0; $idx < $clen; $idx += 2) { + $sum += (int) $code[$idx]; + } + + $sum *= 3; + for ($idx = 1; $idx < $clen; $idx += 2) { + $sum += (int) $code[$idx]; + } + + $check = $sum % 10; + if ($check > 0) { + return 10 - $check; + } + + return $check; + } + + /** + * Format code + */ + protected function formatCode(): void + { + $this->extcode = $this->code . $this->getChecksum($this->code); + } + + /** + * Set the bars array. + * + * @throws BarcodeException in case of error + */ + protected function setBars(): void + { + $this->formatCode(); + if (strlen($this->extcode) % 2 != 0) { + // add leading zero if code-length is odd + $this->extcode = '0' . $this->extcode; + } + + $seq = '1110111010'; + $clen = strlen($this->extcode); + for ($idx = 0; $idx < $clen; ++$idx) { + $digit = $this->extcode[$idx]; + if (! isset($this::CHBAR[$digit])) { + throw new BarcodeException('Invalid character: chr(' . ord($digit) . ')'); + } + + $seq .= $this::CHBAR[$digit]; + } + + $seq .= '111010111'; + $this->processBinarySequence($this->getRawCodeRows($seq)); + } +} diff --git a/vendor/tecnickcom/tc-lib-barcode/src/Type/Linear/UpcA.php b/vendor/tecnickcom/tc-lib-barcode/src/Type/Linear/UpcA.php new file mode 100644 index 0000000..31ad162 --- /dev/null +++ b/vendor/tecnickcom/tc-lib-barcode/src/Type/Linear/UpcA.php @@ -0,0 +1,57 @@ + + * @copyright 2010-2024 Nicola Asuni - Tecnick.com LTD + * @license http://www.gnu.org/copyleft/lesser.html GNU-LGPL v3 (see LICENSE.TXT) + * @link https://github.com/tecnickcom/tc-lib-barcode + * + * This file is part of tc-lib-barcode software library. + */ + +namespace Com\Tecnick\Barcode\Type\Linear; + +/** + * Com\Tecnick\Barcode\Type\Linear\UpcA; + * + * UpcA Barcode type class + * UPC-A + * + * @since 2015-02-21 + * @category Library + * @package Barcode + * @author Nicola Asuni + * @copyright 2010-2024 Nicola Asuni - Tecnick.com LTD + * @license http://www.gnu.org/copyleft/lesser.html GNU-LGPL v3 (see LICENSE.TXT) + * @link https://github.com/tecnickcom/tc-lib-barcode + */ +class UpcA extends \Com\Tecnick\Barcode\Type\Linear\EanOneThree +{ + /** + * Barcode format + * + * @var string + */ + protected const FORMAT = 'UPCA'; + + /** + * Fixed code length + */ + protected int $code_length = 12; + + /** + * Format the code + */ + protected function formatCode(): void + { + $code = str_pad($this->code, ($this->code_length - 1), '0', STR_PAD_LEFT); + $code .= $this->getChecksum($code); + ++$this->code_length; + $this->extcode = '0' . $code; + } +} diff --git a/vendor/tecnickcom/tc-lib-barcode/src/Type/Linear/UpcE.php b/vendor/tecnickcom/tc-lib-barcode/src/Type/Linear/UpcE.php new file mode 100644 index 0000000..ec77830 --- /dev/null +++ b/vendor/tecnickcom/tc-lib-barcode/src/Type/Linear/UpcE.php @@ -0,0 +1,170 @@ + + * @copyright 2010-2024 Nicola Asuni - Tecnick.com LTD + * @license http://www.gnu.org/copyleft/lesser.html GNU-LGPL v3 (see LICENSE.TXT) + * @link https://github.com/tecnickcom/tc-lib-barcode + * + * This file is part of tc-lib-barcode software library. + */ + +namespace Com\Tecnick\Barcode\Type\Linear; + +use Com\Tecnick\Barcode\Exception as BarcodeException; + +/** + * Com\Tecnick\Barcode\Type\Linear\UpcE; + * + * UpcE Barcode type class + * UPC-E + * + * UPC-E is a variation of UPC-A which allows for a more compact barcode by eliminating "extra" zeros. + * Since the resulting UPC-E barcode is about half the size as an UPC-A barcode, UPC-E is generally used on products + * with very small packaging where a full UPC-A barcode couldn't reasonably fit. + * + * @since 2015-02-21 + * @category Library + * @package Barcode + * @author Nicola Asuni + * @copyright 2010-2024 Nicola Asuni - Tecnick.com LTD + * @license http://www.gnu.org/copyleft/lesser.html GNU-LGPL v3 (see LICENSE.TXT) + * @link https://github.com/tecnickcom/tc-lib-barcode + */ +class UpcE extends \Com\Tecnick\Barcode\Type\Linear\UpcA +{ + /** + * Barcode format + * + * @var string + */ + protected const FORMAT = 'UPCE'; + + /** + * Fixed code length + */ + protected int $code_length = 12; + + /** + * Map parities + * + * @var array>> + */ + protected const PARITIES_UPCE = [ + 0 => [ + '0' => ['B', 'B', 'B', 'A', 'A', 'A'], + '1' => ['B', 'B', 'A', 'B', 'A', 'A'], + '2' => ['B', 'B', 'A', 'A', 'B', 'A'], + '3' => ['B', 'B', 'A', 'A', 'A', 'B'], + '4' => ['B', 'A', 'B', 'B', 'A', 'A'], + '5' => ['B', 'A', 'A', 'B', 'B', 'A'], + '6' => ['B', 'A', 'A', 'A', 'B', 'B'], + '7' => ['B', 'A', 'B', 'A', 'B', 'A'], + '8' => ['B', 'A', 'B', 'A', 'A', 'B'], + '9' => ['B', 'A', 'A', 'B', 'A', 'B'], + ], + 1 => [ + '0' => ['A', 'A', 'A', 'B', 'B', 'B'], + '1' => ['A', 'A', 'B', 'A', 'B', 'B'], + '2' => ['A', 'A', 'B', 'B', 'A', 'B'], + '3' => ['A', 'A', 'B', 'B', 'B', 'A'], + '4' => ['A', 'B', 'A', 'A', 'B', 'B'], + '5' => ['A', 'B', 'B', 'A', 'A', 'B'], + '6' => ['A', 'B', 'B', 'B', 'A', 'A'], + '7' => ['A', 'B', 'A', 'B', 'A', 'B'], + '8' => ['A', 'B', 'A', 'B', 'B', 'A'], + '9' => ['A', 'B', 'B', 'A', 'B', 'A'], + ], + ]; + + /** + * Convert UPC-E code to UPC-A + * + * @param string $code Code to convert. + */ + protected function convertUpceToUpca(string $code): string + { + if ($code[5] < 3) { + return '0' . $code[0] . $code[1] . $code[5] . '0000' . $code[2] . $code[3] . $code[4]; + } + + if ($code[5] == 3) { + return '0' . $code[0] . $code[1] . $code[2] . '00000' . $code[3] . $code[4]; + } + + if ($code[5] == 4) { + return '0' . $code[0] . $code[1] . $code[2] . $code[3] . '00000' . $code[4]; + } + + return '0' . $code[0] . $code[1] . $code[2] . $code[3] . $code[4] . '0000' . $code[5]; + } + + /** + * Convert UPC-A code to UPC-E + * + * @param string $code Code to convert. + */ + protected function convertUpcaToUpce(string $code): string + { + $tmp = substr($code, 4, 3); + if (($tmp == '000') || ($tmp == '100') || ($tmp == '200')) { + // manufacturer code ends in 000, 100, or 200 + return substr($code, 2, 2) . substr($code, 9, 3) . substr($code, 4, 1); + } + + $tmp = substr($code, 5, 2); + if ($tmp == '00') { + // manufacturer code ends in 00 + return substr($code, 2, 3) . substr($code, 10, 2) . '3'; + } + + $tmp = substr($code, 6, 1); + if ($tmp == '0') { + // manufacturer code ends in 0 + return substr($code, 2, 4) . substr($code, 11, 1) . '4'; + } + + // manufacturer code does not end in zero + return substr($code, 2, 5) . substr($code, 11, 1); + } + + /** + * Format the code + */ + protected function formatCode(): void + { + $code = $this->code; + if (strlen($code) == 6) { + $code = $this->convertUpceToUpca($code); + } + + $code = str_pad($code, ($this->code_length - 1), '0', STR_PAD_LEFT); + $code .= $this->getChecksum($code); + ++$this->code_length; + $this->extcode = '0' . $code; + } + + /** + * Set the bars array. + * + * @throws BarcodeException in case of error + */ + protected function setBars(): void + { + $this->formatCode(); + $upce_code = $this->convertUpcaToUpce($this->extcode); + $seq = '101'; // left guard bar + $parity = $this::PARITIES_UPCE[$this->extcode[1]][$this->check]; + for ($pos = 0; $pos < 6; ++$pos) { + $seq .= $this::CHBAR[$parity[$pos]][$upce_code[$pos]]; + } + + $seq .= '010101'; // right guard bar + $this->processBinarySequence($this->getRawCodeRows($seq)); + } +} diff --git a/vendor/tecnickcom/tc-lib-barcode/src/Type/Raw.php b/vendor/tecnickcom/tc-lib-barcode/src/Type/Raw.php new file mode 100644 index 0000000..09fa716 --- /dev/null +++ b/vendor/tecnickcom/tc-lib-barcode/src/Type/Raw.php @@ -0,0 +1,42 @@ + + * @copyright 2015-2024 Nicola Asuni - Tecnick.com LTD + * @license http://www.gnu.org/copyleft/lesser.html GNU-LGPL v3 (see LICENSE.TXT) + * @link https://github.com/tecnickcom/tc-lib-barcode + * + * This file is part of tc-lib-barcode software library. + */ + +namespace Com\Tecnick\Barcode\Type; + +/** + * Com\Tecnick\Barcode\Type\Raw + * + * Raw Barcode type class + * RAW MODE (comma-separated rows) + * + * @since 2015-02-21 + * @category Library + * @package Barcode + * @author Nicola Asuni + * @copyright 2015-2024 Nicola Asuni - Tecnick.com LTD + * @license http://www.gnu.org/copyleft/lesser.html GNU-LGPL v3 (see LICENSE.TXT) + * @link https://github.com/tecnickcom/tc-lib-barcode + */ +class Raw extends \Com\Tecnick\Barcode\Type +{ + /** + * Generate the bars array + */ + protected function setBars(): void + { + $this->processBinarySequence($this->getRawCodeRows($this->code)); + } +} diff --git a/vendor/tecnickcom/tc-lib-barcode/src/Type/Square.php b/vendor/tecnickcom/tc-lib-barcode/src/Type/Square.php new file mode 100644 index 0000000..7f058a8 --- /dev/null +++ b/vendor/tecnickcom/tc-lib-barcode/src/Type/Square.php @@ -0,0 +1,40 @@ + + * @copyright 2010-2024 Nicola Asuni - Tecnick.com LTD + * @license http://www.gnu.org/copyleft/lesser.html GNU-LGPL v3 (see LICENSE.TXT) + * @link https://github.com/tecnickcom/tc-lib-barcode + * + * This file is part of tc-lib-barcode software library. + */ + +namespace Com\Tecnick\Barcode\Type; + +/** + * Com\Tecnick\Barcode\Type\Square + * + * Barcode type class + * + * @since 2015-02-21 + * @category Library + * @package Barcode + * @author Nicola Asuni + * @copyright 2010-2024 Nicola Asuni - Tecnick.com LTD + * @license http://www.gnu.org/copyleft/lesser.html GNU-LGPL v3 (see LICENSE.TXT) + * @link https://github.com/tecnickcom/tc-lib-barcode + */ +abstract class Square extends \Com\Tecnick\Barcode\Type +{ + /** + * Barcode type + * + * @var string + */ + protected const TYPE = 'square'; +} diff --git a/vendor/tecnickcom/tc-lib-barcode/src/Type/Square/Aztec.php b/vendor/tecnickcom/tc-lib-barcode/src/Type/Square/Aztec.php new file mode 100644 index 0000000..3303081 --- /dev/null +++ b/vendor/tecnickcom/tc-lib-barcode/src/Type/Square/Aztec.php @@ -0,0 +1,150 @@ + + * @copyright 2023-2024 Nicola Asuni - Tecnick.com LTD + * @license http://www.gnu.org/copyleft/lesser.html GNU-LGPL v3 (see LICENSE.TXT) + * @link https://github.com/tecnickcom/tc-lib-barcode + * + * This file is part of tc-lib-barcode software library. + */ + +namespace Com\Tecnick\Barcode\Type\Square; + +use Com\Tecnick\Barcode\Exception as BarcodeException; +use Com\Tecnick\Barcode\Type\Square\Aztec\Data; +use Com\Tecnick\Barcode\Type\Square\Aztec\Encode; + +/** + * Com\Tecnick\Barcode\Type\Square\Aztec + * + * Aztec Barcode type class + * + * @since 2023-10-12 + * @category Library + * @package Barcode + * @author Nicola Asuni + * @copyright 2015-2024 Nicola Asuni - Tecnick.com LTD + * @license http://www.gnu.org/copyleft/lesser.html GNU-LGPL v3 (see LICENSE.TXT) + * @link https://github.com/tecnickcom/tc-lib-barcode + */ +class Aztec extends \Com\Tecnick\Barcode\Type\Square +{ + /** + * Barcode format + * + * @var string + */ + protected const FORMAT = 'AZTEC'; + + /** + * Error correction code percentage of error check words. + * A minimum of 23% + 3 words is recommended by ISO/IEC 24778:2008a. + */ + protected int $ecc = 33; + + /** + * Encoding mode + */ + protected string $hint = 'A'; + + /** + * Mode: + * - A = Automatic selection between Compact (priority) and Full Range. + * - F = Force Full Range mode. + */ + protected string $mode = 'A'; + + /** + * Extended Channel Interpretation (ECI) code to be added at the beginning of the stream. + * See Data:ECI for the list of supported codes. + * NOTE: Even if special FNC1 or ECI flag characters could be inserted + * at any points in the stream, this will only be added at the beginning of the stream. + */ + protected int $eci = -1; + + /** + * Set extra (optional) parameters: + * 1: ECC : Error correction code percentage of error check words. + * A minimum of 23% + 3 words is recommended by ISO/IEC 24778:2008a. + * 2: HINT : Encoding mode: A=Automatic, B=Binary. + * 3: LAYERS : Custom number of layers (0 = auto). + * 4: ECI : Extended Channel Interpretation (ECI) code. Use -1 for FNC1. See $this->eci. + * + * @SuppressWarnings("PHPMD.CyclomaticComplexity") + * @SuppressWarnings("PHPMD.NPathComplexity") + */ + protected function setParameters(): void + { + parent::setParameters(); + + // ecc percentage + if ( + ! isset($this->params[0]) + || ! is_numeric($this->params[0]) + || ! in_array($this->params[0], range(1, 100)) + ) { + $this->params[0] = 33; + } + + $this->ecc = (int) $this->params[0]; + + // hint + if ( + ! isset($this->params[1]) + || ! is_string($this->params[1]) + || ! in_array($this->params[1], ['A', 'B']) + ) { + $this->params[1] = 'A'; + } + + $this->hint = $this->params[1]; + + // mode + if ( + ! isset($this->params[2]) + || ! is_string($this->params[2]) + || ! in_array($this->params[2], ['A', 'F']) + ) { + $this->params[2] = 'A'; + } + + $this->mode = $this->params[2]; + + // eci code. Used to set the charset encoding. See $this->eci. + if ( + ! isset($this->params[3]) + || ! is_numeric($this->params[3]) + || ! isset(Data::ECI[(int) $this->params[3]]) + ) { + $this->params[3] = -1; + } + + $this->eci = (int) $this->params[3]; + } + + /** + * Get the bars array + * + * @throws BarcodeException in case of error + */ + protected function setBars(): void + { + if (strlen((string) $this->code) == 0) { + throw new BarcodeException('Empty input'); + } + + try { + $encode = new Encode($this->code, $this->ecc, $this->eci, $this->hint, $this->mode); + $grid = $encode->getGrid(); + $this->processBinarySequence($grid); + } catch (BarcodeException $barcodeException) { + throw new BarcodeException('AZTEC: ' . $barcodeException->getMessage()); + } + } +} diff --git a/vendor/tecnickcom/tc-lib-barcode/src/Type/Square/Aztec/Bitstream.php b/vendor/tecnickcom/tc-lib-barcode/src/Type/Square/Aztec/Bitstream.php new file mode 100644 index 0000000..d243160 --- /dev/null +++ b/vendor/tecnickcom/tc-lib-barcode/src/Type/Square/Aztec/Bitstream.php @@ -0,0 +1,391 @@ + + * @copyright 2023-2024 Nicola Asuni - Tecnick.com LTD + * @license http://www.gnu.org/copyleft/lesser.html GNU-LGPL v3 (see LICENSE.TXT) + * @link https://github.com/tecnickcom/tc-lib-barcode + * + * This file is part of tc-lib-barcode software library. + */ + +namespace Com\Tecnick\Barcode\Type\Square\Aztec; + +use Com\Tecnick\Barcode\Exception as BarcodeException; + +/** + * Com\Tecnick\Barcode\Type\Square\Aztec\Bitstream + * + * Bitstream for Aztec Barcode type class + * + * @since 2023-10-13 + * @category Library + * @package Barcode + * @author Nicola Asuni + * @copyright 2023-2024 Nicola Asuni - Tecnick.com LTD + * @license http://www.gnu.org/copyleft/lesser.html GNU-LGPL v3 (see LICENSE.TXT) + * @link https://github.com/tecnickcom/tc-lib-barcode + * + * @SuppressWarnings("PHPMD.ExcessiveClassComplexity") + */ +abstract class Bitstream extends \Com\Tecnick\Barcode\Type\Square\Aztec\Layers +{ + /** + * Performs the high-level encoding for the given code and ECI mode. + * + * @param string $code The code to encode. + * @param int $eci The ECI mode to use. + * @param string $hint The mode to use. + */ + protected function highLevelEncoding( + string $code, + int $eci = 0, + string $hint = 'A' + ): void { + $this->addFLG($eci); + $chrarr = unpack('C*', $code); + if ($chrarr === false) { + throw new BarcodeException('Unable to unpack the code'); + } + + $chars = array_values($chrarr); + $chrlen = count($chars); + if ($hint == 'B') { + $this->binaryEncode($chars, $chrlen); // @phpstan-ignore argument.type + return; + } + + $this->autoEncode($chars, $chrlen); // @phpstan-ignore argument.type + } + + /** + * Forced binary encoding for the given characters. + * + * @param array $chars Integer ASCII values of the characters to encode. + * @param int $chrlen Lenght of the $chars array. + */ + protected function binaryEncode(array $chars, int $chrlen): void + { + $bits = Data::MODE_BITS[Data::MODE_BINARY]; + $this->addShift(Data::MODE_BINARY); + if ($chrlen > 62) { + $this->addRawCwd(5, 0); + $this->addRawCwd(11, ($chrlen - 31)); + for ($idx = 0; $idx < $chrlen; ++$idx) { + $this->addRawCwd($bits, $chars[$idx]); + } + + return; + } + + if ($chrlen > 31) { + $this->addRawCwd(5, 31); + for ($idx = 0; $idx < 31; ++$idx) { + $this->addRawCwd($bits, $chars[$idx]); + } + + $this->addShift(Data::MODE_BINARY); + $this->addRawCwd(5, ($chrlen - 31)); + for ($idx = 31; $idx < $chrlen; ++$idx) { + $this->addRawCwd($bits, $chars[$idx]); + } + + return; + } + + $this->addRawCwd(5, $chrlen); + for ($idx = 0; $idx < $chrlen; ++$idx) { + $this->addRawCwd($bits, $chars[$idx]); + } + } + + /** + * Automatic encoding for the given characters. + * + * @param array $chars Integer ASCII values of the characters to encode. + * @param int $chrlen Lenght of the $chars array. + */ + protected function autoEncode(array $chars, int $chrlen): void + { + $idx = 0; + while ($idx < $chrlen) { + if ($this->processBinaryChars($chars, $idx, $chrlen)) { + continue; + } + + if ($this->processPunctPairs($chars, $idx, $chrlen)) { + continue; + } + + $this->processModeChars($chars, $idx, $chrlen); + } + } + + /** + * Process mode characters. + * + * @param array $chars The array of characters. + * @param int $idx The current character index. + * @param int $chrlen The total number of characters to process. + */ + protected function processModeChars(array &$chars, int &$idx, int $chrlen): void + { + $ord = $chars[$idx]; + $mode = $this->isSameMode($this->encmode, $ord) ? $this->encmode : $this->charMode($ord); + + $nchr = $this->countModeChars($chars, $idx, $chrlen, $mode); + if ($this->encmode !== $mode) { + if ( + ($nchr == 1) + && (isset(Data::SHIFT_MAP[$this->encmode][$mode]) + && Data::SHIFT_MAP[$this->encmode][$mode] !== []) + ) { + $this->addShift($mode); + } else { + $this->addLatch($mode); + } + } + + $this->mergeTmpCwd(); + $idx += $nchr; + } + + /** + * Count consecutive characters in the same mode. + * + * @param array $chars The array of characters. + * @param int $idx The current character index. + * @param int $chrlen The total number of characters to process. + * @param int $mode The current mode. + */ + protected function countModeChars( + array &$chars, + int $idx, + int $chrlen, + int $mode + ): int { + $this->tmpCdws = []; + $nbits = Data::MODE_BITS[$mode]; + $count = 0; + do { + $ord = $chars[$idx]; + if ( + (! $this->isSameMode($mode, $ord)) + || (($idx < ($chrlen - 1)) && ($this->punctPairMode($ord, $chars[($idx + 1)]) > 0)) + ) { + return $count; + } + + $this->tmpCdws[] = [$nbits, $this->charEnc($mode, $ord)]; + ++$count; + ++$idx; + } while ($idx < $chrlen); + + return $count; + } + + /** + * Process consecutive binary characters. + * + * @param array $chars The array of characters. + * @param int $idx The current character index. + * @param int $chrlen The total number of characters to process. + * + * @return bool True if binary characters have been found and processed. + */ + protected function processBinaryChars( + array &$chars, + int &$idx, + int $chrlen + ): bool { + $binchrs = $this->countBinaryChars($chars, $idx, $chrlen); + if ($binchrs == 0) { + return false; + } + + $encmode = $this->encmode; + $this->addShift(Data::MODE_BINARY); + if ($binchrs > 62) { + $this->addRawCwd(5, 0); + $this->addRawCwd(11, ($binchrs - 31)); + $this->mergeTmpCwdRaw(); + $idx += $binchrs; + $this->encmode = $encmode; + return true; + } + + if ($binchrs > 31) { + $nbits = Data::MODE_BITS[Data::MODE_BINARY]; + $this->addRawCwd(5, 31); + for ($bcw = 0; $bcw < 31; ++$bcw) { + $this->addRawCwd($nbits, $this->tmpCdws[$bcw][1]); + } + + $this->addShift(Data::MODE_BINARY); + $this->addRawCwd(5, ($binchrs - 31)); + for ($bcw = 31; $bcw < $binchrs; ++$bcw) { + $this->addRawCwd($nbits, $this->tmpCdws[$bcw][1]); + } + + $idx += $binchrs; + $this->encmode = $encmode; + return true; + } + + $this->addRawCwd(5, $binchrs); + $this->mergeTmpCwdRaw(); + $idx += $binchrs; + $this->encmode = $encmode; + return true; + } + + /** + * Count consecutive binary characters. + * + * @param array $chars The array of characters. + * @param int $idx The current character index. + * @param int $chrlen The total number of characters to process. + * + * @SuppressWarnings("PHPMD.CyclomaticComplexity") + */ + protected function countBinaryChars( + array &$chars, + int $idx, + int $chrlen + ): int { + $this->tmpCdws = []; + $count = 0; + $nbits = Data::MODE_BITS[Data::MODE_BINARY]; + while (($idx < $chrlen) && ($count < 2048)) { + $ord = $chars[$idx]; + if ($this->charMode($ord) != Data::MODE_BINARY) { + return $count; + } + + $this->tmpCdws[] = [$nbits, $ord]; + ++$count; + ++$idx; + } + + return $count; + } + + /** + * Process consecutive special Punctuation Pairs. + * + * @param array $chars The array of characters. + * @param int $idx The current character index. + * @param int $chrlen The total number of characters to process. + * + * @return bool True if pair characters have been found and processed. + * + * @SuppressWarnings("PHPMD.CyclomaticComplexity") + */ + protected function processPunctPairs( + array &$chars, + int &$idx, + int $chrlen + ): bool { + $ppairs = $this->countPunctPairs($chars, $idx, $chrlen); + if ($ppairs == 0) { + return false; + } + + switch ($this->encmode) { + case Data::MODE_PUNCT: + break; + case Data::MODE_MIXED: + $this->addLatch(Data::MODE_PUNCT); + break; + case Data::MODE_UPPER: + case Data::MODE_LOWER: + if ($ppairs > 1) { + $this->addLatch(Data::MODE_PUNCT); + } + + break; + case Data::MODE_DIGIT: + $common = $this->countPunctAndDigitChars($chars, $idx, $chrlen); + $clen = count($common); + if (($clen > 0) && ($clen < 6)) { + $this->tmpCdws = $common; + $this->mergeTmpCwdRaw(); + $idx += $clen; + return true; + } + + if ($ppairs > 2) { + $this->addLatch(Data::MODE_PUNCT); + } + + break; + } + + $this->mergeTmpCwd(Data::MODE_PUNCT); + $idx += ($ppairs * 2); + return true; + } + + /** + * Count consecutive special Punctuation Pairs. + * + * @param array $chars The array of characters. + * @param int $idx The current character index. + * @param int $chrlen The total number of characters to process. + */ + protected function countPunctPairs( + array &$chars, + int $idx, + int $chrlen + ): int { + $this->tmpCdws = []; + $pairs = 0; + $maxidx = $chrlen - 1; + while ($idx < $maxidx) { + $pmode = $this->punctPairMode($chars[$idx], $chars[($idx + 1)]); + if ($pmode == 0) { + return $pairs; + } + + $this->tmpCdws[] = [5, $pmode]; + ++$pairs; + $idx += 2; + } + + return $pairs; + } + + /** + * Counts the number of consecutive charcters that are in both PUNCT or DIGIT modes. + * Returns the array with the codewords. + * + * @param array &$chars The string to count the characters in. + * @param int $idx The starting index to count from. + * @param int $chrlen The length of the string to count. + * + * @return array The array of codewords. + */ + protected function countPunctAndDigitChars( + array &$chars, + int $idx, + int $chrlen + ): array { + $words = []; + while ($idx < $chrlen) { + $ord = $chars[$idx]; + if (! $this->isPunctAndDigitChar($ord)) { + return $words; + } + + $words[] = [4, $this->charEnc(Data::MODE_DIGIT, $ord)]; + ++$idx; + } + + return $words; + } +} diff --git a/vendor/tecnickcom/tc-lib-barcode/src/Type/Square/Aztec/Codeword.php b/vendor/tecnickcom/tc-lib-barcode/src/Type/Square/Aztec/Codeword.php new file mode 100644 index 0000000..0305850 --- /dev/null +++ b/vendor/tecnickcom/tc-lib-barcode/src/Type/Square/Aztec/Codeword.php @@ -0,0 +1,302 @@ + + * @copyright 2023-2024 Nicola Asuni - Tecnick.com LTD + * @license http://www.gnu.org/copyleft/lesser.html GNU-LGPL v3 (see LICENSE.TXT) + * @link https://github.com/tecnickcom/tc-lib-barcode + * + * This file is part of tc-lib-barcode software library. + */ + +namespace Com\Tecnick\Barcode\Type\Square\Aztec; + +/** + * Com\Tecnick\Barcode\Type\Square\Aztec\Codeword + * + * Codeword utility methods for Aztec Barcode type class + * + * @since 2023-10-13 + * @category Library + * @package Barcode + * @author Nicola Asuni + * @copyright 2023-2024 Nicola Asuni - Tecnick.com LTD + * @license http://www.gnu.org/copyleft/lesser.html GNU-LGPL v3 (see LICENSE.TXT) + * @link https://github.com/tecnickcom/tc-lib-barcode + */ +abstract class Codeword +{ + /** + * Current character encoding mode. + */ + protected int $encmode = Data::MODE_UPPER; + + /** + * Array containing the high-level encoding bitstream. + * + * @var array + */ + protected array $bitstream = []; + + /** + * Temporary array of codewords. + * + * @var array + */ + protected array $tmpCdws = []; + + /** + * Count the total number of bits in the bitstream. + */ + protected int $totbits = 0; + + /** + * Encodes a character using the specified mode and ordinal value. + * + * @param int $mode The encoding mode. + * @param int $ord The ordinal value of the character to encode. + * + * @return int The encoded character. + */ + protected function charEnc(int $mode, int $ord): int + { + return isset(Data::CHAR_ENC[$mode][$ord]) ? Data::CHAR_ENC[$mode][$ord] : 0; + } + + /** + * Returns the character mode for a given ASCII code. + * + * @param int $ord The ASCII code of the character. + * + * @return int The character mode. + */ + protected function charMode(int $ord): int + { + return isset(Data::CHAR_MODES[$ord]) ? Data::CHAR_MODES[$ord] : Data::MODE_BINARY; + } + + /** + * Checks if current character is supported by the current code. + * + * @param int $mode The mode to check. + * @param int $ord The character ASCII value to compare against. + * + * @return bool Returns true if the mode is the same as the ordinal value, false otherwise. + */ + protected function isSameMode(int $mode, int $ord): bool + { + return ( + ($mode === $this->charMode($ord)) + || (($ord == 32) && ($mode != Data::MODE_PUNCT)) + || (($mode == Data::MODE_PUNCT) && (($ord == 13) || ($ord == 44) || ($ord == 46))) + ); + } + + /** + * Returns true if the character is in common between the PUNCT and DIGIT modes. + * Characters ' ' (32), '.' (46) and ',' (44) are in common between the PUNCT and DIGIT modes. + * + * @param int $ord Integer ASCII code of the character to check. + */ + protected function isPunctAndDigitChar(int $ord): bool + { + return (($ord == 32) || ($ord == 44) || ($ord == 46)); + } + + /** + * Returns the PUNCT two-bytes code if the given two characters are a punctuation pair. + * Punct codes 2–5 encode two bytes each. + * + * @param int $ord The current curacter code. + * @param int $next The next character code. + */ + protected function punctPairMode(int $ord, int $next): int + { + $key = (($ord << 8) + $next); + return match ($key) { + (13 << 8) + 10 => 2, + (46 << 8) + 32 => 3, + (44 << 8) + 32 => 4, + (58 << 8) + 32 => 5, + default => 0, + }; // no punct pair + } + + /** + * Append a new Codeword as a big-endian bit sequence. + * + * @param array $bitstream Array of bits to append to. + * @param int $totbits Number of bits in the bitstream. + * @param int $wsize The number of bits in the codeword. + * @param int $value The value of the codeword. + */ + protected function appendWordToBitstream( + array &$bitstream, + int &$totbits, + int $wsize, + int $value + ): void { + for ($idx = ($wsize - 1); $idx >= 0; --$idx) { + $bitstream[] = (($value >> $idx) & 1); + } + + $totbits += $wsize; + } + + /** + * Convert the bitstream to words. + * + * @param array $bitstream Array of bits to convert. + * @param int $totbits Number of bits in the bitstream. + * @param int $wsize The word size. + * + * @return array Array of words. + */ + protected function bitstreamToWords( + array $bitstream, + int $totbits, + int $wsize + ): array { + $words = []; + $numwords = (int) ceil($totbits / $wsize); + for ($idx = 0; $idx < $numwords; ++$idx) { + $wrd = 0; + for ($bit = 0; $bit < $wsize; ++$bit) { + $pos = (($idx * $wsize) + $bit); + if (! empty($bitstream[$pos]) || ! isset($bitstream[$pos])) { + $wrd |= (1 << ($wsize - $bit - 1)); // reverse order + } + } + + $words[] = $wrd; + } + + return $words; + } + + /** + * Add a new Codeword as a big-endian bit sequence. + * + * @param int $bits The number of bits in the codeword. + * @param int $value The value of the codeword. + */ + protected function addRawCwd(int $bits, int $value): void + { + $this->appendWordToBitstream($this->bitstream, $this->totbits, $bits, $value); + } + + /** + * Adds a Codeword. + * + * @param int $mode The encoding mode. + * @param int $value The value to encode. + */ + protected function addCdw(int $mode, int $value): void + { + $this->addRawCwd(Data::MODE_BITS[$mode], $value); + } + + /** + * Latch to another mode. + * + * @param int $mode The new encoding mode. + */ + protected function addLatch(int $mode): void + { + $latch = Data::LATCH_MAP[$this->encmode][$mode]; + foreach ($latch as $cdw) { + $this->addRawCwd($cdw[0], $cdw[1]); + } + + $this->encmode = $mode; + } + + /** + * Shift to another mode. + */ + protected function addShift(int $mode): void + { + $shift = Data::SHIFT_MAP[$this->encmode][$mode]; + foreach ($shift as $cdw) { + $this->addRawCwd($cdw[0], $cdw[1]); + } + } + + /** + * Merges the temporary codewords array with the current codewords array. + * Shift to the specified mode. + * + * @param int $mode The encoding mode for the codewords. + */ + protected function mergeTmpCwdWithShift(int $mode): void + { + foreach ($this->tmpCdws as $tmpCdw) { + $this->addShift($mode); + $this->addRawCwd($tmpCdw[0], $tmpCdw[1]); + } + } + + /** + * Merges the temporary codewords array with the current codewords array. + * No shift is performed. + */ + protected function mergeTmpCwdRaw(): void + { + foreach ($this->tmpCdws as $tmpCdw) { + $this->addRawCwd($tmpCdw[0], $tmpCdw[1]); + } + } + + /** + * Merge temporary codewords with current codewords based on the encoding mode. + * + * @param int $mode The encoding mode to use for merging codewords. + * If negative, the current encoding mode will be used. + */ + protected function mergeTmpCwd(int $mode = -1): void + { + if (($mode < 0) || ($this->encmode == $mode)) { + $this->mergeTmpCwdRaw(); + } else { + $this->mergeTmpCwdWithShift($mode); + } + + $this->tmpCdws = []; + } + + /** + * Adds the FLG (Function Length Group) codeword to the data codewords. + * + * @param int $eci Extended Channel Interpretation value. If negative, the function does nothing. + */ + protected function addFLG(int $eci): void + { + if ($eci < 0) { + return; + } + + if ($this->encmode != Data::MODE_PUNCT) { + $this->addShift(Data::MODE_PUNCT); + } + + if ($eci == 0) { + $this->addRawCwd(3, 0); // FNC1 + return; + } + + $seci = (string) $eci; + $digits = strlen($seci); + $this->addRawCwd(3, $digits); // 1–6 digits + for ($idx = 0; $idx < $digits; ++$idx) { + $this->addCdw( + Data::MODE_DIGIT, + $this->charEnc(Data::MODE_DIGIT, ord($seci[$idx])) + ); + } + } +} diff --git a/vendor/tecnickcom/tc-lib-barcode/src/Type/Square/Aztec/Data.php b/vendor/tecnickcom/tc-lib-barcode/src/Type/Square/Aztec/Data.php new file mode 100644 index 0000000..91e0fb2 --- /dev/null +++ b/vendor/tecnickcom/tc-lib-barcode/src/Type/Square/Aztec/Data.php @@ -0,0 +1,556 @@ + + * @copyright 2023-2024 Nicola Asuni - Tecnick.com LTD + * @license http://www.gnu.org/copyleft/lesser.html GNU-LGPL v3 (see LICENSE.TXT) + * @link https://github.com/tecnickcom/tc-lib-barcode + * + * This file is part of tc-lib-barcode software library. + */ + +namespace Com\Tecnick\Barcode\Type\Square\Aztec; + +/** + * Com\Tecnick\Barcode\Type\Square\Aztec\Data + * + * Data for Aztec Barcode type class + * + * @since 2023-10-13 + * @category Library + * @package Barcode + * @author Nicola Asuni + * @copyright 2023-2024 Nicola Asuni - Tecnick.com LTD + * @license http://www.gnu.org/copyleft/lesser.html GNU-LGPL v3 (see LICENSE.TXT) + * @link https://github.com/tecnickcom/tc-lib-barcode + */ +class Data +{ + /** + * Code character encoding mode for uppercase letters. + * + * @var int + */ + public const MODE_UPPER = 0; + + /** + * Code character encoding mode for lowercase letters. + * + * @var int + */ + public const MODE_LOWER = 1; + + /** + * Code character encoding mode for digits. + * + * @var int + */ + public const MODE_DIGIT = 2; + + /** + * Code character encoding mode for mixed cases. + * + * @var int + */ + public const MODE_MIXED = 3; + + /** + * Code character encoding mode for punctuation. + * + * @var int + */ + public const MODE_PUNCT = 4; + + /** + * Code character encoding mode for binary. + * + * @var int + */ + public const MODE_BINARY = 5; + + /** + * Number of bits for each character encoding mode. + * + * @var array + */ + public const MODE_BITS = [ + 5, // 0 = MODE_UPPER + 5, // 1 = MODE_LOWER + 4, // 2 = MODE_DIGIT + 5, // 3 = MODE_MIXED + 5, // 4 = MODE_PUNCT + 8, // 5 = MODE_BINARY + ]; + + /** + * Code character encoding for each mode. + * + * @var array> + */ + public const CHAR_ENC = [ + // MODE_UPPER (initial mode) + 0 => [ + 32 => 1, // ' ' (SP) + 65 => 2, // 'A' + 66 => 3, // 'B' + 67 => 4, // 'C' + 68 => 5, // 'D' + 69 => 6, // 'E' + 70 => 7, // 'F' + 71 => 8, // 'G' + 72 => 9, // 'H' + 73 => 10, // 'I' + 74 => 11, // 'J' + 75 => 12, // 'K' + 76 => 13, // 'L' + 77 => 14, // 'M' + 78 => 15, // 'N' + 79 => 16, // 'O' + 80 => 17, // 'P' + 81 => 18, // 'Q' + 82 => 19, // 'R' + 83 => 20, // 'S' + 84 => 21, // 'T' + 85 => 22, // 'U' + 86 => 23, // 'V' + 87 => 24, // 'W' + 88 => 25, // 'X' + 89 => 26, // 'Y' + 90 => 27, // 'Z' + ], + // MODE_LOWER + 1 => [ + 32 => 1, // ' ' (SP) + 97 => 2, // 'a' + 98 => 3, // 'b' + 99 => 4, // 'c' + 100 => 5, // 'd' + 101 => 6, // 'e' + 102 => 7, // 'f' + 103 => 8, // 'g' + 104 => 9, // 'h' + 105 => 10, // 'i' + 106 => 11, // 'j' + 107 => 12, // 'k' + 108 => 13, // 'l' + 109 => 14, // 'm' + 110 => 15, // 'n' + 111 => 16, // 'o' + 112 => 17, // 'p' + 113 => 18, // 'q' + 114 => 19, // 'r' + 115 => 20, // 's' + 116 => 21, // 't' + 117 => 22, // 'u' + 118 => 23, // 'v' + 119 => 24, // 'w' + 120 => 25, // 'x' + 121 => 26, // 'y' + 122 => 27, // 'z' + ], + // MODE_DIGIT + 2 => [ + 32 => 1, // ' ' (SP) + 44 => 12, // ',' + 46 => 13, // '.' + 48 => 2, // '0' + 49 => 3, // '1' + 50 => 4, // '2' + 51 => 5, // '3' + 52 => 6, // '4' + 53 => 7, // '5' + 54 => 8, // '6' + 55 => 9, // '7' + 56 => 10, // '8' + 57 => 11, // '9' + ], + // MODE_MIXED + 3 => [ + 1 => 2, // '^A' (SOH) + 2 => 3, // '^B' (STX) + 3 => 4, // '^C' (ETX) + 4 => 5, // '^D' (EOT) + 5 => 6, // '^E' (ENQ) + 6 => 7, // '^F' (ACK) + 7 => 8, // '^G' (BEL) + 8 => 9, // '^H' (BS) + 9 => 10, // '^I' (HT) + 10 => 11, // '^J' (LF) + 11 => 12, // '^K' (VT) + 12 => 13, // '^L' (FF) + 13 => 14, // '^M' (CR) + 27 => 15, // '^[' (ESC) + 28 => 16, // '^\' (FS) + 29 => 17, // '^]' (GS) + 30 => 18, // '^^' (RS) + 31 => 19, // '^_' (US) + 64 => 20, // '@' + 92 => 21, // '\' + 94 => 22, // '^' + 95 => 23, // '_' + 96 => 24, // '`' + 124 => 25, // '|' + 126 => 26, // '~' + 127 => 27, // '^?' (DEL) + ], + // MODE_PUNCT + 4 => [ + 13 => 1, // '\r' (CR) + 33 => 6, // '!' + 34 => 7, // '"' + 35 => 8, // '#' + 36 => 9, // '$' + 37 => 10, // '%' + 38 => 11, // '&' + 39 => 12, // ''' + 40 => 13, // '(' + 41 => 14, // ')' + 42 => 15, // '*' + 43 => 16, // '+' + 44 => 17, // ',' + 45 => 18, // '-' + 46 => 19, // '.' + 47 => 20, // '/' + 58 => 21, // ':' + 59 => 22, // ';' + 60 => 23, // '<' + 61 => 24, // '=' + 62 => 25, // '>' + 63 => 26, // '?' + 91 => 27, // '[' + 93 => 28, // ']' + 123 => 29, // '{' + 125 => 30, // '}' + ], + // MODE_BINARY (all 8-bit values are valid) + 5 => [], + ]; + + /** + * Map character ASCII codes to their non-binary mode. + * Exceptions are: + * - the space ' ' character (32) that maps for modes 0,1,2. + * - the carriage return '\r' character (13) that maps for modes 3,4. + * - the comma ',' and dot '.' characters (44,46) that map for modes 2,4. + * + * @var array + */ + public const CHAR_MODES = [ + 1 => 3, // '^A' (SOH) + 2 => 3, // '^B' (STX) + 3 => 3, // '^C' (ETX) + 4 => 3, // '^D' (EOT) + 5 => 3, // '^E' (ENQ) + 6 => 3, // '^F' (ACK) + 7 => 3, // '^G' (BEL) + 8 => 3, // '^H' (BS) + 9 => 3, // '^I' (HT) + 10 => 3, // '^J' (LF) + 11 => 3, // '^K' (VT) + 12 => 3, // '^L' (FF) + 13 => 3, // '^M' (CR) [3,4] + 27 => 3, // '^[' (ESC) + 28 => 3, // '^\' (FS) + 29 => 3, // '^]' (GS) + 30 => 3, // '^^' (RS) + 31 => 3, // '^_' (US) + 32 => 0, // ' ' [0,1,2] + 33 => 4, // '!' + 34 => 4, // '"' + 35 => 4, // '#' + 36 => 4, // '$' + 37 => 4, // '%' + 38 => 4, // '&' + 39 => 4, // ''' + 40 => 4, // '(' + 41 => 4, // ')' + 42 => 4, // '*' + 43 => 4, // '+'f + 44 => 2, // ',' [2,4] + 45 => 4, // '-' + 46 => 2, // '.' [2,4] + 47 => 4, // '/' + 48 => 2, // '0' + 49 => 2, // '1' + 50 => 2, // '2' + 51 => 2, // '3' + 52 => 2, // '4' + 53 => 2, // '5' + 54 => 2, // '6' + 55 => 2, // '7' + 56 => 2, // '8' + 57 => 2, // '9' + 58 => 4, // ':' + 59 => 4, // ';' + 60 => 4, // '<' + 61 => 4, // '=' + 62 => 4, // '>' + 63 => 4, // '?' + 64 => 3, // '@' + 65 => 0, // 'A' + 66 => 0, // 'B' + 67 => 0, // 'C' + 68 => 0, // 'D' + 69 => 0, // 'E' + 70 => 0, // 'F' + 71 => 0, // 'G' + 72 => 0, // 'H' + 73 => 0, // 'I' + 74 => 0, // 'J' + 75 => 0, // 'K' + 76 => 0, // 'L' + 77 => 0, // 'M' + 78 => 0, // 'N' + 79 => 0, // 'O' + 80 => 0, // 'P' + 81 => 0, // 'Q' + 82 => 0, // 'R' + 83 => 0, // 'S' + 84 => 0, // 'T' + 85 => 0, // 'U' + 86 => 0, // 'V' + 87 => 0, // 'W' + 88 => 0, // 'X' + 89 => 0, // 'Y' + 90 => 0, // 'Z' + 91 => 4, // '[' + 92 => 3, // '\' + 93 => 4, // ']' + 94 => 3, // '^' + 95 => 3, // '_' + 96 => 3, // '`' + 97 => 1, // 'a' + 98 => 1, // 'b' + 99 => 1, // 'c' + 100 => 1, // 'd' + 101 => 1, // 'e' + 102 => 1, // 'f' + 103 => 1, // 'g' + 104 => 1, // 'h' + 105 => 1, // 'i' + 106 => 1, // 'j' + 107 => 1, // 'k' + 108 => 1, // 'l' + 109 => 1, // 'm' + 110 => 1, // 'n' + 111 => 1, // 'o' + 112 => 1, // 'p' + 113 => 1, // 'q' + 114 => 1, // 'r' + 115 => 1, // 's' + 116 => 1, // 't' + 117 => 1, // 'u' + 118 => 1, // 'v' + 119 => 1, // 'w' + 120 => 1, // 'x' + 121 => 1, // 'y' + 122 => 1, // 'z' + 123 => 4, // '{' + 124 => 3, // '|' + 125 => 4, // '}' + 126 => 3, // '~' + 127 => 3, // '^?' (DEL) + ]; + + /** + * Latch map for changing character encoding mode. + * Numbers represent: [number of bits to change, latch code value]. + * + * @var array>> + */ + public const LATCH_MAP = [ + // MODE_UPPER + 0 => [ + 1 => [[5, 28]], // -> LOWER + 2 => [[5, 30]], // -> DIGIT + 3 => [[5, 29]], // -> MIXED + 4 => [[5, 29], [5, 30]], // -> MIXED -> PUNCT + ], + // MODE_LOWER + 1 => [ + 0 => [[5, 30], [4, 14]], // -> DIGIT -> UPPER + 2 => [[5, 30]], // -> DIGIT + 3 => [[5, 29]], // -> MIXED + 4 => [[5, 29], [5, 30]], // -> MIXED -> PUNCT + ], + // MODE_DIGIT + 2 => [ + 0 => [[4, 14]], // -> UPPER + 1 => [[4, 14], [5, 28]], // -> UPPER -> LOWER + 3 => [[4, 14], [5, 29]], // -> UPPER -> MIXED + 4 => [[4, 14], [5, 29], [5, 30]], // -> UPPER -> MIXED -> PUNCT + ], + // MODE_MIXED + 3 => [ + 0 => [[5, 29]], // -> UPPER + 1 => [[5, 28]], // -> LOWER + 2 => [[5, 29], [5, 30]], // -> UPPER -> DIGIT + 4 => [[5, 30]], // -> PUNCT + ], + // MODE_PUNCT + 4 => [ + 0 => [[5, 31]], // -> UPPER + 1 => [[5, 31], [5, 28]], // -> UPPER -> LOWER + 2 => [[5, 31], [5, 30]], // -> UPPER -> DIGIT + 3 => [[5, 31], [5, 29]], // -> UPPER -> MIXED + ], + ]; + + /** + * Shift map for changing character encoding mode. + * Numbers represent: [number of bits to change, shift code value]. + * + * @var array>> + */ + public const SHIFT_MAP = [ + // MODE_UPPER + 0 => [ + 1 => [], + 2 => [], + 3 => [], + 4 => [[5, 0]], // -> PUNCT + 5 => [[5, 31]], // -> BINARY + ], + // MODE_LOWER + 1 => [ + 0 => [[5, 28]], // -> UPPER + 2 => [], + 3 => [], + 4 => [[5, 0]], // -> PUNCT + 5 => [[5, 31]], // -> BINARY + ], + // MODE_DIGIT + 2 => [ + 0 => [[4, 15]], // -> UPPER + 1 => [], + 3 => [], + 4 => [[4, 0]], // -> PUNCT + 5 => [[4, 14], [5, 31]], // -> LATCH UPPER -> BINARY + ], + // MODE_MIXED + 3 => [ + 0 => [], + 1 => [], + 2 => [], + 4 => [[5, 0]], // -> PUNCT + 5 => [[5, 31]], // -> BINARY + ], + // MODE_PUNCT + 4 => [ + 0 => [], + 1 => [], + 2 => [], + 3 => [], + 5 => [[5, 31], [5, 31]], // -> LATCH UPPER -> BINARY + ], + ]; + + /** + * Extended Channel Interpretation (ECI) codes. + * + * @var array + */ + public const ECI = [ + 0 => 'FNC1', // Function 1 character + 2 => 'Cp437', // Code page 437 + 3 => 'ISO-8859-1', // ISO/IEC 8859-1 - Latin-1 (Default encoding) + 4 => 'ISO-8859-2', // ISO/IEC 8859-2 - Latin-2 + 5 => 'ISO-8859-3', // ISO/IEC 8859-3 - Latin-3 + 6 => 'ISO-8859-4', // ISO/IEC 8859-4 - Latin-4 + 7 => 'ISO-8859-5', // ISO/IEC 8859-5 - Latin/Cyrillic + 8 => 'ISO-8859-6', // ISO/IEC 8859-6 - Latin/Arabic + 9 => 'ISO-8859-7', // ISO/IEC 8859-7 - Latin/Greek + 10 => 'ISO-8859-8', // ISO/IEC 8859-8 - Latin/Hebrew + 11 => 'ISO-8859-9', // ISO/IEC 8859-9 - Latin-5 + 12 => 'ISO-8859-10', // ISO/IEC 8859-10 - Latin-6 + 13 => 'ISO-8859-11', // ISO/IEC 8859-11 - Latin/Thai + 15 => 'ISO-8859-13', // ISO/IEC 8859-13 - Latin-7 + 16 => 'ISO-8859-14', // ISO/IEC 8859-14 - Latin-8 (Celtic) + 17 => 'ISO-8859-15', // ISO/IEC 8859-15 - Latin-9 + 18 => 'ISO-8859-16', // ISO/IEC 8859-16 - Latin-10 + 20 => 'Shift JIS', // + 21 => 'Cp1250', // Windows-1250 - Superset of Latin-2 + 22 => 'Cp1251', // Windows-1251 - Latin/Cyrillic + 23 => 'Cp1252', // Windows-1252 - Superset of Latin-1 + 24 => 'Cp1256', // Windows-1256 - Arabic + 25 => 'UTF-16BE', // UnicodeBig, UnicodeBigUnmarked + 26 => 'UTF-8', // + 27 => 'US-ASCII', // + 28 => 'Big5', // + 29 => 'GB18030', // GB2312, EUC_CN, GBK + 30 => 'EUC-KR', // + ]; + + /** + * Size and capacities of Aztec Compact Code symbols by number of layers. + * The array entries are: + * - 0: symbol x size; + * - 1: codeword count; + * - 2: codeword size; + * - 3: symbol bit capacity; + * - 4: symbol data digits capacity; + * - 5: symbol data text capacity; + * - 6: symbol data bytes capacity. + * + * @var array + */ + public const SIZE_COMPACT = [ + 1 => [15, 17, 6, 102, 13, 12, 6], + 2 => [19, 40, 6, 240, 40, 33, 19], + 3 => [23, 51, 8, 408, 70, 57, 33], + 4 => [27, 76, 8, 608, 110, 89, 53], + ]; + + /** + * Size and capacities of Aztec Full-range Code symbols by number of layers. + * The array entries are: + * - 0: symbol x size; + * - 1: codeword count; + * - 2: codeword size; + * - 3: symbol bit capacity; + * - 4: symbol data digits capacity; + * - 5: symbol data text capacity; + * - 6: symbol data bytes capacity. + * + * @var array + */ + public const SIZE_FULL = [ + 1 => [19, 21, 6, 126, 18, 15, 8], + 2 => [23, 48, 6, 288, 49, 40, 24], + 3 => [27, 60, 8, 480, 84, 68, 40], + 4 => [31, 88, 8, 704, 128, 104, 62], + 5 => [37, 120, 8, 960, 178, 144, 87], + 6 => [41, 156, 8, 1248, 232, 187, 114], + 7 => [45, 196, 8, 1568, 294, 236, 145], + 8 => [49, 240, 8, 1920, 362, 291, 179], + 9 => [53, 230, 10, 2300, 433, 348, 214], + 10 => [57, 272, 10, 2720, 516, 414, 256], + 11 => [61, 316, 10, 3160, 601, 482, 298], + 12 => [67, 364, 10, 3640, 691, 554, 343], + 13 => [71, 416, 10, 4160, 793, 636, 394], + 14 => [75, 470, 10, 4700, 896, 718, 446], + 15 => [79, 528, 10, 5280, 1008, 808, 502], + 16 => [83, 588, 10, 5880, 1123, 900, 559], + 17 => [87, 652, 10, 6520, 1246, 998, 621], + 18 => [91, 720, 10, 7200, 1378, 1104, 687], + 19 => [95, 790, 10, 7900, 1511, 1210, 753], + 20 => [101, 864, 10, 8640, 1653, 1324, 824], + 21 => [105, 940, 10, 9400, 1801, 1442, 898], + 22 => [109, 1020, 10, 10200, 1956, 1566, 976], + 23 => [113, 920, 12, 11040, 2116, 1694, 1056], + 24 => [117, 992, 12, 11904, 2281, 1826, 1138], + 25 => [121, 1066, 12, 12792, 2452, 1963, 1224], + 26 => [125, 1144, 12, 13728, 2632, 2107, 1314], + 27 => [131, 1224, 12, 14688, 2818, 2256, 1407], + 28 => [135, 1306, 12, 15672, 3007, 2407, 1501], + 29 => [139, 1392, 12, 16704, 3205, 2565, 1600], + 30 => [143, 1480, 12, 17760, 3409, 2728, 1702], + 31 => [147, 1570, 12, 18840, 3616, 2894, 1806], + 32 => [151, 1664, 12, 19968, 3832, 3067, 1914], + ]; +} diff --git a/vendor/tecnickcom/tc-lib-barcode/src/Type/Square/Aztec/Encode.php b/vendor/tecnickcom/tc-lib-barcode/src/Type/Square/Aztec/Encode.php new file mode 100644 index 0000000..72d2ec7 --- /dev/null +++ b/vendor/tecnickcom/tc-lib-barcode/src/Type/Square/Aztec/Encode.php @@ -0,0 +1,364 @@ + + * @copyright 2023-2024 Nicola Asuni - Tecnick.com LTD + * @license http://www.gnu.org/copyleft/lesser.html GNU-LGPL v3 (see LICENSE.TXT) + * @link https://github.com/tecnickcom/tc-lib-barcode + * + * This file is part of tc-lib-barcode software library. + */ + +namespace Com\Tecnick\Barcode\Type\Square\Aztec; + +use Com\Tecnick\Barcode\Exception as BarcodeException; + +/** + * Com\Tecnick\Barcode\Type\Square\Aztec\Encode + * + * Encode for Aztec Barcode type class + * + * @since 2023-10-13 + * @category Library + * @package Barcode + * @author Nicola Asuni + * @copyright 2023-2024 Nicola Asuni - Tecnick.com LTD + * @license http://www.gnu.org/copyleft/lesser.html GNU-LGPL v3 (see LICENSE.TXT) + * @link https://github.com/tecnickcom/tc-lib-barcode + */ +class Encode extends \Com\Tecnick\Barcode\Type\Square\Aztec\Bitstream +{ + /** + * Bidimensional grid containing the encoded data. + * + * @var array> + */ + protected array $grid = []; + + /** + * Coordinate of the grid center. + */ + protected int $gridcenter = 0; + + /** + * Aztec main encoder. + * + * @param string $code The code to encode. + * @param int $ecc The error correction code percentage of error check words. + * @param int $eci The ECI mode to use. + * @param string $hint The mode to use. + * @param string $mode The mode to use (A = Automatic; F = Full Range mode). + */ + public function __construct( + string $code, + int $ecc = 33, + int $eci = 0, + string $hint = 'A', + string $mode = 'A' + ) { + $this->highLevelEncoding($code, $eci, $hint); + if (! $this->sizeAndBitStuffing($ecc, $mode)) { + throw new BarcodeException('Data too long'); + } + + $wsize = $this->layer[2]; + $nbits = $this->layer[3]; + $numcdw = $this->addCheckWords($this->bitstream, $this->totbits, $nbits, $wsize); + $this->setGrid(); + $this->drawMode($numcdw); + $this->drawData(); + } + + /** + * Returns the bidimensional grid containing the encoded data. + * + * @return array> + */ + public function getGrid(): array + { + return $this->grid; + } + + /** + * Returns the Check Codewords array for the given data words. + * + * @param array $bitstream Array of bits. + * @param int $totbits Number of bits in the bitstream. + * @param int $nbits Number of bits per layer. + * @param int $wsize Word size. + * + * @return int The number of data codewords. + */ + protected function addCheckWords( + array &$bitstream, + int &$totbits, + int $nbits, + int $wsize + ): int { + $cdw = $this->bitstreamToWords($bitstream, $totbits, $wsize); + $numcdw = count($cdw); + $totwords = (int) ($nbits / $wsize); + $eccwords = ($totwords - $numcdw); + $errorCorrection = new ErrorCorrection($wsize); + $checkwords = $errorCorrection->checkwords($cdw, $eccwords); + // append check codewords + foreach ($checkwords as $checkword) { + $this->appendWordToBitstream($bitstream, $totbits, $wsize, $checkword); + } + + return $numcdw; + } + + /** + * Initialize the grid with all patterns. + */ + protected function setGrid(): void + { + // initialize grid + $size = $this->layer[0]; + $row = array_fill(0, $size, 0); + $this->grid = array_fill(0, $size, $row); + // draw center + $center = (int) (($size - 1) / 2); + $this->gridcenter = $center; + $this->grid[$center][$center] = 1; + // draw finder pattern (bulls-eye) + $bewidth = $this->compact ? 11 : 15; + $bemid = (int) (($bewidth - 1) / 2); + for ($rng = 2; $rng < $bemid; $rng += 2) { + // center cross points + $this->grid[($center + $rng)][($center)] = 1; + $this->grid[($center - $rng)][($center)] = 1; + $this->grid[($center)][($center + $rng)] = 1; + $this->grid[($center)][($center - $rng)] = 1; + // corner points + $this->grid[($center + $rng)][($center + $rng)] = 1; + $this->grid[($center + $rng)][($center - $rng)] = 1; + $this->grid[($center - $rng)][($center + $rng)] = 1; + $this->grid[($center - $rng)][($center - $rng)] = 1; + for ($pos = 1; $pos < $rng; ++$pos) { + // horizontal points + $this->grid[($center + $rng)][($center + $pos)] = 1; + $this->grid[($center + $rng)][($center - $pos)] = 1; + $this->grid[($center - $rng)][($center + $pos)] = 1; + $this->grid[($center - $rng)][($center - $pos)] = 1; + // vertical points + $this->grid[($center + $pos)][($center + $rng)] = 1; + $this->grid[($center + $pos)][($center - $rng)] = 1; + $this->grid[($center - $pos)][($center + $rng)] = 1; + $this->grid[($center - $pos)][($center - $rng)] = 1; + } + } + + // draw orientation patterns + $this->grid[($center - $bemid)][($center - $bemid)] = 1; // TL + $this->grid[($center - $bemid)][($center - $bemid + 1)] = 1; // TL-R + $this->grid[($center - $bemid + 1)][($center - $bemid)] = 1; // TL-B + $this->grid[($center - $bemid)][($center + $bemid)] = 1; // TR-T + $this->grid[($center - $bemid + 1)][($center + $bemid)] = 1; // TR-B + $this->grid[($center + $bemid - 1)][($center + $bemid)] = 1; // BR + if ($this->compact) { + return; + } + + // draw reference grid for full mode + $halfsize = (int) (($size - 1) / 2); + // central cross + for ($pos = 8; $pos <= $halfsize; $pos += 2) { + // horizontal + $this->grid[($center)][($center - $pos)] = 1; + $this->grid[($center)][($center + $pos)] = 1; + // vertical + $this->grid[($center - $pos)][($center)] = 1; + $this->grid[($center + $pos)][($center)] = 1; + } + + // grid lines + for ($pos = 2; $pos <= $halfsize; $pos += 2) { + for ($ref = 16; $ref <= $halfsize; $ref += 16) { + // horizontal + $this->grid[($center - $ref)][($center - $pos)] = 1; + $this->grid[($center - $ref)][($center + $pos)] = 1; + $this->grid[($center + $ref)][($center - $pos)] = 1; + $this->grid[($center + $ref)][($center + $pos)] = 1; + // vertical + $this->grid[($center - $pos)][($center - $ref)] = 1; + $this->grid[($center - $pos)][($center + $ref)] = 1; + $this->grid[($center + $pos)][($center - $ref)] = 1; + $this->grid[($center + $pos)][($center + $ref)] = 1; + } + } + } + + /** + * Add the mode message to the grid. + * + * @param int $numcdw Number of data codewords. + * + * @SuppressWarnings("PHPMD.CyclomaticComplexity") + * @SuppressWarnings("PHPMD.NPathComplexity") + */ + protected function drawMode(int $numcdw): void + { + $modebs = []; + $nbits = 0; + $center = $this->gridcenter; + $modebits = 40; + $layersbits = 5; + $codewordsbits = 11; + $sidelen = 10; + $srow = -7; + $scol = -5; + if ($this->compact) { + $modebits = 28; + $layersbits = 2; + $codewordsbits = 6; + $sidelen = 7; + $srow = -5; + $scol = -3; + } + + $this->appendWordToBitstream($modebs, $nbits, $layersbits, ($this->numlayers - 1)); + $this->appendWordToBitstream($modebs, $nbits, $codewordsbits, ($numcdw - 1)); + $this->addCheckWords($modebs, $nbits, $modebits, 4); + // draw the mode message in the grid clockwise starting from the top left corner + $bit = 0; + // top + $ypos = ($center + $srow); + $xpos = ($center + $scol); + for ($pos = 0; $pos < $sidelen; ++$pos) { + $xpos += $this->skipModeRefGrid($pos); + $this->grid[$ypos][$xpos] = (empty($modebs[$bit++]) ? 0 : 1); + ++$xpos; + } + + // right + $ypos += 2; + ++$xpos; + for ($pos = 0; $pos < $sidelen; ++$pos) { + $ypos += $this->skipModeRefGrid($pos); + $this->grid[$ypos][$xpos] = (empty($modebs[$bit++]) ? 0 : 1); + ++$ypos; + } + + // bottom + ++$ypos; + $xpos -= 2; + for ($pos = 0; $pos < $sidelen; ++$pos) { + $xpos -= $this->skipModeRefGrid($pos); + $this->grid[$ypos][$xpos] = (empty($modebs[$bit++]) ? 0 : 1); + --$xpos; + } + + // left + $ypos -= 2; + --$xpos; + for ($pos = 0; $pos < $sidelen; ++$pos) { + $ypos -= $this->skipModeRefGrid($pos); + $this->grid[$ypos][$xpos] = (empty($modebs[$bit++]) ? 0 : 1); + --$ypos; + } + } + + /** + * Returns a bit from the end of the bitstream and update the index. + * + * @param int $bit Index of the bit to pop. + */ + protected function popBit(int &$bit): int + { + return (empty($this->bitstream[$bit--]) ? 0 : 1); + } + + /** + * Returns 1 if the current position must be skipped in Full mode. + * + * @param int $pos Position in the grid. + */ + protected function skipModeRefGrid(int $pos): int + { + return (int) ((! $this->compact) && ($pos == 5)); + } + + /** + * Returns the offset for the specified position to skip the reference grid. + * + * @param int $pos Position in the grid. + */ + protected function skipRefGrid(int $pos): int + { + return (int) ((! $this->compact) && (($pos % 16) == 0)); + } + + /** + * Draw the data bitstream in the grid in Full mode. + */ + protected function drawData(): void + { + $center = $this->gridcenter; + $llen = 16; // width of the first layer side + $srow = -8; // start top row offset from the center (LSB) + $scol = -7; // start top column offset from the center (LSB) + if ($this->compact) { + $llen = 13; + $srow = -6; + $scol = -5; + } + + $skip = 0; // skip reference grid while drwaing dominoes + $bit = ($this->totbits - 1); // index of last bitstream bit (first to draw) + for ($layer = 0; $layer < $this->numlayers; ++$layer) { + // top + $ypos = ($center + $srow); + $xpos = ($center + $scol); + for ($pos = 0; $pos < $llen; ++$pos) { + $xpos += $this->skipRefGrid($xpos - $center); // skip reference grid + $this->grid[$ypos][$xpos] = $this->popBit($bit); + $this->grid[($ypos - 1 - $skip)][$xpos] = $this->popBit($bit); + ++$xpos; + } + + // right + ++$ypos; + $xpos -= (2 + $skip); + for ($pos = 0; $pos < $llen; ++$pos) { + $ypos += $this->skipRefGrid($ypos - $center); // skip reference grid + $this->grid[$ypos][$xpos] = $this->popBit($bit); + $this->grid[$ypos][($xpos + 1 + $skip)] = $this->popBit($bit); + ++$ypos; + } + + // bottom + $ypos -= (2 + $skip); + --$xpos; + for ($pos = 0; $pos < $llen; ++$pos) { + $xpos -= $this->skipRefGrid($xpos - $center); // skip reference grid + $this->grid[$ypos][$xpos] = $this->popBit($bit); + $this->grid[($ypos + 1 + $skip)][$xpos] = $this->popBit($bit); + --$xpos; + } + + // left + --$ypos; + $xpos += (2 + $skip); + for ($pos = 0; $pos < $llen; ++$pos) { + $ypos -= $this->skipRefGrid($ypos - $center); // skip reference grid + $this->grid[$ypos][$xpos] = $this->popBit($bit); + $this->grid[$ypos][($xpos - 1 - $skip)] = $this->popBit($bit); + --$ypos; + } + + $llen += 4; + $srow = ($ypos - $center); + $srow -= $this->skipRefGrid($srow); + $scol = ($xpos - 1 - $center); + $scol -= $this->skipRefGrid($scol); + $skip = $this->skipRefGrid($srow - 1); + } + } +} diff --git a/vendor/tecnickcom/tc-lib-barcode/src/Type/Square/Aztec/ErrorCorrection.php b/vendor/tecnickcom/tc-lib-barcode/src/Type/Square/Aztec/ErrorCorrection.php new file mode 100644 index 0000000..0eecca1 --- /dev/null +++ b/vendor/tecnickcom/tc-lib-barcode/src/Type/Square/Aztec/ErrorCorrection.php @@ -0,0 +1,266 @@ + + * @copyright 2023-2024 Nicola Asuni - Tecnick.com LTD + * @license http://www.gnu.org/copyleft/lesser.html GNU-LGPL v3 (see LICENSE.TXT) + * @link https://github.com/tecnickcom/tc-lib-barcode + * + * This file is part of tc-lib-barcode software library. + */ + +namespace Com\Tecnick\Barcode\Type\Square\Aztec; + +/** + * Com\Tecnick\Barcode\Type\Square\Aztec\ErrorCorrection + * + * ErrorCorrection for Aztec Barcode type class + * + * @since 2023-10-13 + * @category Library + * @package Barcode + * @author Nicola Asuni + * @copyright 2023-2024 Nicola Asuni - Tecnick.com LTD + * @license http://www.gnu.org/copyleft/lesser.html GNU-LGPL v3 (see LICENSE.TXT) + * @link https://github.com/tecnickcom/tc-lib-barcode + */ +class ErrorCorrection +{ + /** + * Galois Field primitive by word size. + * + * @var array + */ + protected const GF = [ + 4 => 19, // 10011 GF(16) (x^4 + x + 1) Mode message + 6 => 67, // 1000011 GF(64) (x^6 + x + 1) 01–02 layers + 8 => 301, // 100101101 GF(256) (x^8 + x^5 + x^3 + x^2 + 1) 03–08 layers + 10 => 1033, // 10000001001 GF(1024) (x^10 + x^3 + 1) 09–22 layers + 12 => 4201, // 1000001101001 GF(4096) (x^12 + x^6 + x^5 + x^3 + 1) 23–32 layers + ]; + + /** + * Map the log and exp (inverse log) tables by word size. + * NOTE: It is equal to 2^word_size. + * + * @var array + */ + protected const TSIZE = [ + 4 => 16, + 6 => 64, + 8 => 256, + 10 => 1024, + 12 => 4096, + ]; + + /** + * Log table. + * + * @var array + */ + protected array $tlog = []; + + /** + * Exponential (inverse log) table. + * + * @var array + */ + protected array $texp = []; + + /** + * Size of the log and exp tables. + */ + protected int $tsize = 0; + + /** + * Initialize the the Reed-Solomon Error Correction. + * + * @param int $wsize Size of a word in bits. + */ + public function __construct(int $wsize) + { + $this->genTables($wsize); + } + + /** + * Returns the Reed-Solomon Error Correction Codewords added to the input data. + * + * @param array $data Array of data codewords to process. + * @param int $necc Number of error correction bytes. + * + * @return array + */ + public function checkwords(array $data, int $necc): array + { + $coeff = $this->getCoefficients($data, $necc); + return array_pad($coeff, -$necc, 0); // @phpstan-ignore return.type + } + + /** + * Generates log and exp (inverse log) tables. + * + * @param int $wsize Size of the word in bits. + */ + protected function genTables(int $wsize): void + { + $this->tsize = self::TSIZE[$wsize]; + $this->tlog = array_fill(0, $this->tsize, 0); + $this->texp = $this->tlog; + $primitive = self::GF[$wsize]; + $val = 1; + $sizeminusone = ($this->tsize - 1); + for ($idx = 0; $idx < $this->tsize; ++$idx) { + $this->texp[$idx] = $val; + $val <<= 1; // multiply by 2 + if ($val >= $this->tsize) { + $val ^= $primitive; + $val &= $sizeminusone; + } + } + + for ($idx = 0; $idx < $this->tsize - 1; ++$idx) { + $this->tlog[$this->texp[$idx]] = $idx; + } + } + + /** + * Calculates the coefficients of the error correction polynomial. + * + * @param array $data Array of data codewords to process. + * @param int $necc Number of error correction bytes. + * + * @return array Array of coefficients. + */ + protected function getCoefficients(array $data, int $necc): array + { + $gen = [1]; + for ($idx = 1; $idx <= $necc; ++$idx) { + $gen = $this->multiplyCoeff([1, $this->texp[$idx]], $gen); + } + + $deg = ($necc + 1); + $coeff = $this->multiplyByMonomial($data, 1, $necc); + $len = count($coeff); + while (($len >= $deg) && ($coeff[0] != 0)) { + $scale = $this->multiply($coeff[0], 1); + $largercoeffs = $this->multiplyByMonomial($gen, $scale, ($len - $deg)); + $coeff = $this->addOrSubtract($coeff, $largercoeffs); + $len = count($coeff); + } + + return $coeff; + } + + /** + * Returns the product of two coefficient arrays. + * + * @param array $acf First array of coefficients. + * @param array $bcf Second array of coefficients. + * + * @return array Array of coefficients. + */ + protected function multiplyCoeff(array $acf, array $bcf): array + { + $alen = count($acf); + $blen = count($bcf); + $coeff = array_fill(0, ($alen + $blen - 1), 0); + for ($aid = 0; $aid < $alen; ++$aid) { + for ($bid = 0; $bid < $blen; ++$bid) { + $coeff[$aid + $bid] ^= ($this->multiply($acf[$aid], $bcf[$bid])); + } + } + + return $this->trimCoefficients($coeff); + } + + /** + * Returns the product of $aval and $bval in GF(size). + * + * @param int $aval First value. + * @param int $bval Second value. + */ + protected function multiply(int $aval, int $bval): int + { + if ($aval == 0 || $bval == 0) { + return 0; + } + + return $this->texp[($this->tlog[$aval] + $this->tlog[$bval]) % ($this->tsize - 1)]; + } + + /** + * Left-trim coefficients array. + * + * @param array $coeff Array of coefficients. + * + * @return array Array of coefficients. + */ + protected function trimCoefficients(array $coeff): array + { + while ($coeff !== [] && $coeff[0] == 0) { + array_shift($coeff); + } + + return $coeff; + } + + /** + * Returns the product of a polynomial by a monomial. + * + * @param array $coeff Array of polynomial coefficients. + * @param int $mon Monomial. + * @param int $deg Degree of the monomial. + * + * @return array Array of coefficients. + */ + protected function multiplyByMonomial(array $coeff, int $mon, int $deg): array + { + // if ($mon == 0) { + // return array(0); + // } + $ncf = count($coeff); + $prod = array_fill(0, ($ncf + $deg), 0); + for ($idx = 0; $idx < $ncf; ++$idx) { + $prod[$idx] = $this->multiply($coeff[$idx], $mon); + } + + return $this->trimCoefficients($prod); + } + + /** + * Adds or subtracts two coefficient arrays. + * + * @param array $smaller The smaller array of coefficients. + * @param array $larger The larger array of coefficients. + * + * @return array Array of coefficients. + */ + protected function addOrSubtract(array $smaller, array $larger): array + { + // if ($smaller[0] == 0) { + // return $larger; + // } + // if ($larger[0] == 0) { + // return $smaller; + // } + $slen = count($smaller); + $llen = count($larger); + // if ($slen > $llen) { + // // swap arrays + // list($smaller, $larger) = array($larger, $smaller); + // list($slen, $llen) = array($llen, $slen); + // } + $lendiff = ($llen - $slen); + $coeff = array_slice($larger, 0, $lendiff); + for ($idx = $lendiff; $idx < $llen; ++$idx) { + $coeff[$idx] = ($smaller[($idx - $lendiff)] ^ $larger[$idx]); + } + + return $this->trimCoefficients($coeff); + } +} diff --git a/vendor/tecnickcom/tc-lib-barcode/src/Type/Square/Aztec/Layers.php b/vendor/tecnickcom/tc-lib-barcode/src/Type/Square/Aztec/Layers.php new file mode 100644 index 0000000..e298e7f --- /dev/null +++ b/vendor/tecnickcom/tc-lib-barcode/src/Type/Square/Aztec/Layers.php @@ -0,0 +1,163 @@ + + * @copyright 2023-2024 Nicola Asuni - Tecnick.com LTD + * @license http://www.gnu.org/copyleft/lesser.html GNU-LGPL v3 (see LICENSE.TXT) + * @link https://github.com/tecnickcom/tc-lib-barcode + * + * This file is part of tc-lib-barcode software library. + */ + +namespace Com\Tecnick\Barcode\Type\Square\Aztec; + +/** + * Com\Tecnick\Barcode\Type\Square\Aztec\Layers + * + * Layers for Aztec Barcode type class + * + * @since 2023-10-13 + * @category Library + * @package Barcode + * @author Nicola Asuni + * @copyright 2023-2024 Nicola Asuni - Tecnick.com LTD + * @license http://www.gnu.org/copyleft/lesser.html GNU-LGPL v3 (see LICENSE.TXT) + * @link https://github.com/tecnickcom/tc-lib-barcode + */ +abstract class Layers extends \Com\Tecnick\Barcode\Type\Square\Aztec\Codeword +{ + /** + * True for compact mode (up to 4 layers), false for full-range mode (up to 32 layers). + */ + protected bool $compact = true; + + /** + * Number of data layers. + */ + protected int $numlayers = 0; + + /** + * Size data for the selected layer. + * + * @var array{int, int, int, int, int, int, int} + */ + protected array $layer = [0, 0, 0, 0, 0, 0, 0]; + + /** + * Returns the minimum number of layers required. + * + * @param array $data + * Either the Data::SIZE_COMPACT or Data::SIZE_FULL array. + * @param int $numbits The number of bits to encode. + */ + protected function getMinLayers(array $data, int $numbits): int + { + if ($numbits <= $data[count($data)][3]) { + foreach ($data as $numlayers => $size) { + if ($numbits <= $size[3]) { + return $numlayers; + } + } + } + + return 0; + } + + /** + * Select the layer by the number of bits to encode. + * + * @param int $numbits The number of bits to encode. + * @param string $mode The mode to use (A = Automatic; F = Full Range mode). + * + * @return bool Returns true if the size computation was successful, false otherwise. + */ + protected function setLayerByBits(int $numbits, string $mode = 'A'): bool + { + $this->numlayers = 0; + if ($mode == 'A') { + $this->compact = true; + $this->numlayers = $this->getMinLayers(Data::SIZE_COMPACT, $numbits); + } + + if ($this->numlayers == 0) { + $this->compact = false; + $this->numlayers = $this->getMinLayers(Data::SIZE_FULL, $numbits); + } + + if ($this->numlayers == 0) { + return false; + } + + $this->layer = $this->compact ? Data::SIZE_COMPACT[$this->numlayers] : Data::SIZE_FULL[$this->numlayers]; + return true; + } + + /** + * Computes the type and number of required layers and performs bit stuffing + * + * @param int $ecc The error correction level. + * @param string $mode The mode to use (A = Automatic; F = Full Range mode). + * + * @return bool Returns true if the size computation was successful, false otherwise. + */ + protected function sizeAndBitStuffing(int $ecc, string $mode = 'A'): bool + { + $nsbits = 0; + $eccbits = (11 + (int) (($this->totbits * $ecc) / 100)); + do { + if (! $this->setLayerByBits(($this->totbits + $nsbits + $eccbits), $mode)) { + return false; + } + + $nsbits = $this->bitStuffing(); + } while (($nsbits + $eccbits) > $this->layer[3]); + + $this->bitstream = []; + $this->totbits = 0; + $this->mergeTmpCwdRaw(); + return true; + } + + /** + * Bit-stuffing the bitstream into Reed–Solomon codewords. + * The resulting codewords are stored in the temporary tmpCdws array. + * + * @return int The number of bits in the bitstream after bit stuffing. + */ + protected function bitStuffing(): int + { + $nsbits = 0; + $wsize = $this->layer[2]; + $mask = ((1 << $wsize) - 2); // b-1 bits at 1 and last bit at 0 + $this->tmpCdws = []; + for ($wid = 0; $wid < $this->totbits; $wid += $wsize) { + $word = 0; + for ($idx = 0; $idx < $wsize; ++$idx) { + $bid = ($wid + $idx); + if (($bid >= $this->totbits) || ($this->bitstream[$bid] == 1)) { + $word |= (1 << ($wsize - 1 - $idx)); // the first bit is MSB + } + } + + // If the first b−1 bits of a code word have the same value, + // an extra bit with the complementary value is inserted into the data stream. + if (($word & $mask) === $mask) { + $word &= $mask; + --$wid; + } elseif (($word & $mask) == 0) { + $word |= 1; + --$wid; + } + + $this->tmpCdws[] = [$wsize, $word]; + $nsbits += $wsize; + } + + return $nsbits; + } +} diff --git a/vendor/tecnickcom/tc-lib-barcode/src/Type/Square/Datamatrix.php b/vendor/tecnickcom/tc-lib-barcode/src/Type/Square/Datamatrix.php new file mode 100644 index 0000000..1953372 --- /dev/null +++ b/vendor/tecnickcom/tc-lib-barcode/src/Type/Square/Datamatrix.php @@ -0,0 +1,322 @@ + + * @copyright 2010-2024 Nicola Asuni - Tecnick.com LTD + * @license http://www.gnu.org/copyleft/lesser.html GNU-LGPL v3 (see LICENSE.TXT) + * @link https://github.com/tecnickcom/tc-lib-barcode + * + * This file is part of tc-lib-barcode software library. + */ + +namespace Com\Tecnick\Barcode\Type\Square; + +use Com\Tecnick\Barcode\Exception as BarcodeException; +use Com\Tecnick\Barcode\Type\Square\Datamatrix\Data; +use Com\Tecnick\Barcode\Type\Square\Datamatrix\Encode; + +/** + * Com\Tecnick\Barcode\Type\Square\Datamatrix + * + * Datamatrix Barcode type class + * DATAMATRIX (ISO/IEC 16022) + * + * @since 2015-02-21 + * @category Library + * @package Barcode + * @author Nicola Asuni + * @copyright 2010-2024 Nicola Asuni - Tecnick.com LTD + * @license http://www.gnu.org/copyleft/lesser.html GNU-LGPL v3 (see LICENSE.TXT) + * @link https://github.com/tecnickcom/tc-lib-barcode + */ +class Datamatrix extends \Com\Tecnick\Barcode\Type\Square +{ + /** + * Barcode format + * + * @var string + */ + protected const FORMAT = 'DATAMATRIX'; + + /** + * Array of codewords. + * + * @var array + */ + protected array $cdw = []; + + /** + * Binary grid + * + * @var array> + */ + protected array $grid = []; + + /** + * Datamatrix Encoding object + */ + protected Encode $dmx; + + /** + * Datamatrix shape key (S=square, R=rectangular) + */ + protected string $shape = 'S'; + + /** + * Datamatrix variant (N=default, GS1=FNC1 codeword in first place) + */ + protected bool $gsonemode = false; + + /** + * Datamatrix default encoding. + * See Data::SWITCHCDW for valid values. + */ + protected int $defenc = Data::ENC_ASCII; + + /** + * Set extra (optional) parameters: + * 1: SHAPE: S=square (default), R=rectangular. + * 2: MODE: N=default, GS1 = the FNC1 codeword is added in the first position of Data Matrix ECC 200 version. + * 3: ENCODING: ASCII (default), C40, TXT, X12, EDIFACT, BASE256. + */ + protected function setParameters(): void + { + parent::setParameters(); + + // shape + if (isset($this->params[0]) && ($this->params[0] === 'R')) { + $this->shape = 'R'; + } + + // mode + $this->gsonemode = (isset($this->params[1]) && ($this->params[1] === 'GS1')); + + // encoding + if (isset($this->params[2])) { + $this->defenc = Data::ENCOPTS[$this->params[2]] ?? Data::ENC_ASCII; + } + } + + /** + * Add padding codewords + * + * @param int $size Max barcode size in codewords + * @param int $ncw Number of codewords + * + * @throws BarcodeException in case of error + */ + protected function addPadding(int $size, int $ncw): void + { + if ($size <= $ncw) { + return; + } + + if (($this->dmx->last_enc != Data::ENC_ASCII) && ($this->dmx->last_enc != Data::ENC_BASE256)) { + // return to ASCII encodation before padding + $this->cdw[] = $this->dmx->last_enc == Data::ENC_EDF ? 124 : 254; + + ++$ncw; + } + + if ($size > $ncw) { + // add first pad + $this->cdw[] = 129; + ++$ncw; + // add remaining pads + for ($i = $ncw; $i < $size; ++$i) { + $this->cdw[] = $this->dmx->get253StateCodeword(129, $i); + } + } + } + + /** + * Get the codewords + * + * @return array{int, int, int, int, int, int, int, int, int, int, int, int, int, int, int, int} params + * + * @throws BarcodeException in case of error + */ + protected function getCodewords(): array + { + if (strlen((string) $this->code) == 0) { + throw new BarcodeException('Empty input'); + } + + // get data codewords + $this->cdw = $this->getHighLevelEncoding($this->code); + + // number of data codewords + $ncw = count($this->cdw); + + // check size + if ($ncw > 1560) { + throw new BarcodeException('the input is too large to fit the barcode'); + } + + // get minimum required matrix size. + $params = Data::getPaddingSize($this->shape, $ncw); + $this->addPadding($params[11], $ncw); + + $errorCorrection = new \Com\Tecnick\Barcode\Type\Square\Datamatrix\ErrorCorrection(); + $this->cdw = $errorCorrection->getErrorCorrection($this->cdw, $params[13], $params[14], $params[15]); + + return $params; + } + + /** + * Set the grid + * + * @param int $idx Index + * @param array $places Places + * @param int $row Row + * @param int $col Column + * @param int $rdx Region data row index + * @param int $cdx Region data column index + * @param int $rdri Region data row max index + * @param int $rdci Region data column max index + */ + protected function setGrid( + int &$idx, + array &$places, + int &$row, + int &$col, + int &$rdx, + int &$cdx, + int &$rdri, + int &$rdci + ): void { + // braw bits by case + if ($rdx == 0) { + // top finder pattern + $this->grid[$row][$col] = (int) (($cdx % 2) == 0); + } elseif ($rdx == $rdri) { + // bottom finder pattern + $this->grid[$row][$col] = 1; + } elseif ($cdx == 0) { + // left finder pattern + $this->grid[$row][$col] = 1; + } elseif ($cdx == $rdci) { + // right finder pattern + $this->grid[$row][$col] = (int) (($rdx % 2) > 0); + } else { + // data bit + if ($places[$idx] < 2) { + $this->grid[$row][$col] = $places[$idx]; + } else { + // codeword ID + $cdw_id = (floor($places[$idx] / 10) - 1); + // codeword BIT mask + $cdw_bit = 2 ** (8 - ($places[$idx] % 10)); + $this->grid[$row][$col] = (($this->cdw[$cdw_id] & $cdw_bit) == 0) ? 0 : 1; + } + + ++$idx; + } + } + + /** + * Get high level encoding using the minimum symbol data characters for ECC 200 + * + * @param string $data data to encode + * + * @return array Codewords + * + * @SuppressWarnings("PHPMD.CyclomaticComplexity") + */ + protected function getHighLevelEncoding(string $data): array + { + // STEP A. Start in predefined encodation. + $enc = $this->defenc; // current encoding mode + $this->dmx->last_enc = $enc; // last used encoding + $pos = 0; // current position + $cdw = []; // array of codewords to be returned + $cdw_num = 0; // number of data codewords + $data_length = strlen($data); // number of chars + $field_length = 0; // number of chars in current field + + // Switch to predefined encoding (no action needed if ASCII because it's the default encoding) + if ($this->defenc !== Data::ENC_ASCII) { + $cdw[] = $this->dmx->getSwitchEncodingCodeword($this->defenc); + ++$cdw_num; + } + + while ($pos < $data_length) { + // Determine if current char is FNC1 (don't encode it, just pass it through) + if ($this->gsonemode && ($data[$pos] == chr(232))) { + $cdw[] = 232; + ++$pos; + ++$cdw_num; + continue; + } + + switch ($enc) { + case Data::ENC_ASCII: + // STEP B. While in ASCII encodation + $this->dmx->encodeASCII($cdw, $cdw_num, $pos, $data_length, $data, $enc); + break; + case Data::ENC_C40: + // Upper-case alphanumeric + case Data::ENC_TXT: + // Lower-case alphanumeric + case Data::ENC_X12: + // ANSI X12 + $this->dmx->encodeTXT($cdw, $cdw_num, $pos, $data_length, $data, $enc); + break; + case Data::ENC_EDF: + // F. While in EDIFACT (EDF) encodation + $this->dmx->encodeEDF($cdw, $cdw_num, $pos, $data_length, $field_length, $data, $enc); + break; + case Data::ENC_BASE256: + // G. While in Base 256 (B256) encodation + $this->dmx->encodeBase256($cdw, $cdw_num, $pos, $data_length, $field_length, $data, $enc); + break; + } + + $this->dmx->last_enc = $enc; + } + + return $cdw; + } + + /** + * Get the bars array + * + * @throws BarcodeException in case of error + */ + protected function setBars(): void + { + $this->dmx = new Encode($this->shape); + $params = $this->getCodewords(); + // get placement map + $places = $this->dmx->getPlacementMap($params[2], $params[3]); + // fill the grid with data + $this->grid = []; + $idx = 0; + // region data row max index + $rdri = ($params[4] - 1); + // region data column max index + $rdci = ($params[5] - 1); + // for each horizontal region + for ($hr = 0; $hr < $params[8]; ++$hr) { + // for each row on region + for ($rdx = 0; $rdx < $params[4]; ++$rdx) { + $row = (($hr * $params[4]) + $rdx); + // for each vertical region + for ($vr = 0; $vr < $params[9]; ++$vr) { + // for each column on region + for ($cdx = 0; $cdx < $params[5]; ++$cdx) { + $col = (($vr * $params[5]) + $cdx); + $this->setGrid($idx, $places, $row, $col, $rdx, $cdx, $rdri, $rdci); + } + } + } + } + + $this->processBinarySequence($this->grid); + } +} diff --git a/vendor/tecnickcom/tc-lib-barcode/src/Type/Square/Datamatrix/Data.php b/vendor/tecnickcom/tc-lib-barcode/src/Type/Square/Datamatrix/Data.php new file mode 100644 index 0000000..372d3a6 --- /dev/null +++ b/vendor/tecnickcom/tc-lib-barcode/src/Type/Square/Datamatrix/Data.php @@ -0,0 +1,1027 @@ + + * @copyright 2010-2024 Nicola Asuni - Tecnick.com LTD + * @license http://www.gnu.org/copyleft/lesser.html GNU-LGPL v3 (see LICENSE.TXT) + * @link https://github.com/tecnickcom/tc-lib-barcode + * + * This file is part of tc-lib-barcode software library. + */ + +namespace Com\Tecnick\Barcode\Type\Square\Datamatrix; + +use Com\Tecnick\Barcode\Exception as BarcodeException; + +/** + * Com\Tecnick\Barcode\Type\Square\Datamatrix\Data + * + * Data for Datamatrix Barcode type class + * + * @since 2015-02-21 + * @category Library + * @package Barcode + * @author Nicola Asuni + * @copyright 2010-2024 Nicola Asuni - Tecnick.com LTD + * @license http://www.gnu.org/copyleft/lesser.html GNU-LGPL v3 (see LICENSE.TXT) + * @link https://github.com/tecnickcom/tc-lib-barcode + */ +class Data +{ + /** + * ASCII encoding: ASCII character 0 to 127 (1 byte per CW) + * + * @var int + */ + public const ENC_ASCII = 0; + + /** + * C40 encoding: Upper-case alphanumeric (3/2 bytes per CW) + * + * @var int + */ + public const ENC_C40 = 1; + + /** + * TEXT encoding: Lower-case alphanumeric (3/2 bytes per CW) + * + * @var int + */ + public const ENC_TXT = 2; + + /** + * X12 encoding: ANSI X12 (3/2 byte per CW) + * + * @var int + */ + public const ENC_X12 = 3; + + /** + * EDIFACT encoding: ASCII character 32 to 94 (4/3 bytes per CW) + * + * @var int + */ + public const ENC_EDF = 4; + + /** + * BASE 256 encoding: ASCII character 0 to 255 (1 byte per CW) + * + * @var int + */ + public const ENC_BASE256 = 5; + + /** + * ASCII extended encoding: ASCII character 128 to 255 (1/2 byte per CW) + * + * @var int + */ + public const ENC_ASCII_EXT = 6; + + /** + * ASCII number encoding: ASCII digits (2 bytes per CW) + * + * @var int + */ + public const ENC_ASCII_NUM = 7; + + /** + * Encoding options that can be specified as input parameter. + * + * @var array + */ + public const ENCOPTS = [ + 'ASCII' => Data::ENC_ASCII, + 'C40' => Data::ENC_C40, + 'TXT' => Data::ENC_TXT, + 'X12' => Data::ENC_X12, + 'EDF' => Data::ENC_EDF, + 'BASE256' => Data::ENC_BASE256, + ]; + + /** + * Switch codewords. + * + * @var array + */ + public const SWITCHCDW = [ + Data::ENC_ASCII => 254, + Data::ENC_C40 => 230, + Data::ENC_TXT => 239, + Data::ENC_X12 => 238, + Data::ENC_EDF => 240, + Data::ENC_BASE256 => 231, + ]; + + /** + * Table of Data Matrix ECC 200 Symbol Attributes: + *
  • SHAPE
      + *
    • total matrix rows (including finder pattern)
    • + *
    • total matrix cols (including finder pattern)
    • + *
    • total matrix rows (without finder pattern)
    • + *
    • total matrix cols (without finder pattern)
    • + *
    • region data rows (with finder pattern)
    • + *
    • region data col (with finder pattern)
    • + *
    • region data rows (without finder pattern)
    • + *
    • region data col (without finder pattern)
    • + *
    • horizontal regions
    • + *
    • vertical regions
    • + *
    • regions
    • + *
    • data codewords
    • + *
    • error codewords
    • + *
    • blocks
    • + *
    • data codewords per block
    • + *
    • error codewords per block
    • + *
+ * + * @var array> + */ + public const SYMBATTR = [ + 'S' => [ + // square form + // 10x10 + [ + 0x00a, + 0x00a, + 0x008, + 0x008, + 0x00a, + 0x00a, + 0x008, + 0x008, + 0x001, + 0x001, + 0x001, + 0x003, + 0x005, + 0x001, + 0x003, + 0x005, + ], + // 12x12 + [ + 0x00c, + 0x00c, + 0x00a, + 0x00a, + 0x00c, + 0x00c, + 0x00a, + 0x00a, + 0x001, + 0x001, + 0x001, + 0x005, + 0x007, + 0x001, + 0x005, + 0x007, + ], + // 14x14 + [ + 0x00e, + 0x00e, + 0x00c, + 0x00c, + 0x00e, + 0x00e, + 0x00c, + 0x00c, + 0x001, + 0x001, + 0x001, + 0x008, + 0x00a, + 0x001, + 0x008, + 0x00a, + ], + // 16x16 + [ + 0x010, + 0x010, + 0x00e, + 0x00e, + 0x010, + 0x010, + 0x00e, + 0x00e, + 0x001, + 0x001, + 0x001, + 0x00c, + 0x00c, + 0x001, + 0x00c, + 0x00c, + ], + // 18x18 + [ + 0x012, + 0x012, + 0x010, + 0x010, + 0x012, + 0x012, + 0x010, + 0x010, + 0x001, + 0x001, + 0x001, + 0x012, + 0x00e, + 0x001, + 0x012, + 0x00e, + ], + // 20x20 + [ + 0x014, + 0x014, + 0x012, + 0x012, + 0x014, + 0x014, + 0x012, + 0x012, + 0x001, + 0x001, + 0x001, + 0x016, + 0x012, + 0x001, + 0x016, + 0x012, + ], + // 22x22 + [ + 0x016, + 0x016, + 0x014, + 0x014, + 0x016, + 0x016, + 0x014, + 0x014, + 0x001, + 0x001, + 0x001, + 0x01e, + 0x014, + 0x001, + 0x01e, + 0x014, + ], + // 24x24 + [ + 0x018, + 0x018, + 0x016, + 0x016, + 0x018, + 0x018, + 0x016, + 0x016, + 0x001, + 0x001, + 0x001, + 0x024, + 0x018, + 0x001, + 0x024, + 0x018, + ], + // 26x26 + [ + 0x01a, + 0x01a, + 0x018, + 0x018, + 0x01a, + 0x01a, + 0x018, + 0x018, + 0x001, + 0x001, + 0x001, + 0x02c, + 0x01c, + 0x001, + 0x02c, + 0x01c, + ], + // 32x32 + [ + 0x020, + 0x020, + 0x01c, + 0x01c, + 0x010, + 0x010, + 0x00e, + 0x00e, + 0x002, + 0x002, + 0x004, + 0x03e, + 0x024, + 0x001, + 0x03e, + 0x024, + ], + // 36x36 + [ + 0x024, + 0x024, + 0x020, + 0x020, + 0x012, + 0x012, + 0x010, + 0x010, + 0x002, + 0x002, + 0x004, + 0x056, + 0x02a, + 0x001, + 0x056, + 0x02a, + ], + // 40x40 + [ + 0x028, + 0x028, + 0x024, + 0x024, + 0x014, + 0x014, + 0x012, + 0x012, + 0x002, + 0x002, + 0x004, + 0x072, + 0x030, + 0x001, + 0x072, + 0x030, + ], + // 44x44 + [ + 0x02c, + 0x02c, + 0x028, + 0x028, + 0x016, + 0x016, + 0x014, + 0x014, + 0x002, + 0x002, + 0x004, + 0x090, + 0x038, + 0x001, + 0x090, + 0x038, + ], + // 48x48 + [ + 0x030, + 0x030, + 0x02c, + 0x02c, + 0x018, + 0x018, + 0x016, + 0x016, + 0x002, + 0x002, + 0x004, + 0x0ae, + 0x044, + 0x001, + 0x0ae, + 0x044, + ], + // 52x52 + [ + 0x034, + 0x034, + 0x030, + 0x030, + 0x01a, + 0x01a, + 0x018, + 0x018, + 0x002, + 0x002, + 0x004, + 0x0cc, + 0x054, + 0x002, + 0x066, + 0x02a, + ], + // 64x64 + [ + 0x040, + 0x040, + 0x038, + 0x038, + 0x010, + 0x010, + 0x00e, + 0x00e, + 0x004, + 0x004, + 0x010, + 0x118, + 0x070, + 0x002, + 0x08c, + 0x038, + ], + // 72x72 + [ + 0x048, + 0x048, + 0x040, + 0x040, + 0x012, + 0x012, + 0x010, + 0x010, + 0x004, + 0x004, + 0x010, + 0x170, + 0x090, + 0x004, + 0x05c, + 0x024, + ], + // 80x80 + [ + 0x050, + 0x050, + 0x048, + 0x048, + 0x014, + 0x014, + 0x012, + 0x012, + 0x004, + 0x004, + 0x010, + 0x1c8, + 0x0c0, + 0x004, + 0x072, + 0x030, + ], + // 88x88 + [ + 0x058, + 0x058, + 0x050, + 0x050, + 0x016, + 0x016, + 0x014, + 0x014, + 0x004, + 0x004, + 0x010, + 0x240, + 0x0e0, + 0x004, + 0x090, + 0x038, + ], + // 96x96 + [ + 0x060, + 0x060, + 0x058, + 0x058, + 0x018, + 0x018, + 0x016, + 0x016, + 0x004, + 0x004, + 0x010, + 0x2b8, + 0x110, + 0x004, + 0x0ae, + 0x044, + ], + // 104x104 + [ + 0x068, + 0x068, + 0x060, + 0x060, + 0x01a, + 0x01a, + 0x018, + 0x018, + 0x004, + 0x004, + 0x010, + 0x330, + 0x150, + 0x006, + 0x088, + 0x038, + ], + // 120x120 + [ + 0x078, + 0x078, + 0x06c, + 0x06c, + 0x014, + 0x014, + 0x012, + 0x012, + 0x006, + 0x006, + 0x024, + 0x41a, + 0x198, + 0x006, + 0x0af, + 0x044, + ], + // 132x132 + [ + 0x084, + 0x084, + 0x078, + 0x078, + 0x016, + 0x016, + 0x014, + 0x014, + 0x006, + 0x006, + 0x024, + 0x518, + 0x1f0, + 0x008, + 0x0a3, + 0x03e, + ], + // 144x144 + [ + 0x090, + 0x090, + 0x084, + 0x084, + 0x018, + 0x018, + 0x016, + 0x016, + 0x006, + 0x006, + 0x024, + 0x618, + 0x26c, + 0x00a, + 0x09c, + 0x03e, + ], + ], + 'R' => [ + // rectangular form + // 8x18 + [ + 0x008, + 0x012, + 0x006, + 0x010, + 0x008, + 0x012, + 0x006, + 0x010, + 0x001, + 0x001, + 0x001, + 0x005, + 0x007, + 0x001, + 0x005, + 0x007, + ], + // 8x32 + [ + 0x008, + 0x020, + 0x006, + 0x01c, + 0x008, + 0x010, + 0x006, + 0x00e, + 0x001, + 0x002, + 0x002, + 0x00a, + 0x00b, + 0x001, + 0x00a, + 0x00b, + ], + // 12x26 + [ + 0x00c, + 0x01a, + 0x00a, + 0x018, + 0x00c, + 0x01a, + 0x00a, + 0x018, + 0x001, + 0x001, + 0x001, + 0x010, + 0x00e, + 0x001, + 0x010, + 0x00e, + ], + // 12x36 + [ + 0x00c, + 0x024, + 0x00a, + 0x020, + 0x00c, + 0x012, + 0x00a, + 0x010, + 0x001, + 0x002, + 0x002, + 0x00c, + 0x012, + 0x001, + 0x00c, + 0x012, + ], + // 16x36 + [ + 0x010, + 0x024, + 0x00e, + 0x020, + 0x010, + 0x012, + 0x00e, + 0x010, + 0x001, + 0x002, + 0x002, + 0x020, + 0x018, + 0x001, + 0x020, + 0x018, + ], + // 16x48 + [ + 0x010, + 0x030, + 0x00e, + 0x02c, + 0x010, + 0x018, + 0x00e, + 0x016, + 0x001, + 0x002, + 0x002, + 0x031, + 0x01c, + 0x001, + 0x031, + 0x01c, + ], + ], + ]; + + /** + * Map encodation modes whit character sets. + * + * @var array + */ + public const CHSET_ID = [ + self::ENC_C40 => 'C40', + self::ENC_TXT => 'TXT', + self::ENC_X12 => 'X12', + ]; + + /** + * Basic set of characters for each encodation mode. + * + * @var array> + */ + public const CHSET = [ + 'C40' => [ + // Basic set for C40 + 'S1' => 0x00, + 'S2' => 0x01, + 'S3' => 0x02, + 0x20 => 0x03, + 0x30 => 0x04, + 0x31 => 0x05, + 0x32 => 0x06, + 0x33 => 0x07, + 0x34 => 0x08, + 0x35 => 0x09, + 0x36 => 0x0a, + 0x37 => 0x0b, + 0x38 => 0x0c, + 0x39 => 0x0d, + 0x41 => 0x0e, + 0x42 => 0x0f, + 0x43 => 0x10, + 0x44 => 0x11, + 0x45 => 0x12, + 0x46 => 0x13, + 0x47 => 0x14, + 0x48 => 0x15, + 0x49 => 0x16, + 0x4a => 0x17, + 0x4b => 0x18, + 0x4c => 0x19, + 0x4d => 0x1a, + 0x4e => 0x1b, + 0x4f => 0x1c, + 0x50 => 0x1d, + 0x51 => 0x1e, + 0x52 => 0x1f, + 0x53 => 0x20, + 0x54 => 0x21, + 0x55 => 0x22, + 0x56 => 0x23, + 0x57 => 0x24, + 0x58 => 0x25, + 0x59 => 0x26, + 0x5a => 0x27, + ], + 'TXT' => [ + // Basic set for TEXT + 'S1' => 0x00, + 'S2' => 0x01, + 'S3' => 0x02, + 0x20 => 0x03, + 0x30 => 0x04, + 0x31 => 0x05, + 0x32 => 0x06, + 0x33 => 0x07, + 0x34 => 0x08, + 0x35 => 0x09, + 0x36 => 0x0a, + 0x37 => 0x0b, + 0x38 => 0x0c, + 0x39 => 0x0d, + 0x61 => 0x0e, + 0x62 => 0x0f, + 0x63 => 0x10, + 0x64 => 0x11, + 0x65 => 0x12, + 0x66 => 0x13, + 0x67 => 0x14, + 0x68 => 0x15, + 0x69 => 0x16, + 0x6a => 0x17, + 0x6b => 0x18, + 0x6c => 0x19, + 0x6d => 0x1a, + 0x6e => 0x1b, + 0x6f => 0x1c, + 0x70 => 0x1d, + 0x71 => 0x1e, + 0x72 => 0x1f, + 0x73 => 0x20, + 0x74 => 0x21, + 0x75 => 0x22, + 0x76 => 0x23, + 0x77 => 0x24, + 0x78 => 0x25, + 0x79 => 0x26, + 0x7a => 0x27, + ], + 'SH1' => [ + // Shift 1 set + 0x00 => 0x00, + 0x01 => 0x01, + 0x02 => 0x02, + 0x03 => 0x03, + 0x04 => 0x04, + 0x05 => 0x05, + 0x06 => 0x06, + 0x07 => 0x07, + 0x08 => 0x08, + 0x09 => 0x09, + 0x0a => 0x0a, + 0x0b => 0x0b, + 0x0c => 0x0c, + 0x0d => 0x0d, + 0x0e => 0x0e, + 0x0f => 0x0f, + 0x10 => 0x10, + 0x11 => 0x11, + 0x12 => 0x12, + 0x13 => 0x13, + 0x14 => 0x14, + 0x15 => 0x15, + 0x16 => 0x16, + 0x17 => 0x17, + 0x18 => 0x18, + 0x19 => 0x19, + 0x1a => 0x1a, + 0x1b => 0x1b, + 0x1c => 0x1c, + 0x1d => 0x1d, + 0x1e => 0x1e, + 0x1f => 0x1f, + ], + 'SH2' => [ + // Shift 2 set + 0x21 => 0x00, + 0x22 => 0x01, + 0x23 => 0x02, + 0x24 => 0x03, + 0x25 => 0x04, + 0x26 => 0x05, + 0x27 => 0x06, + 0x28 => 0x07, + 0x29 => 0x08, + 0x2a => 0x09, + 0x2b => 0x0a, + 0x2c => 0x0b, + 0x2d => 0x0c, + 0x2e => 0x0d, + 0x2f => 0x0e, + 0x3a => 0x0f, + 0x3b => 0x10, + 0x3c => 0x11, + 0x3d => 0x12, + 0x3e => 0x13, + 0x3f => 0x14, + 0x40 => 0x15, + 0x5b => 0x16, + 0x5c => 0x17, + 0x5d => 0x18, + 0x5e => 0x19, + 0x5f => 0x1a, + 'F1' => 0x1b, + 'US' => 0x1e, + ], + 'S3C' => [ + // Shift 3 set for C40 + 0x60 => 0x00, + 0x61 => 0x01, + 0x62 => 0x02, + 0x63 => 0x03, + 0x64 => 0x04, + 0x65 => 0x05, + 0x66 => 0x06, + 0x67 => 0x07, + 0x68 => 0x08, + 0x69 => 0x09, + 0x6a => 0x0a, + 0x6b => 0x0b, + 0x6c => 0x0c, + 0x6d => 0x0d, + 0x6e => 0x0e, + 0x6f => 0x0f, + 0x70 => 0x10, + 0x71 => 0x11, + 0x72 => 0x12, + 0x73 => 0x13, + 0x74 => 0x14, + 0x75 => 0x15, + 0x76 => 0x16, + 0x77 => 0x17, + 0x78 => 0x18, + 0x79 => 0x19, + 0x7a => 0x1a, + 0x7b => 0x1b, + 0x7c => 0x1c, + 0x7d => 0x1d, + 0x7e => 0x1e, + 0x7f => 0x1f, + ], + 'S3T' => [ + // Shift 3 set for TEXT + 0x60 => 0x00, + 0x41 => 0x01, + 0x42 => 0x02, + 0x43 => 0x03, + 0x44 => 0x04, + 0x45 => 0x05, + 0x46 => 0x06, + 0x47 => 0x07, + 0x48 => 0x08, + 0x49 => 0x09, + 0x4a => 0x0a, + 0x4b => 0x0b, + 0x4c => 0x0c, + 0x4d => 0x0d, + 0x4e => 0x0e, + 0x4f => 0x0f, + 0x50 => 0x10, + 0x51 => 0x11, + 0x52 => 0x12, + 0x53 => 0x13, + 0x54 => 0x14, + 0x55 => 0x15, + 0x56 => 0x16, + 0x57 => 0x17, + 0x58 => 0x18, + 0x59 => 0x19, + 0x5a => 0x1a, + 0x7b => 0x1b, + 0x7c => 0x1c, + 0x7d => 0x1d, + 0x7e => 0x1e, + 0x7f => 0x1f, + ], + 'X12' => [ + // Set for X12 + 0x0d => 0x00, + 0x2a => 0x01, + 0x3e => 0x02, + 0x20 => 0x03, + 0x30 => 0x04, + 0x31 => 0x05, + 0x32 => 0x06, + 0x33 => 0x07, + 0x34 => 0x08, + 0x35 => 0x09, + 0x36 => 0x0a, + 0x37 => 0x0b, + 0x38 => 0x0c, + 0x39 => 0x0d, + 0x41 => 0x0e, + 0x42 => 0x0f, + 0x43 => 0x10, + 0x44 => 0x11, + 0x45 => 0x12, + 0x46 => 0x13, + 0x47 => 0x14, + 0x48 => 0x15, + 0x49 => 0x16, + 0x4a => 0x17, + 0x4b => 0x18, + 0x4c => 0x19, + 0x4d => 0x1a, + 0x4e => 0x1b, + 0x4f => 0x1c, + 0x50 => 0x1d, + 0x51 => 0x1e, + 0x52 => 0x1f, + 0x53 => 0x20, + 0x54 => 0x21, + 0x55 => 0x22, + 0x56 => 0x23, + 0x57 => 0x24, + 0x58 => 0x25, + 0x59 => 0x26, + 0x5a => 0x27, + ], + ]; + + /** + * Get the required codewords padding size + * + * @param string $shape Shape. + * @param int $ncw Number of codewords. + * + * @return array{int, int, int, int, int, int, int, int, int, int, int, int, int, int, int, int} + * + * @throws BarcodeException in case of error + */ + public static function getPaddingSize(string $shape, int $ncw): array + { + foreach (Data::SYMBATTR[$shape] as $params) { + if ($params[11] >= $ncw) { + return $params; + } + } + + throw new BarcodeException('Unable to find the correct size'); + } +} diff --git a/vendor/tecnickcom/tc-lib-barcode/src/Type/Square/Datamatrix/Encode.php b/vendor/tecnickcom/tc-lib-barcode/src/Type/Square/Datamatrix/Encode.php new file mode 100644 index 0000000..bf97866 --- /dev/null +++ b/vendor/tecnickcom/tc-lib-barcode/src/Type/Square/Datamatrix/Encode.php @@ -0,0 +1,286 @@ + + * @copyright 2015-2024 Nicola Asuni - Tecnick.com LTD + * @license http://www.gnu.org/copyleft/lesser.html GNU-LGPL v3 (see LICENSE.TXT) + * @link https://github.com/tecnickcom/tc-lib-barcode + * + * This file is part of tc-lib-barcode software library. + */ + +namespace Com\Tecnick\Barcode\Type\Square\Datamatrix; + +/** + * Com\Tecnick\Barcode\Type\Square\Datamatrix\Encode + * + * Datamatrix Barcode type class + * DATAMATRIX (ISO/IEC 16022) + * + * @since 2015-02-21 + * @category Library + * @package Barcode + * @author Nicola Asuni + * @copyright 2015-2024 Nicola Asuni - Tecnick.com LTD + * @license http://www.gnu.org/copyleft/lesser.html GNU-LGPL v3 (see LICENSE.TXT) + * @link https://github.com/tecnickcom/tc-lib-barcode + */ +class Encode extends \Com\Tecnick\Barcode\Type\Square\Datamatrix\EncodeTxt +{ + /** + * Initialize a new encode object + * + * @param string $shape Datamatrix shape key (S=square, R=rectangular) + */ + public function __construct(string $shape = 'S') + { + $this->shape = $shape; + } + + /** + * Encode ASCII + * + * @param array $cdw Codewords array + * @param int $cdw_num Codewords number + * @param int $pos Current position + * @param int $data_length Data length + * @param string $data Data string + * @param int $enc Current encoding + */ + public function encodeASCII( + array &$cdw, + int &$cdw_num, + int &$pos, + int &$data_length, + string &$data, + int &$enc + ): void { + if ( + ($data_length > 1) + && ($pos < ($data_length - 1)) + && ( + $this->isCharMode(ord($data[$pos]), Data::ENC_ASCII_NUM) + && $this->isCharMode(ord($data[$pos + 1]), Data::ENC_ASCII_NUM) + ) + ) { + // 1. If the next data sequence is at least 2 consecutive digits, + // encode the next two digits as a double digit in ASCII mode. + $cdw[] = ((int) substr($data, $pos, 2) + 130); + ++$cdw_num; + $pos += 2; + } else { + // 2. If the look-ahead test (starting at step J) indicates another mode, switch to that mode. + $newenc = $this->lookAheadTest($data, $pos, $enc); + if ($newenc !== $enc) { + // switch to new encoding + $enc = $newenc; + $cdw[] = $this->getSwitchEncodingCodeword($enc); + ++$cdw_num; + } else { + // get new byte + $chr = ord($data[$pos]); + ++$pos; + if ($this->isCharMode($chr, Data::ENC_ASCII_EXT)) { + // 3. If the next data character is extended ASCII (greater than 127) + // encode it in ASCII mode first using the Upper Shift (value 235) character. + $cdw[] = 235; + $cdw[] = ($chr - 127); + $cdw_num += 2; + } else { + // 4. Otherwise process the next data character in ASCII encodation. + $cdw[] = ($chr + 1); + ++$cdw_num; + } + } + } + } + + /** + * Encode EDF4 + * + * @param int $epos Current position + * @param array $cdw Codewords array + * @param int $cdw_num Codewords number + * @param int $pos Current position + * @param int $data_length Data length + * @param int $field_length Field length + * @param int $enc Current encoding + * @param array $temp_cw Temporary codewords array + * + * @return bool true to break the loop + */ + public function encodeEDFfour( + int $epos, + array &$cdw, + int &$cdw_num, + int &$pos, + int &$data_length, + int &$field_length, + int &$enc, + array &$temp_cw + ): bool { + if (($epos === $data_length)) { + $enc = Data::ENC_ASCII; + $params = Data::getPaddingSize($this->shape, ($cdw_num + $field_length)); + if (($params[11] - $cdw_num) > 2) { + $cdw[] = $this->getSwitchEncodingCodeword($enc); + ++$cdw_num; + } + + return true; + } + + if ($field_length < 4) { + $enc = Data::ENC_ASCII; + $this->last_enc = $enc; + $params = Data::getPaddingSize($this->shape, ($cdw_num + $field_length + ($data_length - $epos))); + if (($params[11] - $cdw_num) > 2) { + // set unlatch character + $temp_cw[] = 0x1f; + ++$field_length; + // fill empty characters + for ($i = $field_length; $i < 4; ++$i) { + $temp_cw[] = 0; + } + } else { + return true; + } + } + + // encodes four data characters in three codewords + $cdw[] = (($temp_cw[0] & 0x3F) << 2) + (($temp_cw[1] & 0x30) >> 4); + ++$cdw_num; + if ($field_length > 1) { + $cdw[] = (($temp_cw[1] & 0x0F) << 4) + (($temp_cw[2] & 0x3C) >> 2); + ++$cdw_num; + } + + if ($field_length > 2) { + $cdw[] = (($temp_cw[2] & 0x03) << 6) + ($temp_cw[3] & 0x3F); + ++$cdw_num; + } + + $temp_cw = []; + $pos = $epos; + $field_length = 0; + if ($enc == Data::ENC_ASCII) { + return true; // exit from EDIFACT mode + } + + return false; + } + + /** + * Encode EDF + * + * @param array $cdw Codewords array + * @param int $cdw_num Codewords number + * @param int $pos Current position + * @param int $data_length Data length + * @param int $field_length Field length + * @param string $data Data string + * @param int $enc Current encoding + */ + public function encodeEDF( + array &$cdw, + int &$cdw_num, + int &$pos, + int &$data_length, + int &$field_length, + string &$data, + int &$enc + ): void { + // initialize temporary array with 0 length + $temp_cw = []; + $epos = $pos; + $field_length = 0; + do { + // 2. process the next character in EDIFACT encodation. + $chr = ord($data[$epos]); + if ($this->isCharMode($chr, Data::ENC_EDF)) { + ++$epos; + $temp_cw[] = $chr; + ++$field_length; + } + + if ( + (($field_length == 4) + || ($epos == $data_length) + || ! $this->isCharMode($chr, Data::ENC_EDF)) + && $this->encodeEDFfour( + $epos, + $cdw, + $cdw_num, + $pos, + $data_length, + $field_length, + $enc, + $temp_cw + ) + ) { + break; + } + } while ($epos < $data_length); + } + + /** + * Encode Base256 + * + * @param array $cdw Codewords array + * @param int $cdw_num Codewords number + * @param int $pos Current position + * @param int $data_length Data length + * @param int $field_length Field length + * @param string $data Data string + * @param int $enc Current encoding + */ + public function encodeBase256( + array &$cdw, + int &$cdw_num, + int &$pos, + int &$data_length, + int &$field_length, + string &$data, + int &$enc + ): void { + // initialize temporary array with 0 length + $temp_cw = []; + $field_length = 0; + while (($pos < $data_length) && ($field_length <= 1555)) { + $newenc = $this->lookAheadTest($data, $pos, $enc); + if ($newenc !== $enc) { + // 1. If the look-ahead test (starting at step J) + // indicates another mode, switch to that mode. + $enc = $newenc; + break; // exit from B256 mode + } else { + // 2. Otherwise, process the next character in Base 256 encodation. + $chr = ord($data[$pos]); + ++$pos; + $temp_cw[] = $chr; + ++$field_length; + } + } + + // set field length + if ($field_length <= 249) { + $cdw[] = $this->get255StateCodeword($field_length, ($cdw_num + 1)); + ++$cdw_num; + } else { + $cdw[] = $this->get255StateCodeword(((int) floor($field_length / 250) + 249), ($cdw_num + 1)); + $cdw[] = $this->get255StateCodeword(($field_length % 250), ($cdw_num + 2)); + $cdw_num += 2; + } + + // add B256 field + foreach ($temp_cw as $cht) { + $cdw[] = $this->get255StateCodeword($cht, ($cdw_num + 1)); + ++$cdw_num; + } + } +} diff --git a/vendor/tecnickcom/tc-lib-barcode/src/Type/Square/Datamatrix/EncodeTxt.php b/vendor/tecnickcom/tc-lib-barcode/src/Type/Square/Datamatrix/EncodeTxt.php new file mode 100644 index 0000000..83eea8d --- /dev/null +++ b/vendor/tecnickcom/tc-lib-barcode/src/Type/Square/Datamatrix/EncodeTxt.php @@ -0,0 +1,240 @@ + + * @copyright 2010-2024 Nicola Asuni - Tecnick.com LTD + * @license http://www.gnu.org/copyleft/lesser.html GNU-LGPL v3 (see LICENSE.TXT) + * @link https://github.com/tecnickcom/tc-lib-barcode + * + * This file is part of tc-lib-barcode software library. + */ + +namespace Com\Tecnick\Barcode\Type\Square\Datamatrix; + +use Com\Tecnick\Barcode\Exception as BarcodeException; + +/** + * Com\Tecnick\Barcode\Type\Square\Datamatrix\Encodetxt + * + * Datamatrix Barcode type class + * DATAMATRIX (ISO/IEC 16022) + * + * @since 2015-02-21 + * @category Library + * @package Barcode + * @author Nicola Asuni + * @copyright 2010-2024 Nicola Asuni - Tecnick.com LTD + * @license http://www.gnu.org/copyleft/lesser.html GNU-LGPL v3 (see LICENSE.TXT) + * @link https://github.com/tecnickcom/tc-lib-barcode + */ +class EncodeTxt extends \Com\Tecnick\Barcode\Type\Square\Datamatrix\Steps +{ + /** + * Encode TXTC40 shift + * + * @param int $chr Character code + * @param int $enc Current encoding + * @param array $temp_cw Temporary codewords array + * @param int $ptr Pointer + */ + public function encodeTXTC40shift( + int &$chr, + int &$enc, + array &$temp_cw, + int &$ptr + ): void { + if (isset(Data::CHSET['SH1'][$chr])) { + $temp_cw[] = 0; // shift 1 + $shiftset = Data::CHSET['SH1']; + } elseif (isset(Data::CHSET['SH2'][$chr])) { + $temp_cw[] = 1; // shift 2 + $shiftset = Data::CHSET['SH2']; + } elseif (($enc == Data::ENC_C40) && isset(Data::CHSET['S3C'][$chr])) { + $temp_cw[] = 2; // shift 3 + $shiftset = Data::CHSET['S3C']; + } elseif (($enc == Data::ENC_TXT) && isset(Data::CHSET['S3T'][$chr])) { + $temp_cw[] = 2; // shift 3 + $shiftset = Data::CHSET['S3T']; + } else { + throw new BarcodeException('Error'); + } + + $temp_cw[] = $shiftset[$chr]; + $ptr += 2; + } + + /** + * Encode TXTC40 + * + * @param string $data Data string + * @param int $enc Current encoding + * @param array $temp_cw Temporary codewords array + * @param int $ptr Pointer + * @param int $epos End position + * @param array $charset Charset array + * + * @return int Curent character code + */ + public function encodeTXTC40( + string &$data, + int &$enc, + array &$temp_cw, + int &$ptr, + int &$epos, + array &$charset + ): int { + // 2. process the next character in C40 encodation. + $chr = ord($data[$epos]); + ++$epos; + // check for extended character + if (($chr & 0x80) !== 0) { + if ($enc == Data::ENC_X12) { + throw new BarcodeException('TXTC40 Error'); + } + + $chr &= 0x7f; + $temp_cw[] = 1; // shift 2 + $temp_cw[] = 30; // upper shift + $ptr += 2; + } + + if (isset($charset[$chr])) { + $temp_cw[] = $charset[$chr]; + ++$ptr; + } else { + $this->encodeTXTC40shift($chr, $enc, $temp_cw, $ptr); + } + + return $chr; + } + + /** + * Encode TXTC40 last + * The following rules apply when only one or two symbol characters remain in the symbol + * before the start of the error correction codewords. + * + * @param int $chr Character code + * @param array $cdw Codewords array + * @param int $cdw_num Codewords number + * @param int $enc Current encoding + * @param array $temp_cw Temporary codewords array + * @param int $ptr Pointer + * @param int $epos End position + */ + public function encodeTXTC40last( + int $chr, + array &$cdw, + int &$cdw_num, + int &$enc, + array &$temp_cw, + int &$ptr, + int &$epos + ): void { + // get remaining number of data symbols + $cdwr = ($this->getMaxDataCodewords($cdw_num + $ptr) - $cdw_num); + if (($cdwr == 1) && ($ptr == 1)) { + // d. If one symbol character remains and one + // C40 value (data character) remains to be encoded + $cdw[] = ($chr + 1); + ++$cdw_num; + $enc = Data::ENC_ASCII; + $this->last_enc = $enc; + } elseif (($cdwr == 2) && ($ptr == 1)) { + // c. If two symbol characters remain and only one + // C40 value (data character) remains to be encoded + $cdw[] = 254; + $cdw[] = ($chr + 1); + $cdw_num += 2; + $enc = Data::ENC_ASCII; + $this->last_enc = $enc; + } elseif (($cdwr == 2) && ($ptr == 2)) { + // b. If two symbol characters remain and two C40 values remain to be encoded + $ch1 = array_shift($temp_cw); + $ch2 = array_shift($temp_cw); + $ptr -= 2; + $tmp = ((1600 * $ch1) + (40 * $ch2) + 1); + $cdw[] = ($tmp >> 8); + $cdw[] = ($tmp % 256); + $cdw_num += 2; + $enc = Data::ENC_ASCII; + $this->last_enc = $enc; + } elseif ($enc != Data::ENC_ASCII) { + // switch to ASCII encoding + $enc = Data::ENC_ASCII; + $this->last_enc = $enc; + $cdw[] = $this->getSwitchEncodingCodeword($enc); + ++$cdw_num; + $epos -= $ptr; + } + } + + /** + * Encode TXT + * + * @param array $cdw Codewords array + * @param int $cdw_num Codewords number + * @param int $pos Current position + * @param int $data_length Data length + * @param string $data Data string + * @param int $enc Current encoding + */ + public function encodeTXT( + array &$cdw, + int &$cdw_num, + int &$pos, + int &$data_length, + string &$data, + int &$enc + ): void { + $temp_cw = []; + $ptr = 0; + $epos = $pos; + // get charset ID + $set_id = Data::CHSET_ID[$enc]; + // get basic charset for current encoding + $charset = Data::CHSET[$set_id]; + do { + $chr = $this->encodeTXTC40($data, $enc, $temp_cw, $ptr, $epos, $charset); + if ($ptr >= 3) { + $ch1 = array_shift($temp_cw); + $ch2 = array_shift($temp_cw); + $ch3 = array_shift($temp_cw); + $ptr -= 3; + $tmp = ((1600 * $ch1) + (40 * $ch2) + $ch3 + 1); + $cdw[] = ($tmp >> 8); + $cdw[] = ($tmp % 256); + $cdw_num += 2; + $pos = $epos; + // 1. If the C40 encoding is at the point of starting a new double symbol character and + // if the look-ahead test (starting at step J) indicates another mode, switch to that mode. + $newenc = $this->lookAheadTest($data, $pos, $enc); + if ($newenc != $enc) { + // switch to new encoding + $enc = $newenc; + if ($enc != Data::ENC_ASCII) { + // set unlatch character + $cdw[] = $this->getSwitchEncodingCodeword(Data::ENC_ASCII); + ++$cdw_num; + } + + $cdw[] = $this->getSwitchEncodingCodeword($enc); + ++$cdw_num; + $pos -= $ptr; + $ptr = 0; + break; + } + } + } while (($ptr > 0) && ($epos < $data_length)); + + // process last data (if any) + if ($ptr > 0) { + $this->encodeTXTC40last($chr, $cdw, $cdw_num, $enc, $temp_cw, $ptr, $epos); + $pos = $epos; + } + } +} diff --git a/vendor/tecnickcom/tc-lib-barcode/src/Type/Square/Datamatrix/ErrorCorrection.php b/vendor/tecnickcom/tc-lib-barcode/src/Type/Square/Datamatrix/ErrorCorrection.php new file mode 100644 index 0000000..d0bad19 --- /dev/null +++ b/vendor/tecnickcom/tc-lib-barcode/src/Type/Square/Datamatrix/ErrorCorrection.php @@ -0,0 +1,158 @@ + + * @copyright 2010-2024 Nicola Asuni - Tecnick.com LTD + * @license http://www.gnu.org/copyleft/lesser.html GNU-LGPL v3 (see LICENSE.TXT) + * @link https://github.com/tecnickcom/tc-lib-barcode + * + * This file is part of tc-lib-barcode software library. + */ + +namespace Com\Tecnick\Barcode\Type\Square\Datamatrix; + +/** + * Com\Tecnick\Barcode\Type\Square\Datamatrix\ErrorCorrection + * + * Error correction methods and other utilities for Datamatrix Barcode type class + * + * @since 2015-02-21 + * @category Library + * @package Barcode + * @author Nicola Asuni + * @copyright 2010-2024 Nicola Asuni - Tecnick.com LTD + * @license http://www.gnu.org/copyleft/lesser.html GNU-LGPL v3 (see LICENSE.TXT) + * @link https://github.com/tecnickcom/tc-lib-barcode + */ +class ErrorCorrection +{ + /** + * Product of two numbers in a Power-of-Two Galois Field + * + * @param int $numa First number to multiply. + * @param int $numb Second number to multiply. + * @param array $log Log table. + * @param array $alog Anti-Log table. + * @param int $ngf Number of Factors of the Reed-Solomon polynomial. + * + * @return int product + */ + protected function getGFProduct( + int $numa, + int $numb, + array $log, + array $alog, + int $ngf + ): int { + if (($numa == 0) || ($numb == 0)) { + return 0; + } + + return ($alog[($log[$numa] + $log[$numb]) % ($ngf - 1)]); + } + + /** + * Add error correction codewords to data codewords array (ANNEX E). + * + * @param array $wdc Array of datacodewords. + * @param int $nbk Number of blocks. + * @param int $ncw Number of data codewords per block. + * @param int $ncc Number of correction codewords per block. + * @param int $ngf Number of fields on log/antilog table (power of 2). + * @param int $vpp The value of its prime modulus polynomial (301 for ECC200). + * + * @return array data codewords + error codewords + */ + public function getErrorCorrection( + array $wdc, + int $nbk, + int $ncw, + int $ncc, + int $ngf = 256, + int $vpp = 301 + ): array { + // generate the log ($log) and antilog ($alog) tables + $log = [0]; + $alog = [1]; + $this->genLogs($log, $alog, $ngf, $vpp); + + // generate the polynomial coefficients (c) + $plc = array_fill(0, ($ncc + 1), 0); + $plc[0] = 1; + for ($i = 1; $i <= $ncc; ++$i) { + $plc[$i] = $plc[($i - 1)]; + for ($j = ($i - 1); $j >= 1; --$j) { + $plc[$j] = $plc[($j - 1)] ^ $this->getGFProduct($plc[$j], $alog[$i], $log, $alog, $ngf); + } + + $plc[0] = $this->getGFProduct($plc[0], $alog[$i], $log, $alog, $ngf); + } + + ksort($plc); + + // total number of data codewords + $num_wd = ($nbk * $ncw); + // total number of error codewords + $num_we = ($nbk * $ncc); + // for each block + for ($b = 0; $b < $nbk; ++$b) { + // create interleaved data block + $block = []; + for ($n = $b; $n < $num_wd; $n += $nbk) { + $block[] = $wdc[$n]; + } + + // initialize error codewords + $wec = array_fill(0, ($ncc + 1), 0); + // calculate error correction codewords for this block + for ($i = 0; $i < $ncw; ++$i) { + $ker = ($wec[0] ^ $block[$i]); + for ($j = 0; $j < $ncc; ++$j) { + $wec[$j] = ($wec[($j + 1)] ^ $this->getGFProduct($ker, $plc[($ncc - $j - 1)], $log, $alog, $ngf)); + } + } + + // add error codewords at the end of data codewords + $j = 0; + for ($i = $b; $i < $num_we; $i += $nbk) { + $wdc[($num_wd + $i)] = $wec[$j]; + ++$j; + } + } + + // reorder codewords + ksort($wdc); + return $wdc; + } + + /** + * Generate the log ($log) and antilog ($alog) tables + * + * @param array $log Log table + * @param array $alog Anti-Log table + * @param int $ngf Number of fields on log/antilog table (power of 2). + * @param int $vpp The value of its prime modulus polynomial (301 for ECC200). + */ + protected function genLogs( + array &$log, + array &$alog, + int $ngf, + int $vpp + ): void { + for ($i = 1; $i < $ngf; ++$i) { + $alog[$i] = ($alog[($i - 1)] * 2); + if ($alog[$i] >= $ngf) { + $alog[$i] ^= $vpp; + } + + $log[$alog[$i]] = $i; + } + + ksort($log); + } +} diff --git a/vendor/tecnickcom/tc-lib-barcode/src/Type/Square/Datamatrix/Modes.php b/vendor/tecnickcom/tc-lib-barcode/src/Type/Square/Datamatrix/Modes.php new file mode 100644 index 0000000..a659089 --- /dev/null +++ b/vendor/tecnickcom/tc-lib-barcode/src/Type/Square/Datamatrix/Modes.php @@ -0,0 +1,224 @@ + + * @copyright 2010-2024 Nicola Asuni - Tecnick.com LTD + * @license http://www.gnu.org/copyleft/lesser.html GNU-LGPL v3 (see LICENSE.TXT) + * @link https://github.com/tecnickcom/tc-lib-barcode + * + * This file is part of tc-lib-barcode software library. + */ + +namespace Com\Tecnick\Barcode\Type\Square\Datamatrix; + +/** + * Com\Tecnick\Barcode\Type\Square\Datamatrix\Modes + * + * Modes for Datamatrix Barcode type class + * + * @since 2015-02-21 + * @category Library + * @package Barcode + * @author Nicola Asuni + * @copyright 2010-2024 Nicola Asuni - Tecnick.com LTD + * @license http://www.gnu.org/copyleft/lesser.html GNU-LGPL v3 (see LICENSE.TXT) + * @link https://github.com/tecnickcom/tc-lib-barcode + */ +abstract class Modes extends \Com\Tecnick\Barcode\Type\Square\Datamatrix\Placement +{ + /** + * Store last used encoding for data codewords. + */ + public int $last_enc; + + /** + * Datamatrix shape key (S=square, R=rectangular) + */ + public string $shape; + + /** + * Return the 253-state codeword + * + * @param int $cdwpad Pad codeword. + * @param int $cdwpos Number of data codewords from the beginning of encoded data. + */ + public function get253StateCodeword(int $cdwpad, int $cdwpos): int + { + $pad = ($cdwpad + (((149 * $cdwpos) % 253) + 1)); + if ($pad > 254) { + $pad -= 254; + } + + return $pad; + } + + /** + * Return the 255-state codeword + * + * @param int $cdwpad Pad codeword. + * @param int $cdwpos Number of data codewords from the beginning of encoded data. + * + * @return int pad codeword + */ + protected function get255StateCodeword(int $cdwpad, int $cdwpos): int + { + $pad = ($cdwpad + (((149 * $cdwpos) % 255) + 1)); + if ($pad > 255) { + $pad -= 256; + } + + return $pad; + } + + /** + * Returns true if the char belongs to the selected mode + * + * @param int $chr Character (byte) to check. + * @param int $mode Current encoding mode. + * + * @return bool true if the char is of the selected mode. + */ + protected function isCharMode(int $chr, int $mode): bool + { + $ret = match ($mode) { + //Data::ENC_ASCII => 'isASCIIMode', + Data::ENC_C40 => $this->isC40Mode($chr), + Data::ENC_TXT => $this->isTXTMode($chr), + Data::ENC_X12 => $this->isX12Mode($chr), + Data::ENC_EDF => $this->isEDFMode($chr), + Data::ENC_BASE256 => $this->isBASE256Mode($chr), + Data::ENC_ASCII_EXT => $this->isASCIIEXTMode($chr), + Data::ENC_ASCII_NUM => $this->isASCIINUMMode($chr), + default => false, + }; + + return $ret; + } + + ///** + // * Tell if char is ASCII character 0 to 127 + // * + // * @param int $chr Character (byte) to check. + // * + // * @return bool + // */ + //protected function isASCIIMode(int $chr): bool + //{ + // return (($chr >= 0) && ($chr <= 127)); + //} + /** + * Tell if char is Upper-case alphanumeric + * + * @param int $chr Character (byte) to check. + */ + protected function isC40Mode(int $chr): bool + { + return (($chr == 32) || (($chr >= 48) && ($chr <= 57)) || (($chr >= 65) && ($chr <= 90))); + } + + /** + * Tell if char is Lower-case alphanumeric + * + * @param int $chr Character (byte) to check. + */ + protected function isTXTMode(int $chr): bool + { + return (($chr == 32) || (($chr >= 48) && ($chr <= 57)) || (($chr >= 97) && ($chr <= 122))); + } + + /** + * Tell if char is ANSI X12 + * + * @param int $chr Character (byte) to check. + */ + protected function isX12Mode(int $chr): bool + { + return (($chr == 13) || ($chr == 42) || ($chr == 62)); + } + + /** + * Tell if char is ASCII character 32 to 94 + * + * @param int $chr Character (byte) to check. + */ + protected function isEDFMode(int $chr): bool + { + return (($chr >= 32) && ($chr <= 94)); + } + + /** + * Tell if char is Function character (FNC1, Structured Append, Reader Program, or Code Page) + * + * @param int $chr Character (byte) to check. + */ + protected function isBASE256Mode(int $chr): bool + { + return (($chr == 232) || ($chr == 233) || ($chr == 234) || ($chr == 241)); + } + + /** + * Tell if char is ASCII character 128 to 255 + * + * @param int $chr Character (byte) to check. + */ + protected function isASCIIEXTMode(int $chr): bool + { + return (($chr >= 128) && ($chr <= 255)); + } + + /** + * Tell if char is ASCII digits + * + * @param int $chr Character (byte) to check. + */ + protected function isASCIINUMMode(int $chr): bool + { + return (($chr >= 48) && ($chr <= 57)); + } + + /** + * Choose the minimum matrix size and return the max number of data codewords. + * + * @param int $numcw Number of current codewords. + * + * @return int number of data codewords in matrix + */ + protected function getMaxDataCodewords(int $numcw): int + { + $mdc = 0; + foreach (Data::SYMBATTR[$this->shape] as $matrix) { + if ($matrix[11] >= $numcw) { + $mdc = $matrix[11]; + break; + } + } + + return $mdc; + } + + /** + * Get the switching codeword to a new encoding mode (latch codeword) + * + * @param int $mode New encoding mode. + * + * @return int Switch codeword. + */ + public function getSwitchEncodingCodeword(int $mode): int + { + $cdw = Data::SWITCHCDW[$mode]; + if ($cdw != 254) { + return $cdw; + } + + if ($this->last_enc != Data::ENC_EDF) { + return $cdw; + } + + return 124; + } +} diff --git a/vendor/tecnickcom/tc-lib-barcode/src/Type/Square/Datamatrix/Placement.php b/vendor/tecnickcom/tc-lib-barcode/src/Type/Square/Datamatrix/Placement.php new file mode 100644 index 0000000..1c975a4 --- /dev/null +++ b/vendor/tecnickcom/tc-lib-barcode/src/Type/Square/Datamatrix/Placement.php @@ -0,0 +1,362 @@ + + * @copyright 2010-2024 Nicola Asuni - Tecnick.com LTD + * @license http://www.gnu.org/copyleft/lesser.html GNU-LGPL v3 (see LICENSE.TXT) + * @link https://github.com/tecnickcom/tc-lib-barcode + * + * This file is part of tc-lib-barcode software library. + */ + +namespace Com\Tecnick\Barcode\Type\Square\Datamatrix; + +/** + * Com\Tecnick\Barcode\Type\Square\Datamatrix\Placement + * + * Placement methods for Datamatrix Barcode type class + * + * @since 2015-02-21 + * @category Library + * @package Barcode + * @author Nicola Asuni + * @copyright 2010-2024 Nicola Asuni - Tecnick.com LTD + * @license http://www.gnu.org/copyleft/lesser.html GNU-LGPL v3 (see LICENSE.TXT) + * @link https://github.com/tecnickcom/tc-lib-barcode + */ +abstract class Placement +{ + /** + * Places "chr+bit" with appropriate wrapping within array[]. + * (Annex F - ECC 200 symbol character placement) + * + * @param array $marr Array of symbols. + * @param int $nrow Number of rows. + * @param int $ncol Number of columns. + * @param int $row Row number. + * @param int $col Column number. + * @param int $chr Char byte. + * @param int $bit Bit. + * + * @return array + */ + protected function placeModule( + array $marr, + int $nrow, + int $ncol, + int $row, + int $col, + int $chr, + int $bit + ): array { + if ($row < 0) { + $row += $nrow; + $col += (4 - (($nrow + 4) % 8)); + } + + if ($col < 0) { + $col += $ncol; + $row += (4 - (($ncol + 4) % 8)); + } + + $marr[(($row * $ncol) + $col)] = ((10 * $chr) + $bit); + return $marr; + } + + /** + * Places the 8 bits of a utah-shaped symbol character. + * (Annex F - ECC 200 symbol character placement) + * + * @param array $marr Array of symbols. + * @param int $nrow Number of rows. + * @param int $ncol Number of columns. + * @param int $row Row number. + * @param int $col Column number. + * @param int $chr Char byte. + * + * @return array + */ + protected function placeUtah( + array $marr, + int $nrow, + int $ncol, + int $row, + int $col, + int $chr + ): array { + $marr = $this->placeModule($marr, $nrow, $ncol, $row - 2, $col - 2, $chr, 1); + $marr = $this->placeModule($marr, $nrow, $ncol, $row - 2, $col - 1, $chr, 2); + $marr = $this->placeModule($marr, $nrow, $ncol, $row - 1, $col - 2, $chr, 3); + $marr = $this->placeModule($marr, $nrow, $ncol, $row - 1, $col - 1, $chr, 4); + $marr = $this->placeModule($marr, $nrow, $ncol, $row - 1, $col, $chr, 5); + $marr = $this->placeModule($marr, $nrow, $ncol, $row, $col - 2, $chr, 6); + $marr = $this->placeModule($marr, $nrow, $ncol, $row, $col - 1, $chr, 7); + return $this->placeModule($marr, $nrow, $ncol, $row, $col, $chr, 8); + } + + /** + * Places the 8 bits of the first special corner case. + * (Annex F - ECC 200 symbol character placement) + * + * @param array $marr Array of symbols + * @param int $nrow Number of rows + * @param int $ncol Number of columns + * @param int $chr Char byte + * @param int $row Current row + * @param int $col Current column + * + * @return array + */ + protected function placeCornerA( + array $marr, + int $nrow, + int $ncol, + int &$chr, + int $row, + int $col + ): array { + if (($row !== $nrow) || ($col != 0)) { + return $marr; + } + + $marr = $this->placeModule($marr, $nrow, $ncol, $nrow - 1, 0, $chr, 1); + $marr = $this->placeModule($marr, $nrow, $ncol, $nrow - 1, 1, $chr, 2); + $marr = $this->placeModule($marr, $nrow, $ncol, $nrow - 1, 2, $chr, 3); + $marr = $this->placeModule($marr, $nrow, $ncol, 0, $ncol - 2, $chr, 4); + $marr = $this->placeModule($marr, $nrow, $ncol, 0, $ncol - 1, $chr, 5); + $marr = $this->placeModule($marr, $nrow, $ncol, 1, $ncol - 1, $chr, 6); + $marr = $this->placeModule($marr, $nrow, $ncol, 2, $ncol - 1, $chr, 7); + $marr = $this->placeModule($marr, $nrow, $ncol, 3, $ncol - 1, $chr, 8); + ++$chr; + return $marr; + } + + /** + * Places the 8 bits of the second special corner case. + * (Annex F - ECC 200 symbol character placement) + * + * @param array $marr Array of symbols + * @param int $nrow Number of rows + * @param int $ncol Number of columns + * @param int $chr Char byte + * @param int $row Current row + * @param int $col Current column + * + * @return array + */ + protected function placeCornerB( + array $marr, + int $nrow, + int $ncol, + int &$chr, + int $row, + int $col + ): array { + if (($row !== $nrow - 2) || ($col != 0) || (($ncol % 4) == 0)) { + return $marr; + } + + $marr = $this->placeModule($marr, $nrow, $ncol, $nrow - 3, 0, $chr, 1); + $marr = $this->placeModule($marr, $nrow, $ncol, $nrow - 2, 0, $chr, 2); + $marr = $this->placeModule($marr, $nrow, $ncol, $nrow - 1, 0, $chr, 3); + $marr = $this->placeModule($marr, $nrow, $ncol, 0, $ncol - 4, $chr, 4); + $marr = $this->placeModule($marr, $nrow, $ncol, 0, $ncol - 3, $chr, 5); + $marr = $this->placeModule($marr, $nrow, $ncol, 0, $ncol - 2, $chr, 6); + $marr = $this->placeModule($marr, $nrow, $ncol, 0, $ncol - 1, $chr, 7); + $marr = $this->placeModule($marr, $nrow, $ncol, 1, $ncol - 1, $chr, 8); + ++$chr; + return $marr; + } + + /** + * Places the 8 bits of the third special corner case. + * (Annex F - ECC 200 symbol character placement) + * + * @param array $marr Array of symbols + * @param int $nrow Number of rows + * @param int $ncol Number of columns + * @param int $chr Char byte + * @param int $row Current row + * @param int $col Current column + * + * @return array + */ + protected function placeCornerC( + array $marr, + int $nrow, + int $ncol, + int &$chr, + int $row, + int $col + ): array { + if (($row !== $nrow - 2) || ($col != 0) || ($ncol % 8 != 4)) { + return $marr; + } + + $marr = $this->placeModule($marr, $nrow, $ncol, $nrow - 3, 0, $chr, 1); + $marr = $this->placeModule($marr, $nrow, $ncol, $nrow - 2, 0, $chr, 2); + $marr = $this->placeModule($marr, $nrow, $ncol, $nrow - 1, 0, $chr, 3); + $marr = $this->placeModule($marr, $nrow, $ncol, 0, $ncol - 2, $chr, 4); + $marr = $this->placeModule($marr, $nrow, $ncol, 0, $ncol - 1, $chr, 5); + $marr = $this->placeModule($marr, $nrow, $ncol, 1, $ncol - 1, $chr, 6); + $marr = $this->placeModule($marr, $nrow, $ncol, 2, $ncol - 1, $chr, 7); + $marr = $this->placeModule($marr, $nrow, $ncol, 3, $ncol - 1, $chr, 8); + ++$chr; + return $marr; + } + + /** + * Places the 8 bits of the fourth special corner case. + * (Annex F - ECC 200 symbol character placement) + * + * @param array $marr Array of symbols + * @param int $nrow Number of rows + * @param int $ncol Number of columns + * @param int $chr Char byte + * @param int $row Current row + * @param int $col Current column + * + * @return array + */ + protected function placeCornerD( + array $marr, + int $nrow, + int $ncol, + int &$chr, + int $row, + int $col + ): array { + if (($row !== $nrow + 4) || ($col != 2) || ($ncol % 8)) { + return $marr; + } + + $marr = $this->placeModule($marr, $nrow, $ncol, $nrow - 1, 0, $chr, 1); + $marr = $this->placeModule($marr, $nrow, $ncol, $nrow - 1, $ncol - 1, $chr, 2); + $marr = $this->placeModule($marr, $nrow, $ncol, 0, $ncol - 3, $chr, 3); + $marr = $this->placeModule($marr, $nrow, $ncol, 0, $ncol - 2, $chr, 4); + $marr = $this->placeModule($marr, $nrow, $ncol, 0, $ncol - 1, $chr, 5); + $marr = $this->placeModule($marr, $nrow, $ncol, 1, $ncol - 3, $chr, 6); + $marr = $this->placeModule($marr, $nrow, $ncol, 1, $ncol - 2, $chr, 7); + $marr = $this->placeModule($marr, $nrow, $ncol, 1, $ncol - 1, $chr, 8); + ++$chr; + return $marr; + } + + /** + * Sweep upward diagonally, inserting successive characters, + * (Annex F - ECC 200 symbol character placement) + * + * @param array $marr Array of symbols + * @param int $nrow Number of rows + * @param int $ncol Number of columns + * @param int $chr Char byte + * @param int $row Current row + * @param int $col Current column + * + * @return array + */ + protected function placeSweepUpward( + array $marr, + int $nrow, + int $ncol, + int &$chr, + int &$row, + int &$col + ): array { + do { + if (($row < $nrow) && ($col >= 0) && (! $marr[(($row * $ncol) + $col)])) { + $marr = $this->placeUtah($marr, $nrow, $ncol, $row, $col, $chr); + ++$chr; + } + + $row -= 2; + $col += 2; + } while (($row >= 0) && ($col < $ncol)); + + ++$row; + $col += 3; + return $marr; + } + + /** + * Sweep downward diagonally, inserting successive characters, + * (Annex F - ECC 200 symbol character placement) + * + * @param array $marr Array of symbols + * @param int $nrow Number of rows + * @param int $ncol Number of columns + * @param int $chr Char byte + * @param int $row Current row + * @param int $col Current column + * + * @return array + */ + protected function placeSweepDownward( + array $marr, + int $nrow, + int $ncol, + int &$chr, + int &$row, + int &$col + ): array { + do { + if (($row >= 0) && ($col < $ncol) && (! $marr[(($row * $ncol) + $col)])) { + $marr = $this->placeUtah($marr, $nrow, $ncol, $row, $col, $chr); + ++$chr; + } + + $row += 2; + $col -= 2; + } while (($row < $nrow) && ($col >= 0)); + + $row += 3; + ++$col; + return $marr; + } + + /** + * Build a placement map. + * (Annex F - ECC 200 symbol character placement) + * + * @param int $nrow Number of rows. + * @param int $ncol Number of columns. + * + * @return array + */ + public function getPlacementMap( + int $nrow, + int $ncol + ): array { + // initialize array with zeros + $marr = array_fill(0, ($nrow * $ncol), 0); + // set starting values + $chr = 1; + $row = 4; + $col = 0; + do { + // repeatedly first check for one of the special corner cases, then + $marr = $this->placeCornerA($marr, $nrow, $ncol, $chr, $row, $col); + $marr = $this->placeCornerB($marr, $nrow, $ncol, $chr, $row, $col); + $marr = $this->placeCornerC($marr, $nrow, $ncol, $chr, $row, $col); + $marr = $this->placeCornerD($marr, $nrow, $ncol, $chr, $row, $col); + // sweep upward diagonally, inserting successive characters, + $marr = $this->placeSweepUpward($marr, $nrow, $ncol, $chr, $row, $col); + // & then sweep downward diagonally, inserting successive characters,... + $marr = $this->placeSweepDownward($marr, $nrow, $ncol, $chr, $row, $col); + // ... until the entire array is scanned + } while (($row < $nrow) || ($col < $ncol)); + + // lastly, if the lower righthand corner is untouched, fill in fixed pattern + if (! $marr[(($nrow * $ncol) - 1)]) { + $marr[(($nrow * $ncol) - 1)] = 1; + $marr[(($nrow * $ncol) - $ncol - 2)] = 1; + } + + return $marr; + } +} diff --git a/vendor/tecnickcom/tc-lib-barcode/src/Type/Square/Datamatrix/Steps.php b/vendor/tecnickcom/tc-lib-barcode/src/Type/Square/Datamatrix/Steps.php new file mode 100644 index 0000000..7bfc4d3 --- /dev/null +++ b/vendor/tecnickcom/tc-lib-barcode/src/Type/Square/Datamatrix/Steps.php @@ -0,0 +1,387 @@ + + * @copyright 2015-2024 Nicola Asuni - Tecnick.com LTD + * @license http://www.gnu.org/copyleft/lesser.html GNU-LGPL v3 (see LICENSE.TXT) + * @link https://github.com/tecnickcom/tc-lib-barcode + * + * This file is part of tc-lib-barcode software library. + */ + +namespace Com\Tecnick\Barcode\Type\Square\Datamatrix; + +/** + * Com\Tecnick\Barcode\Type\Square\Datamatrix\Steps + * + * Steps methods for Datamatrix Barcode type class + * + * @since 2015-02-21 + * @category Library + * @package Barcode + * @author Nicola Asuni + * @copyright 2015-2024 Nicola Asuni - Tecnick.com LTD + * @license http://www.gnu.org/copyleft/lesser.html GNU-LGPL v3 (see LICENSE.TXT) + * @link https://github.com/tecnickcom/tc-lib-barcode + */ +abstract class Steps extends \Com\Tecnick\Barcode\Type\Square\Datamatrix\Modes +{ + /** + * The look-ahead test scans the data to be encoded to find the best mode (Annex P - steps from J to S). + * + * @param string $data Data to encode + * @param int $pos Current position + * @param int $mode Current encoding mode + * + * @return int encoding mode + */ + public function lookAheadTest(string $data, int $pos, int $mode): int + { + $data_length = strlen($data); + if ($pos >= $data_length) { + return $mode; + } + + $charscount = 0; // count processed chars + // STEP J + if ($mode == Data::ENC_ASCII) { + $numch = [0, 1, 1, 1, 1, 1.25]; + } else { + $numch = [1, 2, 2, 2, 2, 2.25]; + $numch[$mode] = 0; + } + + while (true) { + if (($pos + $charscount) == $data_length) { + return $this->stepK($numch); + } + + $chr = ord($data[$pos + $charscount]); + ++$charscount; + $this->stepL($chr, $numch); + $this->stepM($chr, $numch); + $this->stepN($chr, $numch); + $this->stepO($chr, $numch); + $this->stepP($chr, $numch); + $this->stepQ($chr, $numch); + if ($charscount >= 4) { + $ret = $this->stepR($numch, $pos, $data_length, $charscount, $data); + if ($ret >= 0) { + return $ret; + } + } + } + } + + /** + * Step K + * + * @param array $numch Number of characters + * + * @return int encoding mode + */ + protected function stepK(array $numch): int + { + if ( + $numch[Data::ENC_ASCII] <= ceil(min( + $numch[Data::ENC_C40], + $numch[Data::ENC_TXT], + $numch[Data::ENC_X12], + $numch[Data::ENC_EDF], + $numch[Data::ENC_BASE256] + )) + ) { + return Data::ENC_ASCII; + } + + if ( + $numch[Data::ENC_BASE256] < ceil(min( + $numch[Data::ENC_ASCII], + $numch[Data::ENC_C40], + $numch[Data::ENC_TXT], + $numch[Data::ENC_X12], + $numch[Data::ENC_EDF] + )) + ) { + return Data::ENC_BASE256; + } + + if ( + $numch[Data::ENC_EDF] < ceil(min( + $numch[Data::ENC_ASCII], + $numch[Data::ENC_C40], + $numch[Data::ENC_TXT], + $numch[Data::ENC_X12], + $numch[Data::ENC_BASE256] + )) + ) { + return Data::ENC_EDF; + } + + if ( + $numch[Data::ENC_TXT] < ceil(min( + $numch[Data::ENC_ASCII], + $numch[Data::ENC_C40], + $numch[Data::ENC_X12], + $numch[Data::ENC_EDF], + $numch[Data::ENC_BASE256] + )) + ) { + return Data::ENC_TXT; + } + + if ( + $numch[Data::ENC_X12] < ceil(min( + $numch[Data::ENC_ASCII], + $numch[Data::ENC_C40], + $numch[Data::ENC_TXT], + $numch[Data::ENC_EDF], + $numch[Data::ENC_BASE256] + )) + ) { + return Data::ENC_X12; + } + + return Data::ENC_C40; + } + + /** + * Step L + * + * @param int $chr Character code + * @param array $numch Number of characters + */ + protected function stepL(int $chr, array &$numch): void + { + if ($this->isCharMode($chr, Data::ENC_ASCII_NUM)) { + $numch[Data::ENC_ASCII] += (1 / 2); + } elseif ($this->isCharMode($chr, Data::ENC_ASCII_EXT)) { + $numch[Data::ENC_ASCII] = ceil($numch[Data::ENC_ASCII]); + $numch[Data::ENC_ASCII] += 2; + } else { + $numch[Data::ENC_ASCII] = ceil($numch[Data::ENC_ASCII]); + ++$numch[Data::ENC_ASCII]; + } + } + + /** + * Step M + * + * @param int $chr Character code + * @param array $numch Number of characters + */ + protected function stepM(int $chr, array &$numch): void + { + if ($this->isCharMode($chr, Data::ENC_C40)) { + $numch[Data::ENC_C40] += (2 / 3); + } elseif ($this->isCharMode($chr, Data::ENC_ASCII_EXT)) { + $numch[Data::ENC_C40] += (8 / 3); + } else { + $numch[Data::ENC_C40] += (4 / 3); + } + } + + /** + * Step N + * + * @param int $chr Character code + * @param array $numch Number of characters + */ + protected function stepN(int $chr, array &$numch): void + { + if ($this->isCharMode($chr, Data::ENC_TXT)) { + $numch[Data::ENC_TXT] += (2 / 3); + } elseif ($this->isCharMode($chr, Data::ENC_ASCII_EXT)) { + $numch[Data::ENC_TXT] += (8 / 3); + } else { + $numch[Data::ENC_TXT] += (4 / 3); + } + } + + /** + * Step O + * + * @param int $chr Character code + * @param array $numch Number of characters + */ + protected function stepO(int $chr, array &$numch): void + { + if ($this->isCharMode($chr, Data::ENC_X12) || $this->isCharMode($chr, Data::ENC_C40)) { + $numch[Data::ENC_X12] += (2 / 3); + } elseif ($this->isCharMode($chr, Data::ENC_ASCII_EXT)) { + $numch[Data::ENC_X12] += (13 / 3); + } else { + $numch[Data::ENC_X12] += (10 / 3); + } + } + + /** + * Step P + * + * @param int $chr Character code + * @param array $numch Number of characters + */ + protected function stepP(int $chr, array &$numch): void + { + if ($this->isCharMode($chr, Data::ENC_EDF)) { + $numch[Data::ENC_EDF] += (3 / 4); + } elseif ($this->isCharMode($chr, Data::ENC_ASCII_EXT)) { + $numch[Data::ENC_EDF] += (17 / 4); + } else { + $numch[Data::ENC_EDF] += (13 / 4); + } + } + + /** + * Step Q + * + * @param int $chr Character code + * @param array $numch Number of characters + */ + protected function stepQ(int $chr, array &$numch): void + { + if ($this->isCharMode($chr, Data::ENC_BASE256)) { + $numch[Data::ENC_BASE256] += 4; + } else { + ++$numch[Data::ENC_BASE256]; + } + } + + /** + * Step R-f + * + * @param array $numch Number of characters + * @param int $pos Current position + * @param int $data_length Data length + * @param int $charscount Number of processed characters + * @param string $data Data to encode + * + * @return int Encoding mode + */ + protected function stepRf( + array $numch, + int $pos, + int $data_length, + int $charscount, + string $data + ): int { + if ( + ($numch[Data::ENC_C40] + 1) < min( + $numch[Data::ENC_ASCII], + $numch[Data::ENC_TXT], + $numch[Data::ENC_EDF], + $numch[Data::ENC_BASE256] + ) + ) { + if ($numch[Data::ENC_C40] < $numch[Data::ENC_X12]) { + return Data::ENC_C40; + } + + if ($numch[Data::ENC_C40] == $numch[Data::ENC_X12]) { + $ker = ($pos + $charscount + 1); + while ($ker < $data_length) { + $tmpchr = ord($data[$ker]); + if ($this->isCharMode($tmpchr, Data::ENC_X12)) { + return Data::ENC_X12; + } + + if ($this->isCharMode($tmpchr, Data::ENC_C40)) { + break; + } + + ++$ker; + } + + return Data::ENC_C40; + } + } + + return -1; + } + + /** + * Step R + * + * @param array $numch Number of characters + * @param int $pos Current position + * @param int $data_length Data length + * @param int $charscount Number of processed characters + * @param string $data Data to encode + * + * @return int Encoding mode + */ + protected function stepR( + array $numch, + int $pos, + int $data_length, + int $charscount, + string $data + ): int { + if ( + ($numch[Data::ENC_ASCII] + 1) <= min( + $numch[Data::ENC_C40], + $numch[Data::ENC_TXT], + $numch[Data::ENC_X12], + $numch[Data::ENC_EDF], + $numch[Data::ENC_BASE256] + ) + ) { + return Data::ENC_ASCII; + } + + if ( + (($numch[Data::ENC_BASE256] + 1) <= $numch[Data::ENC_ASCII]) + || (($numch[Data::ENC_BASE256] + 1) < min( + $numch[Data::ENC_C40], + $numch[Data::ENC_TXT], + $numch[Data::ENC_X12], + $numch[Data::ENC_EDF] + )) + ) { + return Data::ENC_BASE256; + } + + if ( + ($numch[Data::ENC_EDF] + 1) < min( + $numch[Data::ENC_ASCII], + $numch[Data::ENC_C40], + $numch[Data::ENC_TXT], + $numch[Data::ENC_X12], + $numch[Data::ENC_BASE256] + ) + ) { + return Data::ENC_EDF; + } + + if ( + ($numch[Data::ENC_TXT] + 1) < min( + $numch[Data::ENC_ASCII], + $numch[Data::ENC_C40], + $numch[Data::ENC_X12], + $numch[Data::ENC_EDF], + $numch[Data::ENC_BASE256] + ) + ) { + return Data::ENC_TXT; + } + + if ( + ($numch[Data::ENC_X12] + 1) < min( + $numch[Data::ENC_ASCII], + $numch[Data::ENC_C40], + $numch[Data::ENC_TXT], + $numch[Data::ENC_EDF], + $numch[Data::ENC_BASE256] + ) + ) { + return Data::ENC_X12; + } + + return $this->stepRf($numch, $pos, $data_length, $charscount, $data); + } +} diff --git a/vendor/tecnickcom/tc-lib-barcode/src/Type/Square/PdfFourOneSeven.php b/vendor/tecnickcom/tc-lib-barcode/src/Type/Square/PdfFourOneSeven.php new file mode 100644 index 0000000..67f9c56 --- /dev/null +++ b/vendor/tecnickcom/tc-lib-barcode/src/Type/Square/PdfFourOneSeven.php @@ -0,0 +1,378 @@ + + * @copyright 2015-2024 Nicola Asuni - Tecnick.com LTD + * @license http://www.gnu.org/copyleft/lesser.html GNU-LGPL v3 (see LICENSE.TXT) + * @link https://github.com/tecnickcom/tc-lib-barcode + * + * This file is part of tc-lib-barcode software library. + */ + +namespace Com\Tecnick\Barcode\Type\Square; + +use Com\Tecnick\Barcode\Exception as BarcodeException; +use Com\Tecnick\Barcode\Type\Square\PdfFourOneSeven\Data; + +/** + * Com\Tecnick\Barcode\Type\Square\PdfFourOneSeven + * + * PdfFourOneSeven Barcode type class + * PDF417 (ISO/IEC 15438:2006) + * + * PDF417 (ISO/IEC 15438:2006) is a 2-dimensional stacked bar code created by Symbol Technologies in 1991. + * It is one of the most popular 2D codes because of its ability to be read with slightly modified handheld + * laser or linear CCD scanners. + * TECHNICAL DATA / FEATURES OF PDF417: + * Encodable Character Set: All 128 ASCII Characters (including extended) + * Code Type: Continuous, Multi-Row + * Symbol Height: 3 - 90 Rows + * Symbol Width: 90X - 583X + * Bidirectional Decoding: Yes + * Error Correction Characters: 2 - 512 + * Maximum Data Characters: 1850 text, 2710 digits, 1108 bytes + * + * @since 2015-02-21 + * @category Library + * @package Barcode + * @author Nicola Asuni + * @copyright 2015-2024 Nicola Asuni - Tecnick.com LTD + * @license http://www.gnu.org/copyleft/lesser.html GNU-LGPL v3 (see LICENSE.TXT) + * @link https://github.com/tecnickcom/tc-lib-barcode + */ +class PdfFourOneSeven extends \Com\Tecnick\Barcode\Type\Square\PdfFourOneSeven\Compaction +{ + /** + * Barcode format + * + * @var string + */ + protected const FORMAT = 'PDF417'; + + /** + * Row height respect X dimension of single module + */ + protected int $row_height = 2; + + /** + * Horizontal quiet zone in modules + */ + protected int $quiet_vertical = 2; + + /** + * Vertical quiet zone in modules + */ + protected int $quiet_horizontal = 2; + + /** + * Aspect ratio (width / height) + */ + protected float $aspectratio = 2; + + /** + * Error correction level (0-8); + * Default -1 = automatic correction level + */ + protected int $ecl = -1; + + /** + * Information for macro block + * + * @var array{ + * 'file_id'?: string, + * 'option_0'?: string, + * 'option_1'?: string, + * 'option_2'?: string, + * 'option_3'?: string, + * 'option_4'?: string, + * 'option_5'?: string, + * 'option_6'?: string, + * 'segment_index'?: int, + * 'segment_total'?: int, + * } + */ + protected array $macro = []; + + /** + * Set extra (optional) parameters + */ + protected function setParameters(): void + { + parent::setParameters(); + + // aspect ratio + if ( + ! empty($this->params[0]) + && (($aspectratio = (float) $this->params[0]) >= 1) + ) { + $this->aspectratio = $aspectratio; + } + + // error correction level (auto) + if ( + isset($this->params[1]) + && (($ecl = (int) $this->params[1]) >= 0) + && ($ecl <= 8) + ) { + $this->ecl = $ecl; + } + + // macro block + $this->setMacroBlockParam(); + } + + /** + * Set macro block parameter + * + * @SuppressWarnings("PHPMD.CyclomaticComplexity") + */ + protected function setMacroBlockParam(): void + { + if ( + isset($this->params[4]) + && (is_string($this->params[4])) + && ($this->params[2] !== '') + && ($this->params[3] !== '') + && ($this->params[4] !== '') + ) { + $this->macro['segment_total'] = (int) $this->params[2]; + $this->macro['segment_index'] = (int) $this->params[3]; + $this->macro['file_id'] = strtr($this->params[4], "\xff", ','); + for ($idx = 0; $idx < 7; ++$idx) { + $opt = $idx + 5; + if ( + isset($this->params[$opt]) + && (is_string($this->params[$opt])) + && ($this->params[$opt] !== '') + ) { + /* @phpstan-ignore-next-line */ + $this->macro['option_' . $idx] = strtr($this->params[$opt], "\xff", ','); + } + } + } + } + + /** + * Get the bars array + * + * @throws BarcodeException in case of error + */ + protected function setBars(): void + { + if (strlen((string) $this->code) == 0) { + throw new BarcodeException('Empty input'); + } + + $seq = $this->getBinSequence(); + $this->processBinarySequence($this->getRawCodeRows($seq)); + } + + /** + * Get macro control block codewords + * + * @param int $numcw Number of codewords + * + * @return array + */ + protected function getMacroBlock(int &$numcw): array + { + if ($this->macro === []) { + return []; + } + + $macrocw = []; + // beginning of macro control block + $macrocw[] = 928; + // segment index + $cdw = $this->getCompaction(902, sprintf('%05d', $this->macro['segment_index']), false); + $macrocw = array_merge($macrocw, $cdw); + // file ID + $cdw = $this->getCompaction(900, $this->macro['file_id'], false); + $macrocw = array_merge($macrocw, $cdw); + // optional fields + $optmodes = [900, 902, 902, 900, 900, 902, 902]; + $optsize = [-1, 2, 4, -1, -1, -1, 2]; + foreach ($optmodes as $key => $omode) { + if (isset($this->macro['option_' . $key])) { + $macrocw[] = 923; + $macrocw[] = $key; + if ($optsize[$key] == 2) { + $this->macro['option_' . $key] = sprintf('%05d', $this->macro['option_' . $key]); + } elseif ($optsize[$key] == 4) { + $this->macro['option_' . $key] = sprintf('%010d', $this->macro['option_' . $key]); + } + + $cdw = $this->getCompaction($omode, $this->macro['option_' . $key], false); + $macrocw = array_merge($macrocw, $cdw); + } + } + + if ($this->macro['segment_index'] == ($this->macro['segment_total'] - 1)) { + // end of control block + $macrocw[] = 922; + } + + // update total codewords + $numcw += count($macrocw); + return $macrocw; + } + + /** + * Get codewords + * + * @param int $rows number of rows + * @param int $cols number of columns + * @param int $ecl eroor correction level + * + * @return array + * + * @throws BarcodeException in case of error + */ + public function getCodewords( + int &$rows, + int &$cols, + int &$ecl + ): array { + $codewords = []; // array of code-words + // get the input sequence array + $sequence = $this->getInputSequences($this->code); + foreach ($sequence as $seq) { + $cws = $this->getCompaction($seq[0], $seq[1], true); + $codewords = array_merge($codewords, $cws); + } + + if ($codewords[0] == 900) { + // Text Alpha is the default mode, so remove the first code + array_shift($codewords); + } + + // count number of codewords + $numcw = count($codewords); + if ($numcw > 925) { + throw new BarcodeException('The maximum codeword capaciy has been reached: ' . $numcw . ' > 925'); + } + + $macrocw = $this->getMacroBlock($numcw); + // set error correction level + $ecl = $this->getErrorCorrectionLevel($this->ecl, $numcw); + // number of codewords for error correction + $errsize = (2 << $ecl); + // calculate number of columns (number of codewords per row) and rows + $nce = ($numcw + $errsize + 1); + $cols = (int) min( + 30, + max(1, round((sqrt(4761 + (68 * $this->aspectratio * $this->row_height * $nce)) - 69) / 34)) + ); + $rows = (int) min( + 90, + max(3, ceil($nce / $cols)) + ); + $size = ($cols * $rows); + if ($size > 928) { + // set dimensions to get maximum capacity + if (abs($this->aspectratio - (17 * 29 / 32)) < abs($this->aspectratio - (17 * 16 / 58))) { + $cols = 29; + $rows = 32; + } else { + $cols = 16; + $rows = 58; + } + + $size = 928; + } + + // calculate padding + $pad = (int) ($size - $nce); + if ($pad > 0) { + // add padding + $codewords = array_merge($codewords, array_fill(0, $pad, 900)); + } + + if ($macrocw !== []) { + // add macro section + $codewords = array_merge($codewords, $macrocw); + } + + // Symbol Length Descriptor (number of data codewords including Symbol Length Descriptor and pad codewords) + $sld = (int) ($size - $errsize); + // add symbol length description + array_unshift($codewords, $sld); + // calculate error correction + $ecw = $this->getErrorCorrection($codewords, $ecl); + // add error correction codewords + return array_merge($codewords, $ecw); + } + + /** + * Creates a PDF417 object as binary string + * + * @return string barcode as binary string + * + * @throws BarcodeException in case of error + */ + public function getBinSequence(): string + { + $rows = 0; + $cols = 0; + $ecl = 0; + $codewords = $this->getCodewords($rows, $cols, $ecl); + $barcode = ''; + // add horizontal quiet zones to start and stop patterns + $pstart = str_repeat('0', $this->quiet_horizontal) . Data::START_PATTERN; + $this->nrows = ($rows * $this->row_height) + (2 * $this->quiet_vertical); + $this->ncols = (($cols + 2) * 17) + 35 + (2 * $this->quiet_horizontal); + // build rows for vertical quiet zone + $empty_row = ',' . str_repeat('0', $this->ncols); + $empty_rows = str_repeat($empty_row, $this->quiet_vertical); + $barcode .= $empty_rows; + $kcw = 0; // codeword index + $cid = 0; // initial cluster + // for each row + for ($rix = 0; $rix < $rows; ++$rix) { + // row start code + $row = $pstart; + $rval = 0; + $cval = 0; + switch ($cid) { + case 0: + $rval = ((30 * (int) ($rix / 3)) + (int) (($rows - 1) / 3)); + $cval = ((30 * (int) ($rix / 3)) + ($cols - 1)); + break; + case 1: + $rval = ((30 * (int) ($rix / 3)) + ($ecl * 3) + (($rows - 1) % 3)); + $cval = ((30 * (int) ($rix / 3)) + (int) (($rows - 1) / 3)); + break; + case 2: + $rval = ((30 * (int) ($rix / 3)) + ($cols - 1)); + $cval = ((30 * (int) ($rix / 3)) + ($ecl * 3) + (($rows - 1) % 3)); + break; + } + + // left row indicator + $row .= sprintf('%17b', Data::CLUSTERS[$cid][$rval]); + // for each column + for ($cix = 0; $cix < $cols; ++$cix) { + $row .= sprintf('%17b', Data::CLUSTERS[$cid][$codewords[$kcw]]); + ++$kcw; + } + + // right row indicator + $row .= sprintf('%17b', Data::CLUSTERS[$cid][$cval]); + // row stop code + $row .= Data::STOP_PATTERN . str_repeat('0', $this->quiet_horizontal); + $brow = ',' . str_repeat($row, $this->row_height); + $barcode .= $brow; + ++$cid; + if ($cid > 2) { + $cid = 0; + } + } + + return $barcode . $empty_rows; + } +} diff --git a/vendor/tecnickcom/tc-lib-barcode/src/Type/Square/PdfFourOneSeven/Compaction.php b/vendor/tecnickcom/tc-lib-barcode/src/Type/Square/PdfFourOneSeven/Compaction.php new file mode 100644 index 0000000..2307cfe --- /dev/null +++ b/vendor/tecnickcom/tc-lib-barcode/src/Type/Square/PdfFourOneSeven/Compaction.php @@ -0,0 +1,231 @@ + + * @copyright 2010-2024 Nicola Asuni - Tecnick.com LTD + * @license http://www.gnu.org/copyleft/lesser.html GNU-LGPL v3 (see LICENSE.TXT) + * @link https://github.com/tecnickcom/tc-lib-barcode + * + * This file is part of tc-lib-barcode software library. + */ + +namespace Com\Tecnick\Barcode\Type\Square\PdfFourOneSeven; + +/** + * Com\Tecnick\Barcode\Type\Square\PdfFourOneSeven\Compaction + * + * Process for PdfFourOneSeven Barcode type class + * + * @since 2015-02-21 + * @category Library + * @package Barcode + * @author Nicola Asuni + * @copyright 2010-2024 Nicola Asuni - Tecnick.com LTD + * @license http://www.gnu.org/copyleft/lesser.html GNU-LGPL v3 (see LICENSE.TXT) + * @link https://github.com/tecnickcom/tc-lib-barcode + */ +abstract class Compaction extends \Com\Tecnick\Barcode\Type\Square\PdfFourOneSeven\Sequence +{ + /** + * Process Sub Text Compaction + * + * @param array $txtarr Array of characters and sub-mode switching characters + * @param int $submode Current submode + * @param int $sub New submode + * @param string $code Data to compact + * @param int $key Character code + * @param int $idx Current index + * @param int $codelen Code length + */ + protected function processTextCompactionSub( + array &$txtarr, + int &$submode, + int $sub, + string $code, + int $key, + int $idx, + int $codelen + ): void { + // $sub is the new submode + if ( + (($idx + 1 === $codelen) || ((($idx + 1) < $codelen) + && (in_array(ord($code[($idx + 1)]), Data::TEXT_SUB_MODES[$submode])))) + && (($sub == 3) || (($sub == 0) && ($submode == 1))) + ) { + // shift (temporary change only for this char) + $txtarr[] = $sub == 3 ? 29 : 27; + } else { + // latch + $txtarr = array_merge($txtarr, Data::TEXT_LATCH['' . $submode . $sub]); + // set new submode + $submode = $sub; + } + + // add character code to array + $txtarr[] = $key; + } + + /** + * Process Text Compaction + * + * @param string $code Data to compact + * @param array $codewords Codewords + */ + protected function processTextCompaction(string $code, array &$codewords): void + { + $submode = 0; // default Alpha sub-mode + $txtarr = []; // array of characters and sub-mode switching characters + $codelen = strlen($code); + for ($idx = 0; $idx < $codelen; ++$idx) { + $chval = ord($code[$idx]); + if (($key = array_search($chval, Data::TEXT_SUB_MODES[$submode], true)) !== false) { + // we are on the same sub-mode + $txtarr[] = $key; + } else { + // the sub-mode is changed + for ($sub = 0; $sub < 4; ++$sub) { + // search new sub-mode + if ( + ($sub != $submode) + && (($key = array_search($chval, Data::TEXT_SUB_MODES[$sub], true)) !== false) + ) { + $this->processTextCompactionSub($txtarr, $submode, $sub, $code, $key, $idx, $codelen); + break; + } + } + } + } + + $txtarrlen = count($txtarr); + if ($txtarrlen % 2 != 0) { + // add padding + $txtarr[] = 29; + ++$txtarrlen; + } + + // calculate codewords + for ($idx = 0; $idx < $txtarrlen; $idx += 2) { + $codewords[] = (30 * $txtarr[$idx]) + $txtarr[($idx + 1)]; + } + } + + /** + * Process Byte Compaction + * + * @param string $code Data to compact + * @param array $codewords Codewords + */ + protected function processByteCompaction(string $code, array &$codewords): void + { + while (($codelen = strlen($code)) > 0) { + if ($codelen > 6) { + $rest = substr($code, 6); + $code = substr($code, 0, 6); + $sublen = 6; + } else { + $rest = ''; + $sublen = strlen($code); + } + + if ($sublen == 6) { + $tdg = bcmul('' . ord($code[0]), '1099511627776'); + $tdg = bcadd($tdg, bcmul('' . ord($code[1]), '4294967296')); + $tdg = bcadd($tdg, bcmul('' . ord($code[2]), '16777216')); + $tdg = bcadd($tdg, bcmul('' . ord($code[3]), '65536')); + $tdg = bcadd($tdg, bcmul('' . ord($code[4]), '256')); + $tdg = bcadd($tdg, '' . ord($code[5])); + // tmp array for the 6 bytes block + $cw6 = []; + for ($idx = 0; $idx < 5; ++$idx) { + $ddg = bcmod($tdg, '900'); + $tdg = bcdiv($tdg, '900'); + // prepend the value to the beginning of the array + array_unshift($cw6, $ddg); + } + + // append the result array at the end + $codewords = array_merge($codewords, $cw6); //@phpstan-ignore parameterByRef.type + } else { + for ($idx = 0; $idx < $sublen; ++$idx) { + $codewords[] = ord($code[$idx]); //@phpstan-ignore parameterByRef.type + } + } + + $code = $rest; + } + } + + /** + * Process Numeric Compaction + * + * @param string $code Data to compact + * @param array $codewords Codewords + */ + protected function processNumericCompaction(string $code, array &$codewords): void + { + while (($codelen = strlen($code)) > 0) { + $rest = ''; + if ($codelen > 44) { + $rest = substr($code, 44); + $code = substr($code, 0, 44); + } + + $tdg = '1' . $code; + do { + $ddg = bcmod($tdg, '900'); + $tdg = bcdiv($tdg, '900'); + array_unshift($codewords, $ddg); + } while ($tdg != '0'); + + $code = $rest; + } + } + + /** + * Compact data by mode + * + * @param int $mode Compaction mode number + * @param string $code Data to compact + * @param bool $addmode If true add the mode codeword in the first position + * + * @return array of codewords + */ + protected function getCompaction( + int $mode, + string $code, + bool $addmode = true + ): array { + $codewords = []; // array of codewords to return + switch ($mode) { + case 900: + // Text Compaction mode latch + $this->processTextCompaction($code, $codewords); + break; + case 901: + case 924: + // Byte Compaction mode latch + $this->processByteCompaction($code, $codewords); + break; + case 902: + // Numeric Compaction mode latch + $this->processNumericCompaction($code, $codewords); + break; + case 913: + // Byte Compaction mode shift + $codewords[] = ord($code); + break; + } + + if ($addmode) { + // add the compaction mode codeword at the beginning + array_unshift($codewords, $mode); + } + + return $codewords; + } +} diff --git a/vendor/tecnickcom/tc-lib-barcode/src/Type/Square/PdfFourOneSeven/Data.php b/vendor/tecnickcom/tc-lib-barcode/src/Type/Square/PdfFourOneSeven/Data.php new file mode 100644 index 0000000..5be4247 --- /dev/null +++ b/vendor/tecnickcom/tc-lib-barcode/src/Type/Square/PdfFourOneSeven/Data.php @@ -0,0 +1,4422 @@ + + * @copyright 2010-2024 Nicola Asuni - Tecnick.com LTD + * @license http://www.gnu.org/copyleft/lesser.html GNU-LGPL v3 (see LICENSE.TXT) + * @link https://github.com/tecnickcom/tc-lib-barcode + * + * This file is part of tc-lib-barcode software library. + */ + +namespace Com\Tecnick\Barcode\Type\Square\PdfFourOneSeven; + +/** + * Com\Tecnick\Barcode\Type\Square\PdfFourOneSeven\Data + * + * Process for PdfFourOneSeven Barcode type class + * + * @since 2015-02-21 + * @category Library + * @package Barcode + * @author Nicola Asuni + * @copyright 2010-2024 Nicola Asuni - Tecnick.com LTD + * @license http://www.gnu.org/copyleft/lesser.html GNU-LGPL v3 (see LICENSE.TXT) + * @link https://github.com/tecnickcom/tc-lib-barcode + * + * @SuppressWarnings("PHPMD.ExcessiveClassLength") + */ +abstract class Data +{ + /** + * Start pattern + * + * @var string + */ + public const START_PATTERN = '11111111010101000'; + + /** + * Stop pattern + * + * @var string + */ + public const STOP_PATTERN = '111111101000101001'; + + /** + * Array of text Compaction Sub-Modes (values 0xFB - 0xFF are used for submode changers) + * + * @var array> + */ + public const TEXT_SUB_MODES = [ + [ + // Alpha + 0x41, + 0x42, + 0x43, + 0x44, + 0x45, + 0x46, + 0x47, + 0x48, + 0x49, + 0x4a, + 0x4b, + 0x4c, + 0x4d, + 0x4e, + 0x4f, + 0x50, + 0x51, + 0x52, + 0x53, + 0x54, + 0x55, + 0x56, + 0x57, + 0x58, + 0x59, + 0x5a, + 0x20, + 0xFD, + 0xFE, + 0xFF, + ], + [ + // Lower + 0x61, + 0x62, + 0x63, + 0x64, + 0x65, + 0x66, + 0x67, + 0x68, + 0x69, + 0x6a, + 0x6b, + 0x6c, + 0x6d, + 0x6e, + 0x6f, + 0x70, + 0x71, + 0x72, + 0x73, + 0x74, + 0x75, + 0x76, + 0x77, + 0x78, + 0x79, + 0x7a, + 0x20, + 0xFD, + 0xFE, + 0xFF, + ], + [ + // Mixed + 0x30, + 0x31, + 0x32, + 0x33, + 0x34, + 0x35, + 0x36, + 0x37, + 0x38, + 0x39, + 0x26, + 0x0d, + 0x09, + 0x2c, + 0x3a, + 0x23, + 0x2d, + 0x2e, + 0x24, + 0x2f, + 0x2b, + 0x25, + 0x2a, + 0x3d, + 0x5e, + 0xFB, + 0x20, + 0xFD, + 0xFE, + 0xFF, + ], + [ + // Puntuaction + 0x3b, + 0x3c, + 0x3e, + 0x40, + 0x5b, + 0x5c, + 0x5d, + 0x5f, + 0x60, + 0x7e, + 0x21, + 0x0d, + 0x09, + 0x2c, + 0x3a, + 0x0a, + 0x2d, + 0x2e, + 0x24, + 0x2f, + 0x22, + 0x7c, + 0x2a, + 0x28, + 0x29, + 0x3f, + 0x7b, + 0x7d, + 0x27, + 0xFF, + ], + ]; + + /** + * Array of switching codes for Text Compaction Sub-Modes + * + * @var array> + */ + public const TEXT_LATCH = [ + '01' => [27], + '02' => [28], + '03' => [28, 25], + '10' => [28, 28], + '12' => [28], + '13' => [28, 25], + '20' => [28], + '21' => [27], + '23' => [25], + '30' => [29], + '31' => [29, 27], + '32' => [29, 28], + ]; + + /** + * Clusters of codewords (0, 3, 6). + * Values are hex equivalents of binary representation of bars (1 = bar, 0 = space). + * The codewords numbered from 900 to 928 have special meaning, + * some enable to switch between modes in order to optimise the code: + * + * 900 : Switch to "Text" mode + * 901 : Switch to "Byte" mode + * 902 : Switch to "Numeric" mode + * 903 - 912 : Reserved + * 913 : Switch to "Octet" only for the next codeword + * 914 - 920 : Reserved + * 921 : Initialization + * 922 : Terminator codeword for Macro PDF control block + * 923 : Sequence tag to identify the beginning of optional fields in the Macro PDF control block + * 924 : Switch to "Byte" mode (If the total number of byte is multiple of 6) + * 925 : Identifier for a user defined Extended Channel Interpretation (ECI) + * 926 : Identifier for a general purpose ECI format + * 927 : Identifier for an ECI of a character set or code page + * 928 : Macro marker codeword to indicate the beginning of a Macro PDF Control Block + * + * @var array> + */ + public const CLUSTERS = [ + [ + // cluster 0 ----------------------------------------------------------------------- + 0x1d5c0, + 0x1eaf0, + 0x1f57c, + 0x1d4e0, + 0x1ea78, + 0x1f53e, + 0x1a8c0, + 0x1d470, + 0x1a860, + 0x15040, + // 10 + 0x1a830, + 0x15020, + 0x1adc0, + 0x1d6f0, + 0x1eb7c, + 0x1ace0, + 0x1d678, + 0x1eb3e, + 0x158c0, + 0x1ac70, + // 20 + 0x15860, + 0x15dc0, + 0x1aef0, + 0x1d77c, + 0x15ce0, + 0x1ae78, + 0x1d73e, + 0x15c70, + 0x1ae3c, + 0x15ef0, + // 30 + 0x1af7c, + 0x15e78, + 0x1af3e, + 0x15f7c, + 0x1f5fa, + 0x1d2e0, + 0x1e978, + 0x1f4be, + 0x1a4c0, + 0x1d270, + // 40 + 0x1e93c, + 0x1a460, + 0x1d238, + 0x14840, + 0x1a430, + 0x1d21c, + 0x14820, + 0x1a418, + 0x14810, + 0x1a6e0, + // 50 + 0x1d378, + 0x1e9be, + 0x14cc0, + 0x1a670, + 0x1d33c, + 0x14c60, + 0x1a638, + 0x1d31e, + 0x14c30, + 0x1a61c, + // 60 + 0x14ee0, + 0x1a778, + 0x1d3be, + 0x14e70, + 0x1a73c, + 0x14e38, + 0x1a71e, + 0x14f78, + 0x1a7be, + 0x14f3c, + // 70 + 0x14f1e, + 0x1a2c0, + 0x1d170, + 0x1e8bc, + 0x1a260, + 0x1d138, + 0x1e89e, + 0x14440, + 0x1a230, + 0x1d11c, + // 80 + 0x14420, + 0x1a218, + 0x14410, + 0x14408, + 0x146c0, + 0x1a370, + 0x1d1bc, + 0x14660, + 0x1a338, + 0x1d19e, + // 90 + 0x14630, + 0x1a31c, + 0x14618, + 0x1460c, + 0x14770, + 0x1a3bc, + 0x14738, + 0x1a39e, + 0x1471c, + 0x147bc, + // 100 + 0x1a160, + 0x1d0b8, + 0x1e85e, + 0x14240, + 0x1a130, + 0x1d09c, + 0x14220, + 0x1a118, + 0x1d08e, + 0x14210, + // 110 + 0x1a10c, + 0x14208, + 0x1a106, + 0x14360, + 0x1a1b8, + 0x1d0de, + 0x14330, + 0x1a19c, + 0x14318, + 0x1a18e, + // 120 + 0x1430c, + 0x14306, + 0x1a1de, + 0x1438e, + 0x14140, + 0x1a0b0, + 0x1d05c, + 0x14120, + 0x1a098, + 0x1d04e, + // 130 + 0x14110, + 0x1a08c, + 0x14108, + 0x1a086, + 0x14104, + 0x141b0, + 0x14198, + 0x1418c, + 0x140a0, + 0x1d02e, + // 140 + 0x1a04c, + 0x1a046, + 0x14082, + 0x1cae0, + 0x1e578, + 0x1f2be, + 0x194c0, + 0x1ca70, + 0x1e53c, + 0x19460, + // 150 + 0x1ca38, + 0x1e51e, + 0x12840, + 0x19430, + 0x12820, + 0x196e0, + 0x1cb78, + 0x1e5be, + 0x12cc0, + 0x19670, + // 160 + 0x1cb3c, + 0x12c60, + 0x19638, + 0x12c30, + 0x12c18, + 0x12ee0, + 0x19778, + 0x1cbbe, + 0x12e70, + 0x1973c, + // 170 + 0x12e38, + 0x12e1c, + 0x12f78, + 0x197be, + 0x12f3c, + 0x12fbe, + 0x1dac0, + 0x1ed70, + 0x1f6bc, + 0x1da60, + // 180 + 0x1ed38, + 0x1f69e, + 0x1b440, + 0x1da30, + 0x1ed1c, + 0x1b420, + 0x1da18, + 0x1ed0e, + 0x1b410, + 0x1da0c, + // 190 + 0x192c0, + 0x1c970, + 0x1e4bc, + 0x1b6c0, + 0x19260, + 0x1c938, + 0x1e49e, + 0x1b660, + 0x1db38, + 0x1ed9e, + // 200 + 0x16c40, + 0x12420, + 0x19218, + 0x1c90e, + 0x16c20, + 0x1b618, + 0x16c10, + 0x126c0, + 0x19370, + 0x1c9bc, + // 210 + 0x16ec0, + 0x12660, + 0x19338, + 0x1c99e, + 0x16e60, + 0x1b738, + 0x1db9e, + 0x16e30, + 0x12618, + 0x16e18, + // 220 + 0x12770, + 0x193bc, + 0x16f70, + 0x12738, + 0x1939e, + 0x16f38, + 0x1b79e, + 0x16f1c, + 0x127bc, + 0x16fbc, + // 230 + 0x1279e, + 0x16f9e, + 0x1d960, + 0x1ecb8, + 0x1f65e, + 0x1b240, + 0x1d930, + 0x1ec9c, + 0x1b220, + 0x1d918, + // 240 + 0x1ec8e, + 0x1b210, + 0x1d90c, + 0x1b208, + 0x1b204, + 0x19160, + 0x1c8b8, + 0x1e45e, + 0x1b360, + 0x19130, + // 250 + 0x1c89c, + 0x16640, + 0x12220, + 0x1d99c, + 0x1c88e, + 0x16620, + 0x12210, + 0x1910c, + 0x16610, + 0x1b30c, + // 260 + 0x19106, + 0x12204, + 0x12360, + 0x191b8, + 0x1c8de, + 0x16760, + 0x12330, + 0x1919c, + 0x16730, + 0x1b39c, + // 270 + 0x1918e, + 0x16718, + 0x1230c, + 0x12306, + 0x123b8, + 0x191de, + 0x167b8, + 0x1239c, + 0x1679c, + 0x1238e, + // 280 + 0x1678e, + 0x167de, + 0x1b140, + 0x1d8b0, + 0x1ec5c, + 0x1b120, + 0x1d898, + 0x1ec4e, + 0x1b110, + 0x1d88c, + // 290 + 0x1b108, + 0x1d886, + 0x1b104, + 0x1b102, + 0x12140, + 0x190b0, + 0x1c85c, + 0x16340, + 0x12120, + 0x19098, + // 300 + 0x1c84e, + 0x16320, + 0x1b198, + 0x1d8ce, + 0x16310, + 0x12108, + 0x19086, + 0x16308, + 0x1b186, + 0x16304, + // 310 + 0x121b0, + 0x190dc, + 0x163b0, + 0x12198, + 0x190ce, + 0x16398, + 0x1b1ce, + 0x1638c, + 0x12186, + 0x16386, + // 320 + 0x163dc, + 0x163ce, + 0x1b0a0, + 0x1d858, + 0x1ec2e, + 0x1b090, + 0x1d84c, + 0x1b088, + 0x1d846, + 0x1b084, + // 330 + 0x1b082, + 0x120a0, + 0x19058, + 0x1c82e, + 0x161a0, + 0x12090, + 0x1904c, + 0x16190, + 0x1b0cc, + 0x19046, + // 340 + 0x16188, + 0x12084, + 0x16184, + 0x12082, + 0x120d8, + 0x161d8, + 0x161cc, + 0x161c6, + 0x1d82c, + 0x1d826, + // 350 + 0x1b042, + 0x1902c, + 0x12048, + 0x160c8, + 0x160c4, + 0x160c2, + 0x18ac0, + 0x1c570, + 0x1e2bc, + 0x18a60, + // 360 + 0x1c538, + 0x11440, + 0x18a30, + 0x1c51c, + 0x11420, + 0x18a18, + 0x11410, + 0x11408, + 0x116c0, + 0x18b70, + // 370 + 0x1c5bc, + 0x11660, + 0x18b38, + 0x1c59e, + 0x11630, + 0x18b1c, + 0x11618, + 0x1160c, + 0x11770, + 0x18bbc, + // 380 + 0x11738, + 0x18b9e, + 0x1171c, + 0x117bc, + 0x1179e, + 0x1cd60, + 0x1e6b8, + 0x1f35e, + 0x19a40, + 0x1cd30, + // 390 + 0x1e69c, + 0x19a20, + 0x1cd18, + 0x1e68e, + 0x19a10, + 0x1cd0c, + 0x19a08, + 0x1cd06, + 0x18960, + 0x1c4b8, + // 400 + 0x1e25e, + 0x19b60, + 0x18930, + 0x1c49c, + 0x13640, + 0x11220, + 0x1cd9c, + 0x1c48e, + 0x13620, + 0x19b18, + // 410 + 0x1890c, + 0x13610, + 0x11208, + 0x13608, + 0x11360, + 0x189b8, + 0x1c4de, + 0x13760, + 0x11330, + 0x1cdde, + // 420 + 0x13730, + 0x19b9c, + 0x1898e, + 0x13718, + 0x1130c, + 0x1370c, + 0x113b8, + 0x189de, + 0x137b8, + 0x1139c, + // 430 + 0x1379c, + 0x1138e, + 0x113de, + 0x137de, + 0x1dd40, + 0x1eeb0, + 0x1f75c, + 0x1dd20, + 0x1ee98, + 0x1f74e, + // 440 + 0x1dd10, + 0x1ee8c, + 0x1dd08, + 0x1ee86, + 0x1dd04, + 0x19940, + 0x1ccb0, + 0x1e65c, + 0x1bb40, + 0x19920, + // 450 + 0x1eedc, + 0x1e64e, + 0x1bb20, + 0x1dd98, + 0x1eece, + 0x1bb10, + 0x19908, + 0x1cc86, + 0x1bb08, + 0x1dd86, + // 460 + 0x19902, + 0x11140, + 0x188b0, + 0x1c45c, + 0x13340, + 0x11120, + 0x18898, + 0x1c44e, + 0x17740, + 0x13320, + // 470 + 0x19998, + 0x1ccce, + 0x17720, + 0x1bb98, + 0x1ddce, + 0x18886, + 0x17710, + 0x13308, + 0x19986, + 0x17708, + // 480 + 0x11102, + 0x111b0, + 0x188dc, + 0x133b0, + 0x11198, + 0x188ce, + 0x177b0, + 0x13398, + 0x199ce, + 0x17798, + // 490 + 0x1bbce, + 0x11186, + 0x13386, + 0x111dc, + 0x133dc, + 0x111ce, + 0x177dc, + 0x133ce, + 0x1dca0, + 0x1ee58, + // 500 + 0x1f72e, + 0x1dc90, + 0x1ee4c, + 0x1dc88, + 0x1ee46, + 0x1dc84, + 0x1dc82, + 0x198a0, + 0x1cc58, + 0x1e62e, + // 510 + 0x1b9a0, + 0x19890, + 0x1ee6e, + 0x1b990, + 0x1dccc, + 0x1cc46, + 0x1b988, + 0x19884, + 0x1b984, + 0x19882, + // 520 + 0x1b982, + 0x110a0, + 0x18858, + 0x1c42e, + 0x131a0, + 0x11090, + 0x1884c, + 0x173a0, + 0x13190, + 0x198cc, + // 530 + 0x18846, + 0x17390, + 0x1b9cc, + 0x11084, + 0x17388, + 0x13184, + 0x11082, + 0x13182, + 0x110d8, + 0x1886e, + // 540 + 0x131d8, + 0x110cc, + 0x173d8, + 0x131cc, + 0x110c6, + 0x173cc, + 0x131c6, + 0x110ee, + 0x173ee, + 0x1dc50, + // 550 + 0x1ee2c, + 0x1dc48, + 0x1ee26, + 0x1dc44, + 0x1dc42, + 0x19850, + 0x1cc2c, + 0x1b8d0, + 0x19848, + 0x1cc26, + // 560 + 0x1b8c8, + 0x1dc66, + 0x1b8c4, + 0x19842, + 0x1b8c2, + 0x11050, + 0x1882c, + 0x130d0, + 0x11048, + 0x18826, + // 570 + 0x171d0, + 0x130c8, + 0x19866, + 0x171c8, + 0x1b8e6, + 0x11042, + 0x171c4, + 0x130c2, + 0x171c2, + 0x130ec, + // 580 + 0x171ec, + 0x171e6, + 0x1ee16, + 0x1dc22, + 0x1cc16, + 0x19824, + 0x19822, + 0x11028, + 0x13068, + 0x170e8, + // 590 + 0x11022, + 0x13062, + 0x18560, + 0x10a40, + 0x18530, + 0x10a20, + 0x18518, + 0x1c28e, + 0x10a10, + 0x1850c, + // 600 + 0x10a08, + 0x18506, + 0x10b60, + 0x185b8, + 0x1c2de, + 0x10b30, + 0x1859c, + 0x10b18, + 0x1858e, + 0x10b0c, + // 610 + 0x10b06, + 0x10bb8, + 0x185de, + 0x10b9c, + 0x10b8e, + 0x10bde, + 0x18d40, + 0x1c6b0, + 0x1e35c, + 0x18d20, + // 620 + 0x1c698, + 0x18d10, + 0x1c68c, + 0x18d08, + 0x1c686, + 0x18d04, + 0x10940, + 0x184b0, + 0x1c25c, + 0x11b40, + // 630 + 0x10920, + 0x1c6dc, + 0x1c24e, + 0x11b20, + 0x18d98, + 0x1c6ce, + 0x11b10, + 0x10908, + 0x18486, + 0x11b08, + // 640 + 0x18d86, + 0x10902, + 0x109b0, + 0x184dc, + 0x11bb0, + 0x10998, + 0x184ce, + 0x11b98, + 0x18dce, + 0x11b8c, + // 650 + 0x10986, + 0x109dc, + 0x11bdc, + 0x109ce, + 0x11bce, + 0x1cea0, + 0x1e758, + 0x1f3ae, + 0x1ce90, + 0x1e74c, + // 660 + 0x1ce88, + 0x1e746, + 0x1ce84, + 0x1ce82, + 0x18ca0, + 0x1c658, + 0x19da0, + 0x18c90, + 0x1c64c, + 0x19d90, + // 670 + 0x1cecc, + 0x1c646, + 0x19d88, + 0x18c84, + 0x19d84, + 0x18c82, + 0x19d82, + 0x108a0, + 0x18458, + 0x119a0, + // 680 + 0x10890, + 0x1c66e, + 0x13ba0, + 0x11990, + 0x18ccc, + 0x18446, + 0x13b90, + 0x19dcc, + 0x10884, + 0x13b88, + // 690 + 0x11984, + 0x10882, + 0x11982, + 0x108d8, + 0x1846e, + 0x119d8, + 0x108cc, + 0x13bd8, + 0x119cc, + 0x108c6, + // 700 + 0x13bcc, + 0x119c6, + 0x108ee, + 0x119ee, + 0x13bee, + 0x1ef50, + 0x1f7ac, + 0x1ef48, + 0x1f7a6, + 0x1ef44, + // 710 + 0x1ef42, + 0x1ce50, + 0x1e72c, + 0x1ded0, + 0x1ef6c, + 0x1e726, + 0x1dec8, + 0x1ef66, + 0x1dec4, + 0x1ce42, + // 720 + 0x1dec2, + 0x18c50, + 0x1c62c, + 0x19cd0, + 0x18c48, + 0x1c626, + 0x1bdd0, + 0x19cc8, + 0x1ce66, + 0x1bdc8, + // 730 + 0x1dee6, + 0x18c42, + 0x1bdc4, + 0x19cc2, + 0x1bdc2, + 0x10850, + 0x1842c, + 0x118d0, + 0x10848, + 0x18426, + // 740 + 0x139d0, + 0x118c8, + 0x18c66, + 0x17bd0, + 0x139c8, + 0x19ce6, + 0x10842, + 0x17bc8, + 0x1bde6, + 0x118c2, + // 750 + 0x17bc4, + 0x1086c, + 0x118ec, + 0x10866, + 0x139ec, + 0x118e6, + 0x17bec, + 0x139e6, + 0x17be6, + 0x1ef28, + // 760 + 0x1f796, + 0x1ef24, + 0x1ef22, + 0x1ce28, + 0x1e716, + 0x1de68, + 0x1ef36, + 0x1de64, + 0x1ce22, + 0x1de62, + // 770 + 0x18c28, + 0x1c616, + 0x19c68, + 0x18c24, + 0x1bce8, + 0x19c64, + 0x18c22, + 0x1bce4, + 0x19c62, + 0x1bce2, + // 780 + 0x10828, + 0x18416, + 0x11868, + 0x18c36, + 0x138e8, + 0x11864, + 0x10822, + 0x179e8, + 0x138e4, + 0x11862, + // 790 + 0x179e4, + 0x138e2, + 0x179e2, + 0x11876, + 0x179f6, + 0x1ef12, + 0x1de34, + 0x1de32, + 0x19c34, + 0x1bc74, + // 800 + 0x1bc72, + 0x11834, + 0x13874, + 0x178f4, + 0x178f2, + 0x10540, + 0x10520, + 0x18298, + 0x10510, + 0x10508, + // 810 + 0x10504, + 0x105b0, + 0x10598, + 0x1058c, + 0x10586, + 0x105dc, + 0x105ce, + 0x186a0, + 0x18690, + 0x1c34c, + // 820 + 0x18688, + 0x1c346, + 0x18684, + 0x18682, + 0x104a0, + 0x18258, + 0x10da0, + 0x186d8, + 0x1824c, + 0x10d90, + // 830 + 0x186cc, + 0x10d88, + 0x186c6, + 0x10d84, + 0x10482, + 0x10d82, + 0x104d8, + 0x1826e, + 0x10dd8, + 0x186ee, + // 840 + 0x10dcc, + 0x104c6, + 0x10dc6, + 0x104ee, + 0x10dee, + 0x1c750, + 0x1c748, + 0x1c744, + 0x1c742, + 0x18650, + // 850 + 0x18ed0, + 0x1c76c, + 0x1c326, + 0x18ec8, + 0x1c766, + 0x18ec4, + 0x18642, + 0x18ec2, + 0x10450, + 0x10cd0, + // 860 + 0x10448, + 0x18226, + 0x11dd0, + 0x10cc8, + 0x10444, + 0x11dc8, + 0x10cc4, + 0x10442, + 0x11dc4, + 0x10cc2, + // 870 + 0x1046c, + 0x10cec, + 0x10466, + 0x11dec, + 0x10ce6, + 0x11de6, + 0x1e7a8, + 0x1e7a4, + 0x1e7a2, + 0x1c728, + // 880 + 0x1cf68, + 0x1e7b6, + 0x1cf64, + 0x1c722, + 0x1cf62, + 0x18628, + 0x1c316, + 0x18e68, + 0x1c736, + 0x19ee8, + // 890 + 0x18e64, + 0x18622, + 0x19ee4, + 0x18e62, + 0x19ee2, + 0x10428, + 0x18216, + 0x10c68, + 0x18636, + 0x11ce8, + // 900 + 0x10c64, + 0x10422, + 0x13de8, + 0x11ce4, + 0x10c62, + 0x13de4, + 0x11ce2, + 0x10436, + 0x10c76, + 0x11cf6, + // 910 + 0x13df6, + 0x1f7d4, + 0x1f7d2, + 0x1e794, + 0x1efb4, + 0x1e792, + 0x1efb2, + 0x1c714, + 0x1cf34, + 0x1c712, + // 920 + 0x1df74, + 0x1cf32, + 0x1df72, + 0x18614, + 0x18e34, + 0x18612, + 0x19e74, + 0x18e32, + 0x1bef4, + ], + [ + // cluster 3 ----------------------------------------------------------------------- + 0x1f560, + 0x1fab8, + 0x1ea40, + 0x1f530, + 0x1fa9c, + 0x1ea20, + 0x1f518, + 0x1fa8e, + 0x1ea10, + 0x1f50c, + // 10 + 0x1ea08, + 0x1f506, + 0x1ea04, + 0x1eb60, + 0x1f5b8, + 0x1fade, + 0x1d640, + 0x1eb30, + 0x1f59c, + 0x1d620, + // 20 + 0x1eb18, + 0x1f58e, + 0x1d610, + 0x1eb0c, + 0x1d608, + 0x1eb06, + 0x1d604, + 0x1d760, + 0x1ebb8, + 0x1f5de, + // 30 + 0x1ae40, + 0x1d730, + 0x1eb9c, + 0x1ae20, + 0x1d718, + 0x1eb8e, + 0x1ae10, + 0x1d70c, + 0x1ae08, + 0x1d706, + // 40 + 0x1ae04, + 0x1af60, + 0x1d7b8, + 0x1ebde, + 0x15e40, + 0x1af30, + 0x1d79c, + 0x15e20, + 0x1af18, + 0x1d78e, + // 50 + 0x15e10, + 0x1af0c, + 0x15e08, + 0x1af06, + 0x15f60, + 0x1afb8, + 0x1d7de, + 0x15f30, + 0x1af9c, + 0x15f18, + // 60 + 0x1af8e, + 0x15f0c, + 0x15fb8, + 0x1afde, + 0x15f9c, + 0x15f8e, + 0x1e940, + 0x1f4b0, + 0x1fa5c, + 0x1e920, + // 70 + 0x1f498, + 0x1fa4e, + 0x1e910, + 0x1f48c, + 0x1e908, + 0x1f486, + 0x1e904, + 0x1e902, + 0x1d340, + 0x1e9b0, + // 80 + 0x1f4dc, + 0x1d320, + 0x1e998, + 0x1f4ce, + 0x1d310, + 0x1e98c, + 0x1d308, + 0x1e986, + 0x1d304, + 0x1d302, + // 90 + 0x1a740, + 0x1d3b0, + 0x1e9dc, + 0x1a720, + 0x1d398, + 0x1e9ce, + 0x1a710, + 0x1d38c, + 0x1a708, + 0x1d386, + // 100 + 0x1a704, + 0x1a702, + 0x14f40, + 0x1a7b0, + 0x1d3dc, + 0x14f20, + 0x1a798, + 0x1d3ce, + 0x14f10, + 0x1a78c, + // 110 + 0x14f08, + 0x1a786, + 0x14f04, + 0x14fb0, + 0x1a7dc, + 0x14f98, + 0x1a7ce, + 0x14f8c, + 0x14f86, + 0x14fdc, + // 120 + 0x14fce, + 0x1e8a0, + 0x1f458, + 0x1fa2e, + 0x1e890, + 0x1f44c, + 0x1e888, + 0x1f446, + 0x1e884, + 0x1e882, + // 130 + 0x1d1a0, + 0x1e8d8, + 0x1f46e, + 0x1d190, + 0x1e8cc, + 0x1d188, + 0x1e8c6, + 0x1d184, + 0x1d182, + 0x1a3a0, + // 140 + 0x1d1d8, + 0x1e8ee, + 0x1a390, + 0x1d1cc, + 0x1a388, + 0x1d1c6, + 0x1a384, + 0x1a382, + 0x147a0, + 0x1a3d8, + // 150 + 0x1d1ee, + 0x14790, + 0x1a3cc, + 0x14788, + 0x1a3c6, + 0x14784, + 0x14782, + 0x147d8, + 0x1a3ee, + 0x147cc, + // 160 + 0x147c6, + 0x147ee, + 0x1e850, + 0x1f42c, + 0x1e848, + 0x1f426, + 0x1e844, + 0x1e842, + 0x1d0d0, + 0x1e86c, + // 170 + 0x1d0c8, + 0x1e866, + 0x1d0c4, + 0x1d0c2, + 0x1a1d0, + 0x1d0ec, + 0x1a1c8, + 0x1d0e6, + 0x1a1c4, + 0x1a1c2, + // 180 + 0x143d0, + 0x1a1ec, + 0x143c8, + 0x1a1e6, + 0x143c4, + 0x143c2, + 0x143ec, + 0x143e6, + 0x1e828, + 0x1f416, + // 190 + 0x1e824, + 0x1e822, + 0x1d068, + 0x1e836, + 0x1d064, + 0x1d062, + 0x1a0e8, + 0x1d076, + 0x1a0e4, + 0x1a0e2, + // 200 + 0x141e8, + 0x1a0f6, + 0x141e4, + 0x141e2, + 0x1e814, + 0x1e812, + 0x1d034, + 0x1d032, + 0x1a074, + 0x1a072, + // 210 + 0x1e540, + 0x1f2b0, + 0x1f95c, + 0x1e520, + 0x1f298, + 0x1f94e, + 0x1e510, + 0x1f28c, + 0x1e508, + 0x1f286, + // 220 + 0x1e504, + 0x1e502, + 0x1cb40, + 0x1e5b0, + 0x1f2dc, + 0x1cb20, + 0x1e598, + 0x1f2ce, + 0x1cb10, + 0x1e58c, + // 230 + 0x1cb08, + 0x1e586, + 0x1cb04, + 0x1cb02, + 0x19740, + 0x1cbb0, + 0x1e5dc, + 0x19720, + 0x1cb98, + 0x1e5ce, + // 240 + 0x19710, + 0x1cb8c, + 0x19708, + 0x1cb86, + 0x19704, + 0x19702, + 0x12f40, + 0x197b0, + 0x1cbdc, + 0x12f20, + // 250 + 0x19798, + 0x1cbce, + 0x12f10, + 0x1978c, + 0x12f08, + 0x19786, + 0x12f04, + 0x12fb0, + 0x197dc, + 0x12f98, + // 260 + 0x197ce, + 0x12f8c, + 0x12f86, + 0x12fdc, + 0x12fce, + 0x1f6a0, + 0x1fb58, + 0x16bf0, + 0x1f690, + 0x1fb4c, + // 270 + 0x169f8, + 0x1f688, + 0x1fb46, + 0x168fc, + 0x1f684, + 0x1f682, + 0x1e4a0, + 0x1f258, + 0x1f92e, + 0x1eda0, + // 280 + 0x1e490, + 0x1fb6e, + 0x1ed90, + 0x1f6cc, + 0x1f246, + 0x1ed88, + 0x1e484, + 0x1ed84, + 0x1e482, + 0x1ed82, + // 290 + 0x1c9a0, + 0x1e4d8, + 0x1f26e, + 0x1dba0, + 0x1c990, + 0x1e4cc, + 0x1db90, + 0x1edcc, + 0x1e4c6, + 0x1db88, + // 300 + 0x1c984, + 0x1db84, + 0x1c982, + 0x1db82, + 0x193a0, + 0x1c9d8, + 0x1e4ee, + 0x1b7a0, + 0x19390, + 0x1c9cc, + // 310 + 0x1b790, + 0x1dbcc, + 0x1c9c6, + 0x1b788, + 0x19384, + 0x1b784, + 0x19382, + 0x1b782, + 0x127a0, + 0x193d8, + // 320 + 0x1c9ee, + 0x16fa0, + 0x12790, + 0x193cc, + 0x16f90, + 0x1b7cc, + 0x193c6, + 0x16f88, + 0x12784, + 0x16f84, + // 330 + 0x12782, + 0x127d8, + 0x193ee, + 0x16fd8, + 0x127cc, + 0x16fcc, + 0x127c6, + 0x16fc6, + 0x127ee, + 0x1f650, + // 340 + 0x1fb2c, + 0x165f8, + 0x1f648, + 0x1fb26, + 0x164fc, + 0x1f644, + 0x1647e, + 0x1f642, + 0x1e450, + 0x1f22c, + // 350 + 0x1ecd0, + 0x1e448, + 0x1f226, + 0x1ecc8, + 0x1f666, + 0x1ecc4, + 0x1e442, + 0x1ecc2, + 0x1c8d0, + 0x1e46c, + // 360 + 0x1d9d0, + 0x1c8c8, + 0x1e466, + 0x1d9c8, + 0x1ece6, + 0x1d9c4, + 0x1c8c2, + 0x1d9c2, + 0x191d0, + 0x1c8ec, + // 370 + 0x1b3d0, + 0x191c8, + 0x1c8e6, + 0x1b3c8, + 0x1d9e6, + 0x1b3c4, + 0x191c2, + 0x1b3c2, + 0x123d0, + 0x191ec, + // 380 + 0x167d0, + 0x123c8, + 0x191e6, + 0x167c8, + 0x1b3e6, + 0x167c4, + 0x123c2, + 0x167c2, + 0x123ec, + 0x167ec, + // 390 + 0x123e6, + 0x167e6, + 0x1f628, + 0x1fb16, + 0x162fc, + 0x1f624, + 0x1627e, + 0x1f622, + 0x1e428, + 0x1f216, + // 400 + 0x1ec68, + 0x1f636, + 0x1ec64, + 0x1e422, + 0x1ec62, + 0x1c868, + 0x1e436, + 0x1d8e8, + 0x1c864, + 0x1d8e4, + // 410 + 0x1c862, + 0x1d8e2, + 0x190e8, + 0x1c876, + 0x1b1e8, + 0x1d8f6, + 0x1b1e4, + 0x190e2, + 0x1b1e2, + 0x121e8, + // 420 + 0x190f6, + 0x163e8, + 0x121e4, + 0x163e4, + 0x121e2, + 0x163e2, + 0x121f6, + 0x163f6, + 0x1f614, + 0x1617e, + // 430 + 0x1f612, + 0x1e414, + 0x1ec34, + 0x1e412, + 0x1ec32, + 0x1c834, + 0x1d874, + 0x1c832, + 0x1d872, + 0x19074, + // 440 + 0x1b0f4, + 0x19072, + 0x1b0f2, + 0x120f4, + 0x161f4, + 0x120f2, + 0x161f2, + 0x1f60a, + 0x1e40a, + 0x1ec1a, + // 450 + 0x1c81a, + 0x1d83a, + 0x1903a, + 0x1b07a, + 0x1e2a0, + 0x1f158, + 0x1f8ae, + 0x1e290, + 0x1f14c, + 0x1e288, + // 460 + 0x1f146, + 0x1e284, + 0x1e282, + 0x1c5a0, + 0x1e2d8, + 0x1f16e, + 0x1c590, + 0x1e2cc, + 0x1c588, + 0x1e2c6, + // 470 + 0x1c584, + 0x1c582, + 0x18ba0, + 0x1c5d8, + 0x1e2ee, + 0x18b90, + 0x1c5cc, + 0x18b88, + 0x1c5c6, + 0x18b84, + // 480 + 0x18b82, + 0x117a0, + 0x18bd8, + 0x1c5ee, + 0x11790, + 0x18bcc, + 0x11788, + 0x18bc6, + 0x11784, + 0x11782, + // 490 + 0x117d8, + 0x18bee, + 0x117cc, + 0x117c6, + 0x117ee, + 0x1f350, + 0x1f9ac, + 0x135f8, + 0x1f348, + 0x1f9a6, + // 500 + 0x134fc, + 0x1f344, + 0x1347e, + 0x1f342, + 0x1e250, + 0x1f12c, + 0x1e6d0, + 0x1e248, + 0x1f126, + 0x1e6c8, + // 510 + 0x1f366, + 0x1e6c4, + 0x1e242, + 0x1e6c2, + 0x1c4d0, + 0x1e26c, + 0x1cdd0, + 0x1c4c8, + 0x1e266, + 0x1cdc8, + // 520 + 0x1e6e6, + 0x1cdc4, + 0x1c4c2, + 0x1cdc2, + 0x189d0, + 0x1c4ec, + 0x19bd0, + 0x189c8, + 0x1c4e6, + 0x19bc8, + // 530 + 0x1cde6, + 0x19bc4, + 0x189c2, + 0x19bc2, + 0x113d0, + 0x189ec, + 0x137d0, + 0x113c8, + 0x189e6, + 0x137c8, + // 540 + 0x19be6, + 0x137c4, + 0x113c2, + 0x137c2, + 0x113ec, + 0x137ec, + 0x113e6, + 0x137e6, + 0x1fba8, + 0x175f0, + // 550 + 0x1bafc, + 0x1fba4, + 0x174f8, + 0x1ba7e, + 0x1fba2, + 0x1747c, + 0x1743e, + 0x1f328, + 0x1f996, + 0x132fc, + // 560 + 0x1f768, + 0x1fbb6, + 0x176fc, + 0x1327e, + 0x1f764, + 0x1f322, + 0x1767e, + 0x1f762, + 0x1e228, + 0x1f116, + // 570 + 0x1e668, + 0x1e224, + 0x1eee8, + 0x1f776, + 0x1e222, + 0x1eee4, + 0x1e662, + 0x1eee2, + 0x1c468, + 0x1e236, + // 580 + 0x1cce8, + 0x1c464, + 0x1dde8, + 0x1cce4, + 0x1c462, + 0x1dde4, + 0x1cce2, + 0x1dde2, + 0x188e8, + 0x1c476, + // 590 + 0x199e8, + 0x188e4, + 0x1bbe8, + 0x199e4, + 0x188e2, + 0x1bbe4, + 0x199e2, + 0x1bbe2, + 0x111e8, + 0x188f6, + // 600 + 0x133e8, + 0x111e4, + 0x177e8, + 0x133e4, + 0x111e2, + 0x177e4, + 0x133e2, + 0x177e2, + 0x111f6, + 0x133f6, + // 610 + 0x1fb94, + 0x172f8, + 0x1b97e, + 0x1fb92, + 0x1727c, + 0x1723e, + 0x1f314, + 0x1317e, + 0x1f734, + 0x1f312, + // 620 + 0x1737e, + 0x1f732, + 0x1e214, + 0x1e634, + 0x1e212, + 0x1ee74, + 0x1e632, + 0x1ee72, + 0x1c434, + 0x1cc74, + // 630 + 0x1c432, + 0x1dcf4, + 0x1cc72, + 0x1dcf2, + 0x18874, + 0x198f4, + 0x18872, + 0x1b9f4, + 0x198f2, + 0x1b9f2, + // 640 + 0x110f4, + 0x131f4, + 0x110f2, + 0x173f4, + 0x131f2, + 0x173f2, + 0x1fb8a, + 0x1717c, + 0x1713e, + 0x1f30a, + // 650 + 0x1f71a, + 0x1e20a, + 0x1e61a, + 0x1ee3a, + 0x1c41a, + 0x1cc3a, + 0x1dc7a, + 0x1883a, + 0x1987a, + 0x1b8fa, + // 660 + 0x1107a, + 0x130fa, + 0x171fa, + 0x170be, + 0x1e150, + 0x1f0ac, + 0x1e148, + 0x1f0a6, + 0x1e144, + 0x1e142, + // 670 + 0x1c2d0, + 0x1e16c, + 0x1c2c8, + 0x1e166, + 0x1c2c4, + 0x1c2c2, + 0x185d0, + 0x1c2ec, + 0x185c8, + 0x1c2e6, + // 680 + 0x185c4, + 0x185c2, + 0x10bd0, + 0x185ec, + 0x10bc8, + 0x185e6, + 0x10bc4, + 0x10bc2, + 0x10bec, + 0x10be6, + // 690 + 0x1f1a8, + 0x1f8d6, + 0x11afc, + 0x1f1a4, + 0x11a7e, + 0x1f1a2, + 0x1e128, + 0x1f096, + 0x1e368, + 0x1e124, + // 700 + 0x1e364, + 0x1e122, + 0x1e362, + 0x1c268, + 0x1e136, + 0x1c6e8, + 0x1c264, + 0x1c6e4, + 0x1c262, + 0x1c6e2, + // 710 + 0x184e8, + 0x1c276, + 0x18de8, + 0x184e4, + 0x18de4, + 0x184e2, + 0x18de2, + 0x109e8, + 0x184f6, + 0x11be8, + // 720 + 0x109e4, + 0x11be4, + 0x109e2, + 0x11be2, + 0x109f6, + 0x11bf6, + 0x1f9d4, + 0x13af8, + 0x19d7e, + 0x1f9d2, + // 730 + 0x13a7c, + 0x13a3e, + 0x1f194, + 0x1197e, + 0x1f3b4, + 0x1f192, + 0x13b7e, + 0x1f3b2, + 0x1e114, + 0x1e334, + // 740 + 0x1e112, + 0x1e774, + 0x1e332, + 0x1e772, + 0x1c234, + 0x1c674, + 0x1c232, + 0x1cef4, + 0x1c672, + 0x1cef2, + // 750 + 0x18474, + 0x18cf4, + 0x18472, + 0x19df4, + 0x18cf2, + 0x19df2, + 0x108f4, + 0x119f4, + 0x108f2, + 0x13bf4, + // 760 + 0x119f2, + 0x13bf2, + 0x17af0, + 0x1bd7c, + 0x17a78, + 0x1bd3e, + 0x17a3c, + 0x17a1e, + 0x1f9ca, + 0x1397c, + // 770 + 0x1fbda, + 0x17b7c, + 0x1393e, + 0x17b3e, + 0x1f18a, + 0x1f39a, + 0x1f7ba, + 0x1e10a, + 0x1e31a, + 0x1e73a, + // 780 + 0x1ef7a, + 0x1c21a, + 0x1c63a, + 0x1ce7a, + 0x1defa, + 0x1843a, + 0x18c7a, + 0x19cfa, + 0x1bdfa, + 0x1087a, + // 790 + 0x118fa, + 0x139fa, + 0x17978, + 0x1bcbe, + 0x1793c, + 0x1791e, + 0x138be, + 0x179be, + 0x178bc, + 0x1789e, + // 800 + 0x1785e, + 0x1e0a8, + 0x1e0a4, + 0x1e0a2, + 0x1c168, + 0x1e0b6, + 0x1c164, + 0x1c162, + 0x182e8, + 0x1c176, + // 810 + 0x182e4, + 0x182e2, + 0x105e8, + 0x182f6, + 0x105e4, + 0x105e2, + 0x105f6, + 0x1f0d4, + 0x10d7e, + 0x1f0d2, + // 820 + 0x1e094, + 0x1e1b4, + 0x1e092, + 0x1e1b2, + 0x1c134, + 0x1c374, + 0x1c132, + 0x1c372, + 0x18274, + 0x186f4, + // 830 + 0x18272, + 0x186f2, + 0x104f4, + 0x10df4, + 0x104f2, + 0x10df2, + 0x1f8ea, + 0x11d7c, + 0x11d3e, + 0x1f0ca, + // 840 + 0x1f1da, + 0x1e08a, + 0x1e19a, + 0x1e3ba, + 0x1c11a, + 0x1c33a, + 0x1c77a, + 0x1823a, + 0x1867a, + 0x18efa, + // 850 + 0x1047a, + 0x10cfa, + 0x11dfa, + 0x13d78, + 0x19ebe, + 0x13d3c, + 0x13d1e, + 0x11cbe, + 0x13dbe, + 0x17d70, + // 860 + 0x1bebc, + 0x17d38, + 0x1be9e, + 0x17d1c, + 0x17d0e, + 0x13cbc, + 0x17dbc, + 0x13c9e, + 0x17d9e, + 0x17cb8, + // 870 + 0x1be5e, + 0x17c9c, + 0x17c8e, + 0x13c5e, + 0x17cde, + 0x17c5c, + 0x17c4e, + 0x17c2e, + 0x1c0b4, + 0x1c0b2, + // 880 + 0x18174, + 0x18172, + 0x102f4, + 0x102f2, + 0x1e0da, + 0x1c09a, + 0x1c1ba, + 0x1813a, + 0x1837a, + 0x1027a, + // 890 + 0x106fa, + 0x10ebe, + 0x11ebc, + 0x11e9e, + 0x13eb8, + 0x19f5e, + 0x13e9c, + 0x13e8e, + 0x11e5e, + 0x13ede, + // 900 + 0x17eb0, + 0x1bf5c, + 0x17e98, + 0x1bf4e, + 0x17e8c, + 0x17e86, + 0x13e5c, + 0x17edc, + 0x13e4e, + 0x17ece, + // 910 + 0x17e58, + 0x1bf2e, + 0x17e4c, + 0x17e46, + 0x13e2e, + 0x17e6e, + 0x17e2c, + 0x17e26, + 0x10f5e, + 0x11f5c, + // 920 + 0x11f4e, + 0x13f58, + 0x19fae, + 0x13f4c, + 0x13f46, + 0x11f2e, + 0x13f6e, + 0x13f2c, + 0x13f26, + ], + [ + // cluster 6 ----------------------------------------------------------------------- + 0x1abe0, + 0x1d5f8, + 0x153c0, + 0x1a9f0, + 0x1d4fc, + 0x151e0, + 0x1a8f8, + 0x1d47e, + 0x150f0, + 0x1a87c, + // 10 + 0x15078, + 0x1fad0, + 0x15be0, + 0x1adf8, + 0x1fac8, + 0x159f0, + 0x1acfc, + 0x1fac4, + 0x158f8, + 0x1ac7e, + // 20 + 0x1fac2, + 0x1587c, + 0x1f5d0, + 0x1faec, + 0x15df8, + 0x1f5c8, + 0x1fae6, + 0x15cfc, + 0x1f5c4, + 0x15c7e, + // 30 + 0x1f5c2, + 0x1ebd0, + 0x1f5ec, + 0x1ebc8, + 0x1f5e6, + 0x1ebc4, + 0x1ebc2, + 0x1d7d0, + 0x1ebec, + 0x1d7c8, + // 40 + 0x1ebe6, + 0x1d7c4, + 0x1d7c2, + 0x1afd0, + 0x1d7ec, + 0x1afc8, + 0x1d7e6, + 0x1afc4, + 0x14bc0, + 0x1a5f0, + // 50 + 0x1d2fc, + 0x149e0, + 0x1a4f8, + 0x1d27e, + 0x148f0, + 0x1a47c, + 0x14878, + 0x1a43e, + 0x1483c, + 0x1fa68, + // 60 + 0x14df0, + 0x1a6fc, + 0x1fa64, + 0x14cf8, + 0x1a67e, + 0x1fa62, + 0x14c7c, + 0x14c3e, + 0x1f4e8, + 0x1fa76, + // 70 + 0x14efc, + 0x1f4e4, + 0x14e7e, + 0x1f4e2, + 0x1e9e8, + 0x1f4f6, + 0x1e9e4, + 0x1e9e2, + 0x1d3e8, + 0x1e9f6, + // 80 + 0x1d3e4, + 0x1d3e2, + 0x1a7e8, + 0x1d3f6, + 0x1a7e4, + 0x1a7e2, + 0x145e0, + 0x1a2f8, + 0x1d17e, + 0x144f0, + // 90 + 0x1a27c, + 0x14478, + 0x1a23e, + 0x1443c, + 0x1441e, + 0x1fa34, + 0x146f8, + 0x1a37e, + 0x1fa32, + 0x1467c, + // 100 + 0x1463e, + 0x1f474, + 0x1477e, + 0x1f472, + 0x1e8f4, + 0x1e8f2, + 0x1d1f4, + 0x1d1f2, + 0x1a3f4, + 0x1a3f2, + // 110 + 0x142f0, + 0x1a17c, + 0x14278, + 0x1a13e, + 0x1423c, + 0x1421e, + 0x1fa1a, + 0x1437c, + 0x1433e, + 0x1f43a, + // 120 + 0x1e87a, + 0x1d0fa, + 0x14178, + 0x1a0be, + 0x1413c, + 0x1411e, + 0x141be, + 0x140bc, + 0x1409e, + 0x12bc0, + // 130 + 0x195f0, + 0x1cafc, + 0x129e0, + 0x194f8, + 0x1ca7e, + 0x128f0, + 0x1947c, + 0x12878, + 0x1943e, + 0x1283c, + // 140 + 0x1f968, + 0x12df0, + 0x196fc, + 0x1f964, + 0x12cf8, + 0x1967e, + 0x1f962, + 0x12c7c, + 0x12c3e, + 0x1f2e8, + // 150 + 0x1f976, + 0x12efc, + 0x1f2e4, + 0x12e7e, + 0x1f2e2, + 0x1e5e8, + 0x1f2f6, + 0x1e5e4, + 0x1e5e2, + 0x1cbe8, + // 160 + 0x1e5f6, + 0x1cbe4, + 0x1cbe2, + 0x197e8, + 0x1cbf6, + 0x197e4, + 0x197e2, + 0x1b5e0, + 0x1daf8, + 0x1ed7e, + // 170 + 0x169c0, + 0x1b4f0, + 0x1da7c, + 0x168e0, + 0x1b478, + 0x1da3e, + 0x16870, + 0x1b43c, + 0x16838, + 0x1b41e, + // 180 + 0x1681c, + 0x125e0, + 0x192f8, + 0x1c97e, + 0x16de0, + 0x124f0, + 0x1927c, + 0x16cf0, + 0x1b67c, + 0x1923e, + // 190 + 0x16c78, + 0x1243c, + 0x16c3c, + 0x1241e, + 0x16c1e, + 0x1f934, + 0x126f8, + 0x1937e, + 0x1fb74, + 0x1f932, + // 200 + 0x16ef8, + 0x1267c, + 0x1fb72, + 0x16e7c, + 0x1263e, + 0x16e3e, + 0x1f274, + 0x1277e, + 0x1f6f4, + 0x1f272, + // 210 + 0x16f7e, + 0x1f6f2, + 0x1e4f4, + 0x1edf4, + 0x1e4f2, + 0x1edf2, + 0x1c9f4, + 0x1dbf4, + 0x1c9f2, + 0x1dbf2, + // 220 + 0x193f4, + 0x193f2, + 0x165c0, + 0x1b2f0, + 0x1d97c, + 0x164e0, + 0x1b278, + 0x1d93e, + 0x16470, + 0x1b23c, + // 230 + 0x16438, + 0x1b21e, + 0x1641c, + 0x1640e, + 0x122f0, + 0x1917c, + 0x166f0, + 0x12278, + 0x1913e, + 0x16678, + // 240 + 0x1b33e, + 0x1663c, + 0x1221e, + 0x1661e, + 0x1f91a, + 0x1237c, + 0x1fb3a, + 0x1677c, + 0x1233e, + 0x1673e, + // 250 + 0x1f23a, + 0x1f67a, + 0x1e47a, + 0x1ecfa, + 0x1c8fa, + 0x1d9fa, + 0x191fa, + 0x162e0, + 0x1b178, + 0x1d8be, + // 260 + 0x16270, + 0x1b13c, + 0x16238, + 0x1b11e, + 0x1621c, + 0x1620e, + 0x12178, + 0x190be, + 0x16378, + 0x1213c, + // 270 + 0x1633c, + 0x1211e, + 0x1631e, + 0x121be, + 0x163be, + 0x16170, + 0x1b0bc, + 0x16138, + 0x1b09e, + 0x1611c, + // 280 + 0x1610e, + 0x120bc, + 0x161bc, + 0x1209e, + 0x1619e, + 0x160b8, + 0x1b05e, + 0x1609c, + 0x1608e, + 0x1205e, + // 290 + 0x160de, + 0x1605c, + 0x1604e, + 0x115e0, + 0x18af8, + 0x1c57e, + 0x114f0, + 0x18a7c, + 0x11478, + 0x18a3e, + // 300 + 0x1143c, + 0x1141e, + 0x1f8b4, + 0x116f8, + 0x18b7e, + 0x1f8b2, + 0x1167c, + 0x1163e, + 0x1f174, + 0x1177e, + // 310 + 0x1f172, + 0x1e2f4, + 0x1e2f2, + 0x1c5f4, + 0x1c5f2, + 0x18bf4, + 0x18bf2, + 0x135c0, + 0x19af0, + 0x1cd7c, + // 320 + 0x134e0, + 0x19a78, + 0x1cd3e, + 0x13470, + 0x19a3c, + 0x13438, + 0x19a1e, + 0x1341c, + 0x1340e, + 0x112f0, + // 330 + 0x1897c, + 0x136f0, + 0x11278, + 0x1893e, + 0x13678, + 0x19b3e, + 0x1363c, + 0x1121e, + 0x1361e, + 0x1f89a, + // 340 + 0x1137c, + 0x1f9ba, + 0x1377c, + 0x1133e, + 0x1373e, + 0x1f13a, + 0x1f37a, + 0x1e27a, + 0x1e6fa, + 0x1c4fa, + // 350 + 0x1cdfa, + 0x189fa, + 0x1bae0, + 0x1dd78, + 0x1eebe, + 0x174c0, + 0x1ba70, + 0x1dd3c, + 0x17460, + 0x1ba38, + // 360 + 0x1dd1e, + 0x17430, + 0x1ba1c, + 0x17418, + 0x1ba0e, + 0x1740c, + 0x132e0, + 0x19978, + 0x1ccbe, + 0x176e0, + // 370 + 0x13270, + 0x1993c, + 0x17670, + 0x1bb3c, + 0x1991e, + 0x17638, + 0x1321c, + 0x1761c, + 0x1320e, + 0x1760e, + // 380 + 0x11178, + 0x188be, + 0x13378, + 0x1113c, + 0x17778, + 0x1333c, + 0x1111e, + 0x1773c, + 0x1331e, + 0x1771e, + // 390 + 0x111be, + 0x133be, + 0x177be, + 0x172c0, + 0x1b970, + 0x1dcbc, + 0x17260, + 0x1b938, + 0x1dc9e, + 0x17230, + // 400 + 0x1b91c, + 0x17218, + 0x1b90e, + 0x1720c, + 0x17206, + 0x13170, + 0x198bc, + 0x17370, + 0x13138, + 0x1989e, + // 410 + 0x17338, + 0x1b99e, + 0x1731c, + 0x1310e, + 0x1730e, + 0x110bc, + 0x131bc, + 0x1109e, + 0x173bc, + 0x1319e, + // 420 + 0x1739e, + 0x17160, + 0x1b8b8, + 0x1dc5e, + 0x17130, + 0x1b89c, + 0x17118, + 0x1b88e, + 0x1710c, + 0x17106, + // 430 + 0x130b8, + 0x1985e, + 0x171b8, + 0x1309c, + 0x1719c, + 0x1308e, + 0x1718e, + 0x1105e, + 0x130de, + 0x171de, + // 440 + 0x170b0, + 0x1b85c, + 0x17098, + 0x1b84e, + 0x1708c, + 0x17086, + 0x1305c, + 0x170dc, + 0x1304e, + 0x170ce, + // 450 + 0x17058, + 0x1b82e, + 0x1704c, + 0x17046, + 0x1302e, + 0x1706e, + 0x1702c, + 0x17026, + 0x10af0, + 0x1857c, + // 460 + 0x10a78, + 0x1853e, + 0x10a3c, + 0x10a1e, + 0x10b7c, + 0x10b3e, + 0x1f0ba, + 0x1e17a, + 0x1c2fa, + 0x185fa, + // 470 + 0x11ae0, + 0x18d78, + 0x1c6be, + 0x11a70, + 0x18d3c, + 0x11a38, + 0x18d1e, + 0x11a1c, + 0x11a0e, + 0x10978, + // 480 + 0x184be, + 0x11b78, + 0x1093c, + 0x11b3c, + 0x1091e, + 0x11b1e, + 0x109be, + 0x11bbe, + 0x13ac0, + 0x19d70, + // 490 + 0x1cebc, + 0x13a60, + 0x19d38, + 0x1ce9e, + 0x13a30, + 0x19d1c, + 0x13a18, + 0x19d0e, + 0x13a0c, + 0x13a06, + // 500 + 0x11970, + 0x18cbc, + 0x13b70, + 0x11938, + 0x18c9e, + 0x13b38, + 0x1191c, + 0x13b1c, + 0x1190e, + 0x13b0e, + // 510 + 0x108bc, + 0x119bc, + 0x1089e, + 0x13bbc, + 0x1199e, + 0x13b9e, + 0x1bd60, + 0x1deb8, + 0x1ef5e, + 0x17a40, + // 520 + 0x1bd30, + 0x1de9c, + 0x17a20, + 0x1bd18, + 0x1de8e, + 0x17a10, + 0x1bd0c, + 0x17a08, + 0x1bd06, + 0x17a04, + // 530 + 0x13960, + 0x19cb8, + 0x1ce5e, + 0x17b60, + 0x13930, + 0x19c9c, + 0x17b30, + 0x1bd9c, + 0x19c8e, + 0x17b18, + // 540 + 0x1390c, + 0x17b0c, + 0x13906, + 0x17b06, + 0x118b8, + 0x18c5e, + 0x139b8, + 0x1189c, + 0x17bb8, + 0x1399c, + // 550 + 0x1188e, + 0x17b9c, + 0x1398e, + 0x17b8e, + 0x1085e, + 0x118de, + 0x139de, + 0x17bde, + 0x17940, + 0x1bcb0, + // 560 + 0x1de5c, + 0x17920, + 0x1bc98, + 0x1de4e, + 0x17910, + 0x1bc8c, + 0x17908, + 0x1bc86, + 0x17904, + 0x17902, + // 570 + 0x138b0, + 0x19c5c, + 0x179b0, + 0x13898, + 0x19c4e, + 0x17998, + 0x1bcce, + 0x1798c, + 0x13886, + 0x17986, + // 580 + 0x1185c, + 0x138dc, + 0x1184e, + 0x179dc, + 0x138ce, + 0x179ce, + 0x178a0, + 0x1bc58, + 0x1de2e, + 0x17890, + // 590 + 0x1bc4c, + 0x17888, + 0x1bc46, + 0x17884, + 0x17882, + 0x13858, + 0x19c2e, + 0x178d8, + 0x1384c, + 0x178cc, + // 600 + 0x13846, + 0x178c6, + 0x1182e, + 0x1386e, + 0x178ee, + 0x17850, + 0x1bc2c, + 0x17848, + 0x1bc26, + 0x17844, + // 610 + 0x17842, + 0x1382c, + 0x1786c, + 0x13826, + 0x17866, + 0x17828, + 0x1bc16, + 0x17824, + 0x17822, + 0x13816, + // 620 + 0x17836, + 0x10578, + 0x182be, + 0x1053c, + 0x1051e, + 0x105be, + 0x10d70, + 0x186bc, + 0x10d38, + 0x1869e, + // 630 + 0x10d1c, + 0x10d0e, + 0x104bc, + 0x10dbc, + 0x1049e, + 0x10d9e, + 0x11d60, + 0x18eb8, + 0x1c75e, + 0x11d30, + // 640 + 0x18e9c, + 0x11d18, + 0x18e8e, + 0x11d0c, + 0x11d06, + 0x10cb8, + 0x1865e, + 0x11db8, + 0x10c9c, + 0x11d9c, + // 650 + 0x10c8e, + 0x11d8e, + 0x1045e, + 0x10cde, + 0x11dde, + 0x13d40, + 0x19eb0, + 0x1cf5c, + 0x13d20, + 0x19e98, + // 660 + 0x1cf4e, + 0x13d10, + 0x19e8c, + 0x13d08, + 0x19e86, + 0x13d04, + 0x13d02, + 0x11cb0, + 0x18e5c, + 0x13db0, + // 670 + 0x11c98, + 0x18e4e, + 0x13d98, + 0x19ece, + 0x13d8c, + 0x11c86, + 0x13d86, + 0x10c5c, + 0x11cdc, + 0x10c4e, + // 680 + 0x13ddc, + 0x11cce, + 0x13dce, + 0x1bea0, + 0x1df58, + 0x1efae, + 0x1be90, + 0x1df4c, + 0x1be88, + 0x1df46, + // 690 + 0x1be84, + 0x1be82, + 0x13ca0, + 0x19e58, + 0x1cf2e, + 0x17da0, + 0x13c90, + 0x19e4c, + 0x17d90, + 0x1becc, + // 700 + 0x19e46, + 0x17d88, + 0x13c84, + 0x17d84, + 0x13c82, + 0x17d82, + 0x11c58, + 0x18e2e, + 0x13cd8, + 0x11c4c, + // 710 + 0x17dd8, + 0x13ccc, + 0x11c46, + 0x17dcc, + 0x13cc6, + 0x17dc6, + 0x10c2e, + 0x11c6e, + 0x13cee, + 0x17dee, + // 720 + 0x1be50, + 0x1df2c, + 0x1be48, + 0x1df26, + 0x1be44, + 0x1be42, + 0x13c50, + 0x19e2c, + 0x17cd0, + 0x13c48, + // 730 + 0x19e26, + 0x17cc8, + 0x1be66, + 0x17cc4, + 0x13c42, + 0x17cc2, + 0x11c2c, + 0x13c6c, + 0x11c26, + 0x17cec, + // 740 + 0x13c66, + 0x17ce6, + 0x1be28, + 0x1df16, + 0x1be24, + 0x1be22, + 0x13c28, + 0x19e16, + 0x17c68, + 0x13c24, + // 750 + 0x17c64, + 0x13c22, + 0x17c62, + 0x11c16, + 0x13c36, + 0x17c76, + 0x1be14, + 0x1be12, + 0x13c14, + 0x17c34, + // 760 + 0x13c12, + 0x17c32, + 0x102bc, + 0x1029e, + 0x106b8, + 0x1835e, + 0x1069c, + 0x1068e, + 0x1025e, + 0x106de, + // 770 + 0x10eb0, + 0x1875c, + 0x10e98, + 0x1874e, + 0x10e8c, + 0x10e86, + 0x1065c, + 0x10edc, + 0x1064e, + 0x10ece, + // 780 + 0x11ea0, + 0x18f58, + 0x1c7ae, + 0x11e90, + 0x18f4c, + 0x11e88, + 0x18f46, + 0x11e84, + 0x11e82, + 0x10e58, + // 790 + 0x1872e, + 0x11ed8, + 0x18f6e, + 0x11ecc, + 0x10e46, + 0x11ec6, + 0x1062e, + 0x10e6e, + 0x11eee, + 0x19f50, + // 800 + 0x1cfac, + 0x19f48, + 0x1cfa6, + 0x19f44, + 0x19f42, + 0x11e50, + 0x18f2c, + 0x13ed0, + 0x19f6c, + 0x18f26, + // 810 + 0x13ec8, + 0x11e44, + 0x13ec4, + 0x11e42, + 0x13ec2, + 0x10e2c, + 0x11e6c, + 0x10e26, + 0x13eec, + 0x11e66, + // 820 + 0x13ee6, + 0x1dfa8, + 0x1efd6, + 0x1dfa4, + 0x1dfa2, + 0x19f28, + 0x1cf96, + 0x1bf68, + 0x19f24, + 0x1bf64, + // 830 + 0x19f22, + 0x1bf62, + 0x11e28, + 0x18f16, + 0x13e68, + 0x11e24, + 0x17ee8, + 0x13e64, + 0x11e22, + 0x17ee4, + // 840 + 0x13e62, + 0x17ee2, + 0x10e16, + 0x11e36, + 0x13e76, + 0x17ef6, + 0x1df94, + 0x1df92, + 0x19f14, + 0x1bf34, + // 850 + 0x19f12, + 0x1bf32, + 0x11e14, + 0x13e34, + 0x11e12, + 0x17e74, + 0x13e32, + 0x17e72, + 0x1df8a, + 0x19f0a, + // 860 + 0x1bf1a, + 0x11e0a, + 0x13e1a, + 0x17e3a, + 0x1035c, + 0x1034e, + 0x10758, + 0x183ae, + 0x1074c, + 0x10746, + // 870 + 0x1032e, + 0x1076e, + 0x10f50, + 0x187ac, + 0x10f48, + 0x187a6, + 0x10f44, + 0x10f42, + 0x1072c, + 0x10f6c, + // 880 + 0x10726, + 0x10f66, + 0x18fa8, + 0x1c7d6, + 0x18fa4, + 0x18fa2, + 0x10f28, + 0x18796, + 0x11f68, + 0x18fb6, + // 890 + 0x11f64, + 0x10f22, + 0x11f62, + 0x10716, + 0x10f36, + 0x11f76, + 0x1cfd4, + 0x1cfd2, + 0x18f94, + 0x19fb4, + // 900 + 0x18f92, + 0x19fb2, + 0x10f14, + 0x11f34, + 0x10f12, + 0x13f74, + 0x11f32, + 0x13f72, + 0x1cfca, + 0x18f8a, + // 910 + 0x19f9a, + 0x10f0a, + 0x11f1a, + 0x13f3a, + 0x103ac, + 0x103a6, + 0x107a8, + 0x183d6, + 0x107a4, + 0x107a2, + // 920 + 0x10396, + 0x107b6, + 0x187d4, + 0x187d2, + 0x10794, + 0x10fb4, + 0x10792, + 0x10fb2, + 0x1c7ea, + ], + ]; + + /** + * Array of factors of the Reed-Solomon polynomial equations used for error correction; + * One sub array for each correction level (0-8). + * + * @var array> + */ + public const RS_FACTORS = [ + [ + // ECL 0 (2 factors) ------------------------------------------------------------------------------- + 0x01b, + 0x395, + ], + [ + // ECL 1 (4 factors) ------------------------------------------------------------------------------- + 0x20a, + 0x238, + 0x2d3, + 0x329, + ], + [ + // ECL 2 (8 factors) ------------------------------------------------------------------------------- + 0x0ed, + 0x134, + 0x1b4, + 0x11c, + 0x286, + 0x28d, + 0x1ac, + 0x17b, + ], + [ + // ECL 3 (16 factors) ------------------------------------------------------------------------------ + 0x112, + 0x232, + 0x0e8, + 0x2f3, + 0x257, + 0x20c, + 0x321, + 0x084, + 0x127, + 0x074, + 0x1ba, + 0x1ac, + 0x127, + 0x02a, + 0x0b0, + 0x041, + ], + [ + // ECL 4 (32 factors) ------------------------------------------------------------------------------ + 0x169, + 0x23f, + 0x39a, + 0x20d, + 0x0b0, + 0x24a, + 0x280, + 0x141, + 0x218, + 0x2e6, + 0x2a5, + 0x2e6, + 0x2af, + 0x11c, + 0x0c1, + 0x205, + // 16 + 0x111, + 0x1ee, + 0x107, + 0x093, + 0x251, + 0x320, + 0x23b, + 0x140, + 0x323, + 0x085, + 0x0e7, + 0x186, + 0x2ad, + 0x14a, + 0x03f, + 0x19a, + ], + [ + // ECL 5 (64 factors) ------------------------------------------------------------------------------ + 0x21b, + 0x1a6, + 0x006, + 0x05d, + 0x35e, + 0x303, + 0x1c5, + 0x06a, + 0x262, + 0x11f, + 0x06b, + 0x1f9, + 0x2dd, + 0x36d, + 0x17d, + 0x264, + // 16 + 0x2d3, + 0x1dc, + 0x1ce, + 0x0ac, + 0x1ae, + 0x261, + 0x35a, + 0x336, + 0x21f, + 0x178, + 0x1ff, + 0x190, + 0x2a0, + 0x2fa, + 0x11b, + 0x0b8, + // 32 + 0x1b8, + 0x023, + 0x207, + 0x01f, + 0x1cc, + 0x252, + 0x0e1, + 0x217, + 0x205, + 0x160, + 0x25d, + 0x09e, + 0x28b, + 0x0c9, + 0x1e8, + 0x1f6, + // 48 + 0x288, + 0x2dd, + 0x2cd, + 0x053, + 0x194, + 0x061, + 0x118, + 0x303, + 0x348, + 0x275, + 0x004, + 0x17d, + 0x34b, + 0x26f, + 0x108, + 0x21f, + ], + [ + // ECL 6 (128 factors) ----------------------------------------------------------------------------- + 0x209, + 0x136, + 0x360, + 0x223, + 0x35a, + 0x244, + 0x128, + 0x17b, + 0x035, + 0x30b, + 0x381, + 0x1bc, + 0x190, + 0x39d, + 0x2ed, + 0x19f, + // 16 + 0x336, + 0x05d, + 0x0d9, + 0x0d0, + 0x3a0, + 0x0f4, + 0x247, + 0x26c, + 0x0f6, + 0x094, + 0x1bf, + 0x277, + 0x124, + 0x38c, + 0x1ea, + 0x2c0, + // 32 + 0x204, + 0x102, + 0x1c9, + 0x38b, + 0x252, + 0x2d3, + 0x2a2, + 0x124, + 0x110, + 0x060, + 0x2ac, + 0x1b0, + 0x2ae, + 0x25e, + 0x35c, + 0x239, + // 48 + 0x0c1, + 0x0db, + 0x081, + 0x0ba, + 0x0ec, + 0x11f, + 0x0c0, + 0x307, + 0x116, + 0x0ad, + 0x028, + 0x17b, + 0x2c8, + 0x1cf, + 0x286, + 0x308, + // 64 + 0x0ab, + 0x1eb, + 0x129, + 0x2fb, + 0x09c, + 0x2dc, + 0x05f, + 0x10e, + 0x1bf, + 0x05a, + 0x1fb, + 0x030, + 0x0e4, + 0x335, + 0x328, + 0x382, + // 80 + 0x310, + 0x297, + 0x273, + 0x17a, + 0x17e, + 0x106, + 0x17c, + 0x25a, + 0x2f2, + 0x150, + 0x059, + 0x266, + 0x057, + 0x1b0, + 0x29e, + 0x268, + // 96 + 0x09d, + 0x176, + 0x0f2, + 0x2d6, + 0x258, + 0x10d, + 0x177, + 0x382, + 0x34d, + 0x1c6, + 0x162, + 0x082, + 0x32e, + 0x24b, + 0x324, + 0x022, + // 112 + 0x0d3, + 0x14a, + 0x21b, + 0x129, + 0x33b, + 0x361, + 0x025, + 0x205, + 0x342, + 0x13b, + 0x226, + 0x056, + 0x321, + 0x004, + 0x06c, + 0x21b, + ], + [ + // ECL 7 (256 factors) ----------------------------------------------------------------------------- + 0x20c, + 0x37e, + 0x04b, + 0x2fe, + 0x372, + 0x359, + 0x04a, + 0x0cc, + 0x052, + 0x24a, + 0x2c4, + 0x0fa, + 0x389, + 0x312, + 0x08a, + 0x2d0, + // 16 + 0x35a, + 0x0c2, + 0x137, + 0x391, + 0x113, + 0x0be, + 0x177, + 0x352, + 0x1b6, + 0x2dd, + 0x0c2, + 0x118, + 0x0c9, + 0x118, + 0x33c, + 0x2f5, + // 32 + 0x2c6, + 0x32e, + 0x397, + 0x059, + 0x044, + 0x239, + 0x00b, + 0x0cc, + 0x31c, + 0x25d, + 0x21c, + 0x391, + 0x321, + 0x2bc, + 0x31f, + 0x089, + // 48 + 0x1b7, + 0x1a2, + 0x250, + 0x29c, + 0x161, + 0x35b, + 0x172, + 0x2b6, + 0x145, + 0x0f0, + 0x0d8, + 0x101, + 0x11c, + 0x225, + 0x0d1, + 0x374, + // 64 + 0x13b, + 0x046, + 0x149, + 0x319, + 0x1ea, + 0x112, + 0x36d, + 0x0a2, + 0x2ed, + 0x32c, + 0x2ac, + 0x1cd, + 0x14e, + 0x178, + 0x351, + 0x209, + // 80 + 0x133, + 0x123, + 0x323, + 0x2c8, + 0x013, + 0x166, + 0x18f, + 0x38c, + 0x067, + 0x1ff, + 0x033, + 0x008, + 0x205, + 0x0e1, + 0x121, + 0x1d6, + // 96 + 0x27d, + 0x2db, + 0x042, + 0x0ff, + 0x395, + 0x10d, + 0x1cf, + 0x33e, + 0x2da, + 0x1b1, + 0x350, + 0x249, + 0x088, + 0x21a, + 0x38a, + 0x05a, + // 112 + 0x002, + 0x122, + 0x2e7, + 0x0c7, + 0x28f, + 0x387, + 0x149, + 0x031, + 0x322, + 0x244, + 0x163, + 0x24c, + 0x0bc, + 0x1ce, + 0x00a, + 0x086, + // 128 + 0x274, + 0x140, + 0x1df, + 0x082, + 0x2e3, + 0x047, + 0x107, + 0x13e, + 0x176, + 0x259, + 0x0c0, + 0x25d, + 0x08e, + 0x2a1, + 0x2af, + 0x0ea, + // 144 + 0x2d2, + 0x180, + 0x0b1, + 0x2f0, + 0x25f, + 0x280, + 0x1c7, + 0x0c1, + 0x2b1, + 0x2c3, + 0x325, + 0x281, + 0x030, + 0x03c, + 0x2dc, + 0x26d, + // 160 + 0x37f, + 0x220, + 0x105, + 0x354, + 0x28f, + 0x135, + 0x2b9, + 0x2f3, + 0x2f4, + 0x03c, + 0x0e7, + 0x305, + 0x1b2, + 0x1a5, + 0x2d6, + 0x210, + // 176 + 0x1f7, + 0x076, + 0x031, + 0x31b, + 0x020, + 0x090, + 0x1f4, + 0x0ee, + 0x344, + 0x18a, + 0x118, + 0x236, + 0x13f, + 0x009, + 0x287, + 0x226, + // 192 + 0x049, + 0x392, + 0x156, + 0x07e, + 0x020, + 0x2a9, + 0x14b, + 0x318, + 0x26c, + 0x03c, + 0x261, + 0x1b9, + 0x0b4, + 0x317, + 0x37d, + 0x2f2, + // 208 + 0x25d, + 0x17f, + 0x0e4, + 0x2ed, + 0x2f8, + 0x0d5, + 0x036, + 0x129, + 0x086, + 0x036, + 0x342, + 0x12b, + 0x39a, + 0x0bf, + 0x38e, + 0x214, + // 224 + 0x261, + 0x33d, + 0x0bd, + 0x014, + 0x0a7, + 0x01d, + 0x368, + 0x1c1, + 0x053, + 0x192, + 0x029, + 0x290, + 0x1f9, + 0x243, + 0x1e1, + 0x0ad, + // 240 + 0x194, + 0x0fb, + 0x2b0, + 0x05f, + 0x1f1, + 0x22b, + 0x282, + 0x21f, + 0x133, + 0x09f, + 0x39c, + 0x22e, + 0x288, + 0x037, + 0x1f1, + 0x00a, + ], + [ + // ECL 8 (512 factors) ----------------------------------------------------------------------------- + 0x160, + 0x04d, + 0x175, + 0x1f8, + 0x023, + 0x257, + 0x1ac, + 0x0cf, + 0x199, + 0x23e, + 0x076, + 0x1f2, + 0x11d, + 0x17c, + 0x15e, + 0x1ec, + // 16 + 0x0c5, + 0x109, + 0x398, + 0x09b, + 0x392, + 0x12b, + 0x0e5, + 0x283, + 0x126, + 0x367, + 0x132, + 0x058, + 0x057, + 0x0c1, + 0x160, + 0x30d, + // 32 + 0x34e, + 0x04b, + 0x147, + 0x208, + 0x1b3, + 0x21f, + 0x0cb, + 0x29a, + 0x0f9, + 0x15a, + 0x30d, + 0x26d, + 0x280, + 0x10c, + 0x31a, + 0x216, + // 48 + 0x21b, + 0x30d, + 0x198, + 0x186, + 0x284, + 0x066, + 0x1dc, + 0x1f3, + 0x122, + 0x278, + 0x221, + 0x025, + 0x35a, + 0x394, + 0x228, + 0x029, + // 64 + 0x21e, + 0x121, + 0x07a, + 0x110, + 0x17f, + 0x320, + 0x1e5, + 0x062, + 0x2f0, + 0x1d8, + 0x2f9, + 0x06b, + 0x310, + 0x35c, + 0x292, + 0x2e5, + // 80 + 0x122, + 0x0cc, + 0x2a9, + 0x197, + 0x357, + 0x055, + 0x063, + 0x03e, + 0x1e2, + 0x0b4, + 0x014, + 0x129, + 0x1c3, + 0x251, + 0x391, + 0x08e, + // 96 + 0x328, + 0x2ac, + 0x11f, + 0x218, + 0x231, + 0x04c, + 0x28d, + 0x383, + 0x2d9, + 0x237, + 0x2e8, + 0x186, + 0x201, + 0x0c0, + 0x204, + 0x102, + // 112 + 0x0f0, + 0x206, + 0x31a, + 0x18b, + 0x300, + 0x350, + 0x033, + 0x262, + 0x180, + 0x0a8, + 0x0be, + 0x33a, + 0x148, + 0x254, + 0x312, + 0x12f, + // 128 + 0x23a, + 0x17d, + 0x19f, + 0x281, + 0x09c, + 0x0ed, + 0x097, + 0x1ad, + 0x213, + 0x0cf, + 0x2a4, + 0x2c6, + 0x059, + 0x0a8, + 0x130, + 0x192, + // 144 + 0x028, + 0x2c4, + 0x23f, + 0x0a2, + 0x360, + 0x0e5, + 0x041, + 0x35d, + 0x349, + 0x200, + 0x0a4, + 0x1dd, + 0x0dd, + 0x05c, + 0x166, + 0x311, + // 160 + 0x120, + 0x165, + 0x352, + 0x344, + 0x33b, + 0x2e0, + 0x2c3, + 0x05e, + 0x008, + 0x1ee, + 0x072, + 0x209, + 0x002, + 0x1f3, + 0x353, + 0x21f, + // 176 + 0x098, + 0x2d9, + 0x303, + 0x05f, + 0x0f8, + 0x169, + 0x242, + 0x143, + 0x358, + 0x31d, + 0x121, + 0x033, + 0x2ac, + 0x1d2, + 0x215, + 0x334, + // 192 + 0x29d, + 0x02d, + 0x386, + 0x1c4, + 0x0a7, + 0x156, + 0x0f4, + 0x0ad, + 0x023, + 0x1cf, + 0x28b, + 0x033, + 0x2bb, + 0x24f, + 0x1c4, + 0x242, + // 208 + 0x025, + 0x07c, + 0x12a, + 0x14c, + 0x228, + 0x02b, + 0x1ab, + 0x077, + 0x296, + 0x309, + 0x1db, + 0x352, + 0x2fc, + 0x16c, + 0x242, + 0x38f, + // 224 + 0x11b, + 0x2c7, + 0x1d8, + 0x1a4, + 0x0f5, + 0x120, + 0x252, + 0x18a, + 0x1ff, + 0x147, + 0x24d, + 0x309, + 0x2bb, + 0x2b0, + 0x02b, + 0x198, + // 240 + 0x34a, + 0x17f, + 0x2d1, + 0x209, + 0x230, + 0x284, + 0x2ca, + 0x22f, + 0x03e, + 0x091, + 0x369, + 0x297, + 0x2c9, + 0x09f, + 0x2a0, + 0x2d9, + // 256 + 0x270, + 0x03b, + 0x0c1, + 0x1a1, + 0x09e, + 0x0d1, + 0x233, + 0x234, + 0x157, + 0x2b5, + 0x06d, + 0x260, + 0x233, + 0x16d, + 0x0b5, + 0x304, + // 272 + 0x2a5, + 0x136, + 0x0f8, + 0x161, + 0x2c4, + 0x19a, + 0x243, + 0x366, + 0x269, + 0x349, + 0x278, + 0x35c, + 0x121, + 0x218, + 0x023, + 0x309, + // 288 + 0x26a, + 0x24a, + 0x1a8, + 0x341, + 0x04d, + 0x255, + 0x15a, + 0x10d, + 0x2f5, + 0x278, + 0x2b7, + 0x2ef, + 0x14b, + 0x0f7, + 0x0b8, + 0x02d, + // 304 + 0x313, + 0x2a8, + 0x012, + 0x042, + 0x197, + 0x171, + 0x036, + 0x1ec, + 0x0e4, + 0x265, + 0x33e, + 0x39a, + 0x1b5, + 0x207, + 0x284, + 0x389, + // 320 + 0x315, + 0x1a4, + 0x131, + 0x1b9, + 0x0cf, + 0x12c, + 0x37c, + 0x33b, + 0x08d, + 0x219, + 0x17d, + 0x296, + 0x201, + 0x038, + 0x0fc, + 0x155, + // 336 + 0x0f2, + 0x31d, + 0x346, + 0x345, + 0x2d0, + 0x0e0, + 0x133, + 0x277, + 0x03d, + 0x057, + 0x230, + 0x136, + 0x2f4, + 0x299, + 0x18d, + 0x328, + // 352 + 0x353, + 0x135, + 0x1d9, + 0x31b, + 0x17a, + 0x01f, + 0x287, + 0x393, + 0x1cb, + 0x326, + 0x24e, + 0x2db, + 0x1a9, + 0x0d8, + 0x224, + 0x0f9, + // 368 + 0x141, + 0x371, + 0x2bb, + 0x217, + 0x2a1, + 0x30e, + 0x0d2, + 0x32f, + 0x389, + 0x12f, + 0x34b, + 0x39a, + 0x119, + 0x049, + 0x1d5, + 0x317, + // 384 + 0x294, + 0x0a2, + 0x1f2, + 0x134, + 0x09b, + 0x1a6, + 0x38b, + 0x331, + 0x0bb, + 0x03e, + 0x010, + 0x1a9, + 0x217, + 0x150, + 0x11e, + 0x1b5, + // 400 + 0x177, + 0x111, + 0x262, + 0x128, + 0x0b7, + 0x39b, + 0x074, + 0x29b, + 0x2ef, + 0x161, + 0x03e, + 0x16e, + 0x2b3, + 0x17b, + 0x2af, + 0x34a, + // 416 + 0x025, + 0x165, + 0x2d0, + 0x2e6, + 0x14a, + 0x005, + 0x027, + 0x39b, + 0x137, + 0x1a8, + 0x0f2, + 0x2ed, + 0x141, + 0x036, + 0x29d, + 0x13c, + // 432 + 0x156, + 0x12b, + 0x216, + 0x069, + 0x29b, + 0x1e8, + 0x280, + 0x2a0, + 0x240, + 0x21c, + 0x13c, + 0x1e6, + 0x2d1, + 0x262, + 0x02e, + 0x290, + // 448 + 0x1bf, + 0x0ab, + 0x268, + 0x1d0, + 0x0be, + 0x213, + 0x129, + 0x141, + 0x2fa, + 0x2f0, + 0x215, + 0x0af, + 0x086, + 0x00e, + 0x17d, + 0x1b1, + // 464 + 0x2cd, + 0x02d, + 0x06f, + 0x014, + 0x254, + 0x11c, + 0x2e0, + 0x08a, + 0x286, + 0x19b, + 0x36d, + 0x29d, + 0x08d, + 0x397, + 0x02d, + 0x30c, + // 480 + 0x197, + 0x0a4, + 0x14c, + 0x383, + 0x0a5, + 0x2d6, + 0x258, + 0x145, + 0x1f2, + 0x28f, + 0x165, + 0x2f0, + 0x300, + 0x0df, + 0x351, + 0x287, + // 496 + 0x03f, + 0x136, + 0x35f, + 0x0fb, + 0x16e, + 0x130, + 0x11a, + 0x2e2, + 0x2a3, + 0x19a, + 0x185, + 0x0f4, + 0x01f, + 0x079, + 0x12f, + 0x107, + ], + ]; +} diff --git a/vendor/tecnickcom/tc-lib-barcode/src/Type/Square/PdfFourOneSeven/Sequence.php b/vendor/tecnickcom/tc-lib-barcode/src/Type/Square/PdfFourOneSeven/Sequence.php new file mode 100644 index 0000000..eb9b3ba --- /dev/null +++ b/vendor/tecnickcom/tc-lib-barcode/src/Type/Square/PdfFourOneSeven/Sequence.php @@ -0,0 +1,186 @@ + + * @copyright 2010-2024 Nicola Asuni - Tecnick.com LTD + * @license http://www.gnu.org/copyleft/lesser.html GNU-LGPL v3 (see LICENSE.TXT) + * @link https://github.com/tecnickcom/tc-lib-barcode + * + * This file is part of tc-lib-barcode software library. + */ + +namespace Com\Tecnick\Barcode\Type\Square\PdfFourOneSeven; + +/** + * Com\Tecnick\Barcode\Type\Square\PdfFourOneSeven\Sequence + * + * Process for PdfFourOneSeven Barcode type class + * + * @since 2015-02-21 + * @category Library + * @package Barcode + * @author Nicola Asuni + * @copyright 2010-2024 Nicola Asuni - Tecnick.com LTD + * @license http://www.gnu.org/copyleft/lesser.html GNU-LGPL v3 (see LICENSE.TXT) + * @link https://github.com/tecnickcom/tc-lib-barcode + */ +abstract class Sequence extends \Com\Tecnick\Barcode\Type\Square +{ + /** + * Get the error correction level (0-8) to be used + * + * @param int $ecl Error correction level + * @param int $numcw Number of data codewords + * + * @return int error correction level + */ + protected function getErrorCorrectionLevel(int $ecl, int $numcw): int + { + $maxecl = 8; // maximum error level + $maxerrsize = (928 - $numcw); // available codewords for error + while (($maxecl > 0) && ($maxerrsize < (2 << $maxecl))) { + --$maxecl; + } + + if (($ecl < 0) || ($ecl > 8)) { + if ($numcw < 41) { + $ecl = 2; + } elseif ($numcw < 161) { + $ecl = 3; + } elseif ($numcw < 321) { + $ecl = 4; + } elseif ($numcw < 864) { + $ecl = 5; + } else { + $ecl = $maxecl; + } + } + + return (int) min($maxecl, $ecl); + } + + /** + * Get the error correction codewords + * + * @param array $codewords Array of codewords including Symbol Length Descriptor and pad + * @param int $ecl Error correction level 0-8 + * + * @return array of error correction codewords + */ + protected function getErrorCorrection(array $codewords, int $ecl): array + { + // get error correction coefficients + $ecc = Data::RS_FACTORS[$ecl]; + // number of error correction factors + $eclsize = (2 << $ecl); + // maximum index for RS_FACTORS[$ecl] + $eclmaxid = ($eclsize - 1); + // initialize array of error correction codewords + $ecw = array_fill(0, $eclsize, 0); + // for each data codeword + foreach ($codewords as $codeword) { + $tk1 = ($codeword + $ecw[$eclmaxid]) % 929; + for ($idx = $eclmaxid; $idx > 0; --$idx) { + $tk2 = (($tk1 * $ecc[$idx]) % 929); + $tk3 = (929 - $tk2); + $ecw[$idx] = (int) (($ecw[($idx - 1)] + $tk3) % 929); + } + + $tk2 = (($tk1 * $ecc[0]) % 929); + $tk3 = (929 - $tk2); + $ecw[0] = (int) ($tk3 % 929); + } + + foreach ($ecw as $idx => $err) { + if ($err != 0) { + $ecw[$idx] = (int) (929 - $err); + } + } + + return array_reverse($ecw); + } + + /** + * Process a single sequence + * + * @param array $sequence_array Sequence to process + * @param string $code Data to process + * @param int $seq Current sequence + * @param int $offset Current code offset + */ + protected function processSequence(array &$sequence_array, string $code, int $seq, int $offset): void + { + // extract text sequence before the number sequence + $prevseq = substr($code, $offset, ($seq - $offset)); + $textseq = []; + // get text sequences + preg_match_all('/([\x09\x0a\x0d\x20-\x7e]{5,})/', $prevseq, $textseq, PREG_OFFSET_CAPTURE); + $textseq[1][] = ['', strlen($prevseq)]; + $txtoffset = 0; + foreach ($textseq[1] as $txtseq) { + $txtseqlen = strlen($txtseq[0]); + if ($txtseq[1] > 0) { + // extract byte sequence before the text sequence + $prevtxtseq = substr($prevseq, $txtoffset, ($txtseq[1] - $txtoffset)); + if (strlen($prevtxtseq) > 0) { + // add BYTE sequence + if ( + (strlen($prevtxtseq) == 1) + && (($sequence_array !== []) + && ($sequence_array[(count($sequence_array) - 1)][0] == 900)) + ) { + $sequence_array[] = [913, $prevtxtseq]; + } elseif ((strlen($prevtxtseq) % 6) == 0) { + $sequence_array[] = [924, $prevtxtseq]; + } else { + $sequence_array[] = [901, $prevtxtseq]; + } + } + } + + if ($txtseqlen > 0) { + // add numeric sequence + $sequence_array[] = [900, $txtseq[0]]; + } + + $txtoffset = ($txtseq[1] + $txtseqlen); + } + } + + /** + * Get an array of sequences from input + * + * @param string $code Data to process + * + * @return array + */ + protected function getInputSequences(string $code): array + { + $sequence_array = []; // array to be returned + $numseq = []; + // get numeric sequences + preg_match_all('/(\d{13,})/', $code, $numseq, PREG_OFFSET_CAPTURE); + $numseq[1][] = ['', strlen($code)]; + $offset = 0; + foreach ($numseq[1] as $seq) { + $seqlen = strlen($seq[0]); + if ($seq[1] > 0) { + $this->processSequence($sequence_array, $code, $seq[1], $offset); + } + + if ($seqlen > 0) { + // add numeric sequence + $sequence_array[] = [902, $seq[0]]; + } + + $offset = ($seq[1] + $seqlen); + } + + return $sequence_array; + } +} diff --git a/vendor/tecnickcom/tc-lib-barcode/src/Type/Square/QrCode.php b/vendor/tecnickcom/tc-lib-barcode/src/Type/Square/QrCode.php new file mode 100644 index 0000000..dfea82f --- /dev/null +++ b/vendor/tecnickcom/tc-lib-barcode/src/Type/Square/QrCode.php @@ -0,0 +1,259 @@ + + * @copyright 2015-2024 Nicola Asuni - Tecnick.com LTD + * @license http://www.gnu.org/copyleft/lesser.html GNU-LGPL v3 (see LICENSE.TXT) + * @link https://github.com/tecnickcom/tc-lib-barcode + * + * This file is part of tc-lib-barcode software library. + */ + +namespace Com\Tecnick\Barcode\Type\Square; + +use Com\Tecnick\Barcode\Exception as BarcodeException; +use Com\Tecnick\Barcode\Type\Square\QrCode\ByteStream; +use Com\Tecnick\Barcode\Type\Square\QrCode\Data; +use Com\Tecnick\Barcode\Type\Square\QrCode\Encoder; +use Com\Tecnick\Barcode\Type\Square\QrCode\Split; + +/** + * Com\Tecnick\Barcode\Type\Square\QrCode + * + * QrCode Barcode type class + * + * @since 2015-02-21 + * @category Library + * @package Barcode + * @author Nicola Asuni + * @copyright 2015-2024 Nicola Asuni - Tecnick.com LTD + * @license http://www.gnu.org/copyleft/lesser.html GNU-LGPL v3 (see LICENSE.TXT) + * @link https://github.com/tecnickcom/tc-lib-barcode + */ +class QrCode extends \Com\Tecnick\Barcode\Type\Square +{ + /** + * Barcode format + * + * @var string + */ + protected const FORMAT = 'QRCODE'; + + /** + * QR code version. + * The Size of QRcode is defined as version. Version is an integer value from 1 to 40. + * Version 1 is 21*21 matrix. And 4 modules increases whenever 1 version increases. + * So version 40 is 177*177 matrix. + */ + protected int $version = 0; + + /** + * Error correction level + */ + protected int $level = 0; + + /** + * Encoding mode + */ + protected int $hint = 2; + + /** + * Boolean flag, if false the input string will be converted to uppercase. + */ + protected bool $case_sensitive = true; + + /** + * If negative, checks all masks available, + * otherwise the value indicates the number of masks to be checked, + * mask ids are random. + */ + protected int $random_mask = -1; + + /** + * If true, estimates best mask (spec. default, but extremally slow; + * set to false to significant performance boost but (propably) worst quality code. + */ + protected bool $best_mask = true; + + /** + * Default mask used when $this->best_mask === false + */ + protected int $default_mask = 2; + + /** + * ByteStream class object + */ + protected ByteStream $bsObj; + + /** + * Set extra (optional) parameters: + * 1: LEVEL - error correction level: L, M, Q, H + * 2: HINT - encoding mode: NL=variable, NM=numeric, AN=alphanumeric, 8B=8bit, KJ=KANJI, ST=STRUCTURED + * 3: VERSION - integer value from 1 to 40 + * 4: CASE SENSITIVE - if 0 the input string will be converted to uppercase + * 5: RANDOM MASK - false or number of masks to be checked + * 6: BEST MASK - true to find the best mask (slow) + * 7: DEFAULT MASK - mask to use when the best mask option is false + * + * @SuppressWarnings("PHPMD.CyclomaticComplexity") + * @SuppressWarnings("PHPMD.NPathComplexity") + */ + protected function setParameters(): void + { + parent::setParameters(); + + // level + if ( + ! isset($this->params[0]) + || ! isset(Data::ECC_LEVELS[$this->params[0]]) + ) { + $this->params[0] = 'L'; + } + + $this->level = Data::ECC_LEVELS[$this->params[0]]; + + // hint + if ( + ! isset($this->params[1]) + || ! isset(Data::ENC_MODES[$this->params[1]]) + ) { + $this->params[1] = '8B'; + } + + $this->hint = Data::ENC_MODES[$this->params[1]]; + + // version + if ( + ! isset($this->params[2]) + || ($this->params[2] < 0) + || ($this->params[2] > Data::QRSPEC_VERSION_MAX) + ) { + $this->params[2] = 0; + } + + $this->version = (int) $this->params[2]; + + // case sensitive + if (! isset($this->params[3])) { + $this->params[3] = 1; + } + + $this->case_sensitive = (bool) $this->params[3]; + + // random mask mode - number of masks to be checked + if (! empty($this->params[4])) { + $this->random_mask = (int) $this->params[4]; + } + + // find best mask + if (! isset($this->params[5])) { + $this->params[5] = 1; + } + + $this->best_mask = (bool) $this->params[5]; + + // default mask + if (! isset($this->params[6])) { + $this->params[6] = 2; + } + + $this->default_mask = (int) $this->params[6]; + } + + /** + * Get the bars array + * + * @throws BarcodeException in case of error + */ + protected function setBars(): void + { + if (strlen((string) $this->code) == 0) { + throw new BarcodeException('Empty input'); + } + + $this->bsObj = new ByteStream($this->hint, $this->version, $this->level); + // generate the qrcode + $this->processBinarySequence( + $this->binarize( + $this->encodeString($this->code) + ) + ); + } + + /** + * Convert the frame in binary form + * + * @param array $frame Array to binarize + * + * @return array frame in binary form + */ + protected function binarize(array $frame): array + { + $len = count($frame); + // the frame is square (width = height) + foreach ($frame as &$frameLine) { + for ($idx = 0; $idx < $len; ++$idx) { + $frameLine[$idx] = ((ord($frameLine[$idx]) & 1) !== 0) ? '1' : '0'; + } + } + + return $frame; + } + + /** + * Encode the input string + * + * @param string $data input string to encode + * + * @return array Encoded data + */ + protected function encodeString(string $data): array + { + if (! $this->case_sensitive) { + $data = $this->toUpper($data); + } + + $split = new Split($this->bsObj, $this->hint, $this->version); + $datacode = $this->bsObj->getByteStream($split->getSplittedString($data)); + $this->version = $this->bsObj->version; + $encoder = new Encoder( + $this->version, + $this->level, + $this->random_mask, + $this->best_mask, + $this->default_mask + ); + return $encoder->encodeMask(-1, $datacode); + } + + /** + * Convert input string into upper case mode + * + * @param string $data Data + */ + protected function toUpper(string $data): string + { + $len = strlen($data); + $pos = 0; + + while ($pos < $len) { + $mode = $this->bsObj->getEncodingMode($data, $pos); + if ($mode == Data::ENC_MODES['KJ']) { + $pos += 2; + } else { + if ((ord($data[$pos]) >= ord('a')) && (ord($data[$pos]) <= ord('z'))) { + $data[$pos] = chr(ord($data[$pos]) - 32); + } + + ++$pos; + } + } + + return $data; + } +} diff --git a/vendor/tecnickcom/tc-lib-barcode/src/Type/Square/QrCode/ByteStream.php b/vendor/tecnickcom/tc-lib-barcode/src/Type/Square/QrCode/ByteStream.php new file mode 100644 index 0000000..5bb4a72 --- /dev/null +++ b/vendor/tecnickcom/tc-lib-barcode/src/Type/Square/QrCode/ByteStream.php @@ -0,0 +1,263 @@ + + * @copyright 2010-2024 Nicola Asuni - Tecnick.com LTD + * @license http://www.gnu.org/copyleft/lesser.html GNU-LGPL v3 (see LICENSE.TXT) + * @link https://github.com/tecnickcom/tc-lib-barcode + * + * This file is part of tc-lib-barcode software library. + */ + +namespace Com\Tecnick\Barcode\Type\Square\QrCode; + +use Com\Tecnick\Barcode\Exception as BarcodeException; + +/** + * Com\Tecnick\Barcode\Type\Square\QrCode\ByteStream + * + * @since 2015-02-21 + * @category Library + * @package Barcode + * @author Nicola Asuni + * @copyright 2010-2024 Nicola Asuni - Tecnick.com LTD + * @license http://www.gnu.org/copyleft/lesser.html GNU-LGPL v3 (see LICENSE.TXT) + * @link https://github.com/tecnickcom/tc-lib-barcode + * + * @phpstan-import-type Item from \Com\Tecnick\Barcode\Type\Square\QrCode\Estimate + */ +class ByteStream extends \Com\Tecnick\Barcode\Type\Square\QrCode\Encode +{ + /** + * Initialize + * + * @param int $hint Encoding mode + * @param int $version Code version + * @param int $level Error Correction Level + */ + public function __construct(int $hint, int $version, int $level) + { + $this->hint = $hint; + $this->version = $version; + $this->level = $level; + } + + /** + * Pack all bit streams padding bits into a byte array + * + * @param array $items Items + * + * @return array padded merged byte stream + */ + public function getByteStream(array $items): array + { + return $this->bitstreamToByte( + $this->appendPaddingBit( + $this->mergeBitStream($items) + ) + ); + } + + /** + * merge the bit stream + * + * @param array $items Items + * + * @return array bitstream + */ + protected function mergeBitStream(array $items): array + { + $items = $this->convertData($items); + $bstream = []; + foreach ($items as $item) { + $bstream = $this->appendBitstream($bstream, $item['bstream']); + } + + return $bstream; + } + + /** + * Append Padding Bit to bitstream + * + * @param array $bstream Bit stream + * + * @return array bitstream + */ + protected function appendPaddingBit(array $bstream): array + { + if (empty($bstream)) { + return []; + } + + $bits = count($bstream); + $spec = new Spec(); + $maxwords = $spec->getDataLength($this->version, $this->level); + $maxbits = $maxwords * 8; + if ($maxbits == $bits) { + return $bstream; + } + + if ($maxbits - $bits < 5) { + return $this->appendNum($bstream, $maxbits - $bits, 0); + } + + $bits += 4; + $words = (int) (($bits + 7) / 8); + $padding = []; + $padding = $this->appendNum($padding, $words * 8 - $bits + 4, 0); + + $padlen = $maxwords - $words; + if ($padlen > 0) { + $padbuf = []; + for ($idx = 0; $idx < $padlen; ++$idx) { + $padbuf[$idx] = ((($idx & 1) !== 0) ? 0x11 : 0xec); + } + + $padding = $this->appendBytes($padding, $padlen, $padbuf); + } + + return $this->appendBitstream($bstream, $padding); + } + + /** + * Convert bitstream to bytes + * + * @param array $bstream Original bitstream + * + * @return array of bytes + */ + protected function bitstreamToByte(array $bstream): array + { + $size = count($bstream); + if ($size == 0) { + return []; + } + + $data = array_fill(0, (int) (($size + 7) / 8), 0); + $bytes = (int) ($size / 8); + $pos = 0; + for ($idx = 0; $idx < $bytes; ++$idx) { + $val = 0; + for ($jdx = 0; $jdx < 8; ++$jdx) { + $val <<= 1; + $val |= $bstream[$pos]; + ++$pos; + } + + $data[$idx] = $val; + } + + if (($size & 7) !== 0) { + $val = 0; + for ($jdx = 0; $jdx < ($size & 7); ++$jdx) { + $val <<= 1; + $val |= $bstream[$pos]; + ++$pos; + } + + $data[$bytes] = $val; + } + + return $data; + } + + /** + * convertData + * + * @param array $items Items + * + * @return array + */ + protected function convertData(array $items): array + { + $ver = $this->estimateVersion($items, $this->level); + if ($ver > $this->version) { + $this->version = $ver; + } + + while (true) { + $cbs = $this->createBitStream($items); + $items = $cbs[0]; + $bits = $cbs[1]; + if ($bits < 0) { + throw new BarcodeException('Negative Bits value'); + } + + $ver = $this->getMinimumVersion((int) (($bits + 7) / 8), $this->level); + if ($ver > $this->version) { + $this->version = $ver; + } else { + break; + } + } + + return $items; + } + + /** + * Create BitStream + * + * @param array $items Items + * + * @return array{ + * 0: array, + * 1: int, + * } + */ + protected function createBitStream(array $items): array + { + $total = 0; + foreach ($items as $key => $item) { + $items[$key] = $this->encodeBitStream($item, $this->version); + $bits = count($items[$key]['bstream']); + $total += $bits; + } + + return [$items, $total]; + } + + /** + * Encode BitStream + * + * @param Item $inputitem Input item + * @param int $version Code version + * + * @return Item + */ + public function encodeBitStream(array $inputitem, int $version): array + { + $inputitem['bstream'] = []; + $spec = new Spec(); + $words = $spec->maximumWords($inputitem['mode'], $version); + + if ($inputitem['size'] <= $words) { + return match ($inputitem['mode']) { + Data::ENC_MODES['NM'] => $this->encodeModeNum($inputitem, $version), + Data::ENC_MODES['AN'] => $this->encodeModeAn($inputitem, $version), + Data::ENC_MODES['8B'] => $this->encodeMode8($inputitem, $version), + Data::ENC_MODES['KJ'] => $this->encodeModeKanji($inputitem, $version), + Data::ENC_MODES['ST'] => $this->encodeModeStructure($inputitem), + default => throw new BarcodeException('Invalid mode'), + }; + } + + $st1 = $this->newInputItem($inputitem['mode'], $words, $inputitem['data']); + $st2 = $this->newInputItem( + $inputitem['mode'], + ($inputitem['size'] - $words), + array_slice($inputitem['data'], $words) + ); + $st1 = $this->encodeBitStream($st1, $version); + $st2 = $this->encodeBitStream($st2, $version); + $inputitem['bstream'] = []; + $inputitem['bstream'] = $this->appendBitstream($inputitem['bstream'], $st1['bstream']); + $inputitem['bstream'] = $this->appendBitstream($inputitem['bstream'], $st2['bstream']); + + return $inputitem; + } +} diff --git a/vendor/tecnickcom/tc-lib-barcode/src/Type/Square/QrCode/Data.php b/vendor/tecnickcom/tc-lib-barcode/src/Type/Square/QrCode/Data.php new file mode 100644 index 0000000..e644e28 --- /dev/null +++ b/vendor/tecnickcom/tc-lib-barcode/src/Type/Square/QrCode/Data.php @@ -0,0 +1,530 @@ + + * @copyright 2010-2024 Nicola Asuni - Tecnick.com LTD + * @license http://www.gnu.org/copyleft/lesser.html GNU-LGPL v3 (see LICENSE.TXT) + * @link https://github.com/tecnickcom/tc-lib-barcode + * + * This file is part of tc-lib-barcode software library. + */ + +namespace Com\Tecnick\Barcode\Type\Square\QrCode; + +/** + * Com\Tecnick\Barcode\Type\Square\QrCode\Data + * + * Data for QrCode Barcode type class + * + * @since 2015-02-21 + * @category Library + * @package Barcode + * @author Nicola Asuni + * @copyright 2010-2024 Nicola Asuni - Tecnick.com LTD + * @license http://www.gnu.org/copyleft/lesser.html GNU-LGPL v3 (see LICENSE.TXT) + * @link https://github.com/tecnickcom/tc-lib-barcode + */ +class Data +{ + /** + * Maximum QR Code version. + * + * @var int + */ + public const QRSPEC_VERSION_MAX = 40; + + /** + * Maximum matrix size for maximum version (version 40 is 177*177 matrix). + * + * @var int + */ + public const QRSPEC_WIDTH_MAX = 177; + + // ----------------------------------------------------- + + /** + * Matrix index to get width from CAPACITY array. + * + * @var int + */ + public const QRCAP_WIDTH = 0; + + /** + * Matrix index to get number of words from CAPACITY array. + * + * @var int + */ + public const QRCAP_WORDS = 1; + + /** + * Matrix index to get remainder from CAPACITY array. + * + * @var int + */ + public const QRCAP_REMINDER = 2; + + /** + * Matrix index to get error correction level from CAPACITY array. + * + * @var int + */ + public const QRCAP_EC = 3; + + // ----------------------------------------------------- + + // Structure (currently usupported) + + /** + * Number of header bits for structured mode + * + * @var int + */ + public const STRUCTURE_HEADER_BITS = 20; + + /** + * Max number of symbols for structured mode + * + * @var int + */ + public const MAX_STRUCTURED_SYMBOLS = 16; + + // ----------------------------------------------------- + + // Masks + + /** + * Down point base value for case 1 mask pattern (concatenation of same color in a line or a column) + * + * @var int + */ + public const N1 = 3; + + /** + * Down point base value for case 2 mask pattern (module block of same color) + * + * @var int + */ + public const N2 = 3; + + /** + * Down point base value for case 3 mask pattern + * (1:1:3:1:1 (dark:bright:dark:bright:dark) pattern in a line or a column) + * + * @var int + */ + public const N3 = 40; + + /** + * Down point base value for case 4 mask pattern (ration of dark modules in whole) + * + * @var int + */ + public const N4 = 10; + + /** + * Encoding modes (characters which can be encoded in QRcode) + * + * NL : variable + * NM : Encoding mode numeric (0-9). 3 characters are encoded to 10bit length. + * AN : Encoding mode alphanumeric (0-9A-Z $%*+-./:) 45characters. 2 characters are encoded to 11bit length. + * 8B : Encoding mode 8bit byte data. In theory, 2953 characters or less can be stored in a QRcode. + * KJ : Encoding mode KANJI. A KANJI character (multibyte character) is encoded to 13bit length. + * ST : Encoding mode STRUCTURED + * + * @var array + */ + public const ENC_MODES = [ + 'NL' => -1, + 'NM' => 0, + 'AN' => 1, + '8B' => 2, + 'KJ' => 3, + 'ST' => 4, + ]; + + /** + * Array of valid error correction levels + * QRcode has a function of an error correcting for miss reading that white is black. + * Error correcting is defined in 4 level as below. + * L : About 7% or less errors can be corrected. + * M : About 15% or less errors can be corrected. + * Q : About 25% or less errors can be corrected. + * H : About 30% or less errors can be corrected. + * + * @var array + */ + public const ECC_LEVELS = [ + 'L' => 0, + 'M' => 1, + 'Q' => 2, + 'H' => 3, + ]; + + /** + * Alphabet-numeric conversion table. + * + * @var array + */ + public const AN_TABLE = [ + -1, + -1, + -1, + -1, + -1, + -1, + -1, + -1, + -1, + -1, + -1, + -1, + -1, + -1, + -1, + -1, + // + -1, + -1, + -1, + -1, + -1, + -1, + -1, + -1, + -1, + -1, + -1, + -1, + -1, + -1, + -1, + -1, + // + 36, + -1, + -1, + -1, + 37, + 38, + -1, + -1, + -1, + -1, + 39, + 40, + -1, + 41, + 42, + 43, + // + 0, + 1, + 2, + 3, + 4, + 5, + 6, + 7, + 8, + 9, + 44, + -1, + -1, + -1, + -1, + -1, + // + -1, + 10, + 11, + 12, + 13, + 14, + 15, + 16, + 17, + 18, + 19, + 20, + 21, + 22, + 23, + 24, + // + 25, + 26, + 27, + 28, + 29, + 30, + 31, + 32, + 33, + 34, + 35, + -1, + -1, + -1, + -1, + -1, + // + -1, + -1, + -1, + -1, + -1, + -1, + -1, + -1, + -1, + -1, + -1, + -1, + -1, + -1, + -1, + -1, + // + -1, + -1, + -1, + -1, + -1, + -1, + -1, + -1, + -1, + -1, + -1, + -1, + -1, + -1, + -1, + -1, + ]; + + /** + * Array Table of the capacity of symbols. + * See Table 1 (pp.13) and Table 12-16 (pp.30-36), JIS X0510:2004. + * + * @var array + */ + public const CAPACITY = [ + [0, 0, 0, [0, 0, 0, 0]], + [21, 26, 0, [7, 10, 13, 17]], + [25, 44, 7, [10, 16, 22, 28]], + [29, 70, 7, [15, 26, 36, 44]], + [33, 100, 7, [20, 36, 52, 64]], + [37, 134, 7, [26, 48, 72, 88]], + [41, 172, 7, [36, 64, 96, 112]], + [45, 196, 0, [40, 72, 108, 130]], + [49, 242, 0, [48, 88, 132, 156]], + [53, 292, 0, [60, 110, 160, 192]], + [57, 346, 0, [72, 130, 192, 224]], + [61, 404, 0, [80, 150, 224, 264]], + [65, 466, 0, [96, 176, 260, 308]], + [69, 532, 0, [104, 198, 288, 352]], + [73, 581, 3, [120, 216, 320, 384]], + [77, 655, 3, [132, 240, 360, 432]], + [81, 733, 3, [144, 280, 408, 480]], + [85, 815, 3, [168, 308, 448, 532]], + [89, 901, 3, [180, 338, 504, 588]], + [93, 991, 3, [196, 364, 546, 650]], + [97, 1085, 3, [224, 416, 600, 700]], + [101, 1156, 4, [224, 442, 644, 750]], + [105, 1258, 4, [252, 476, 690, 816]], + [109, 1364, 4, [270, 504, 750, 900]], + [113, 1474, 4, [300, 560, 810, 960]], + [117, 1588, 4, [312, 588, 870, 1050]], + [121, 1706, 4, [336, 644, 952, 1110]], + [125, 1828, 4, [360, 700, 1020, 1200]], + [129, 1921, 3, [390, 728, 1050, 1260]], + [133, 2051, 3, [420, 784, 1140, 1350]], + [137, 2185, 3, [450, 812, 1200, 1440]], + [141, 2323, 3, [480, 868, 1290, 1530]], + [145, 2465, 3, [510, 924, 1350, 1620]], + [149, 2611, 3, [540, 980, 1440, 1710]], + [153, 2761, 3, [570, 1036, 1530, 1800]], + [157, 2876, 0, [570, 1064, 1590, 1890]], + [161, 3034, 0, [600, 1120, 1680, 1980]], + [165, 3196, 0, [630, 1204, 1770, 2100]], + [169, 3362, 0, [660, 1260, 1860, 2220]], + [173, 3532, 0, [720, 1316, 1950, 2310]], + [177, 3706, 0, [750, 1372, 2040, 2430]], + ]; + + /** + * Array Length indicator. + * + * @var array + */ + public const LEN_TABLE_BITS = [ + [10, 12, 14], + [9, 11, 13], + [8, 16, 16], + [8, 10, 12], + ]; + + /** + * Array Table of the error correction code (Reed-Solomon block). + * See Table 12-16 (pp.30-36), JIS X0510:2004. + * + * @var array + */ + public const ECC_TABLE = [ + [[0, 0], [0, 0], [0, 0], [0, 0]], + [[1, 0], [1, 0], [1, 0], [1, 0]], + [[1, 0], [1, 0], [1, 0], [1, 0]], + [[1, 0], [1, 0], [2, 0], [2, 0]], + [[1, 0], [2, 0], [2, 0], [4, 0]], + [[1, 0], [2, 0], [2, 2], [2, 2]], + [[2, 0], [4, 0], [4, 0], [4, 0]], + [[2, 0], [4, 0], [2, 4], [4, 1]], + [[2, 0], [2, 2], [4, 2], [4, 2]], + [[2, 0], [3, 2], [4, 4], [4, 4]], + [[2, 2], [4, 1], [6, 2], [6, 2]], + [[4, 0], [1, 4], [4, 4], [3, 8]], + [[2, 2], [6, 2], [4, 6], [7, 4]], + [[4, 0], [8, 1], [8, 4], [12, 4]], + [[3, 1], [4, 5], [11, 5], [11, 5]], + [[5, 1], [5, 5], [5, 7], [11, 7]], + [[5, 1], [7, 3], [15, 2], [3, 13]], + [[1, 5], [10, 1], [1, 15], [2, 17]], + [[5, 1], [9, 4], [17, 1], [2, 19]], + [[3, 4], [3, 11], [17, 4], [9, 16]], + [[3, 5], [3, 13], [15, 5], [15, 10]], + [[4, 4], [17, 0], [17, 6], [19, 6]], + [[2, 7], [17, 0], [7, 16], [34, 0]], + [[4, 5], [4, 14], [11, 14], [16, 14]], + [[6, 4], [6, 14], [11, 16], [30, 2]], + [[8, 4], [8, 13], [7, 22], [22, 13]], + [[10, 2], [19, 4], [28, 6], [33, 4]], + [[8, 4], [22, 3], [8, 26], [12, 28]], + [[3, 10], [3, 23], [4, 31], [11, 31]], + [[7, 7], [21, 7], [1, 37], [19, 26]], + [[5, 10], [19, 10], [15, 25], [23, 25]], + [[13, 3], [2, 29], [42, 1], [23, 28]], + [[17, 0], [10, 23], [10, 35], [19, 35]], + [[17, 1], [14, 21], [29, 19], [11, 46]], + [[13, 6], [14, 23], [44, 7], [59, 1]], + [[12, 7], [12, 26], [39, 14], [22, 41]], + [[6, 14], [6, 34], [46, 10], [2, 64]], + [[17, 4], [29, 14], [49, 10], [24, 46]], + [[4, 18], [13, 32], [48, 14], [42, 32]], + [[20, 4], [40, 7], [43, 22], [10, 67]], + [[19, 6], [18, 31], [34, 34], [20, 61]], + ]; + + /** + * Array Positions of alignment patterns. + * This array includes only the second and the third position of the alignment patterns. + * Rest of them can be calculated from the distance between them. + * See Table 1 in Appendix E (pp.71) of JIS X0510:2004. + * + * @var array + */ + public const ALIGN_PATTERN = [ + [0, 0], + [0, 0], + [18, 0], + [22, 0], + [26, 0], + [30, 0], + [34, 0], + [22, 38], + [24, 42], + [26, 46], + [28, 50], + [30, 54], + [32, 58], + [34, 62], + [26, 46], + [26, 48], + [26, 50], + [30, 54], + [30, 56], + [30, 58], + [34, 62], + [28, 50], + [26, 50], + [30, 54], + [28, 54], + [32, 58], + [30, 58], + [34, 62], + [26, 50], + [30, 54], + [26, 52], + [30, 56], + [34, 60], + [30, 58], + [34, 62], + [30, 54], + [24, 50], + [28, 54], + [32, 58], + [26, 54], + [30, 58], + ]; + + /** + * Array Version information pattern (BCH coded). + * See Table 1 in Appendix D (pp.68) of JIS X0510:2004. + * size: [QRSPEC_VERSION_MAX - 6] + * + * @var array + */ + public const VERSION_PATTERN = [ + 0x07c94, + 0x085bc, + 0x09a99, + 0x0a4d3, + 0x0bbf6, + 0x0c762, + 0x0d847, + 0x0e60d, + 0x0f928, + 0x10b78, + 0x1145d, + 0x12a17, + 0x13532, + 0x149a6, + 0x15683, + 0x168c9, + 0x177ec, + 0x18ec4, + 0x191e1, + 0x1afab, + 0x1b08e, + 0x1cc1a, + 0x1d33f, + 0x1ed75, + 0x1f250, + 0x209d5, + 0x216f0, + 0x228ba, + 0x2379f, + 0x24b0b, + 0x2542e, + 0x26a64, + 0x27541, + 0x28c69, + ]; + + /** + * Array Format information + * + * @var array + */ + public const FORMAT_INFO = [ + [0x77c4, 0x72f3, 0x7daa, 0x789d, 0x662f, 0x6318, 0x6c41, 0x6976], + [0x5412, 0x5125, 0x5e7c, 0x5b4b, 0x45f9, 0x40ce, 0x4f97, 0x4aa0], + [0x355f, 0x3068, 0x3f31, 0x3a06, 0x24b4, 0x2183, 0x2eda, 0x2bed], + [0x1689, 0x13be, 0x1ce7, 0x19d0, 0x0762, 0x0255, 0x0d0c, 0x083b], + ]; +} diff --git a/vendor/tecnickcom/tc-lib-barcode/src/Type/Square/QrCode/Encode.php b/vendor/tecnickcom/tc-lib-barcode/src/Type/Square/QrCode/Encode.php new file mode 100644 index 0000000..1d453bc --- /dev/null +++ b/vendor/tecnickcom/tc-lib-barcode/src/Type/Square/QrCode/Encode.php @@ -0,0 +1,224 @@ + + * @copyright 2010-2024 Nicola Asuni - Tecnick.com LTD + * @license http://www.gnu.org/copyleft/lesser.html GNU-LGPL v3 (see LICENSE.TXT) + * @link https://github.com/tecnickcom/tc-lib-barcode + * + * This file is part of tc-lib-barcode software library. + */ + +namespace Com\Tecnick\Barcode\Type\Square\QrCode; + +/** + * Com\Tecnick\Barcode\Type\Square\QrCode\Encode + * + * @since 2015-02-21 + * @category Library + * @package Barcode + * @author Nicola Asuni + * @copyright 2010-2024 Nicola Asuni - Tecnick.com LTD + * @license http://www.gnu.org/copyleft/lesser.html GNU-LGPL v3 (see LICENSE.TXT) + * @link https://github.com/tecnickcom/tc-lib-barcode + */ +abstract class Encode extends \Com\Tecnick\Barcode\Type\Square\QrCode\EncodingMode +{ + /** + * encode Mode Num + * + * @param array{ + * 'mode': int, + * 'size': int, + * 'data': array, + * 'bstream': array, + * } $inputitem input item + * @param int $version Code version + * + * @return array{ + * 'mode': int, + * 'size': int, + * 'data': array, + * 'bstream': array, + * } input item + */ + protected function encodeModeNum(array $inputitem, int $version): array + { + $words = (int) ($inputitem['size'] / 3); + $inputitem['bstream'] = []; + $val = 0x1; + $inputitem['bstream'] = $this->appendNum($inputitem['bstream'], 4, $val); + $inputitem['bstream'] = $this->appendNum( + $inputitem['bstream'], + $this->getLengthIndicator(Data::ENC_MODES['NM'], $version), + $inputitem['size'] + ); + for ($i = 0; $i < $words; ++$i) { + $val = (ord($inputitem['data'][$i * 3]) - ord('0')) * 100; + $val += (ord($inputitem['data'][$i * 3 + 1]) - ord('0')) * 10; + $val += (ord($inputitem['data'][$i * 3 + 2]) - ord('0')); + $inputitem['bstream'] = $this->appendNum($inputitem['bstream'], 10, $val); + } + + if ($inputitem['size'] - $words * 3 == 1) { + $val = ord($inputitem['data'][$words * 3]) - ord('0'); + $inputitem['bstream'] = $this->appendNum($inputitem['bstream'], 4, $val); + } elseif (($inputitem['size'] - ($words * 3)) == 2) { + $val = (ord($inputitem['data'][$words * 3]) - ord('0')) * 10; + $val += (ord($inputitem['data'][$words * 3 + 1]) - ord('0')); + $inputitem['bstream'] = $this->appendNum($inputitem['bstream'], 7, $val); + } + + return $inputitem; + } + + /** + * encode Mode An + * + * @param array{ + * 'mode': int, + * 'size': int, + * 'data': array, + * 'bstream': array, + * } $inputitem input item + * @param int $version Code version + * + * @return array{ + * 'mode': int, + * 'size': int, + * 'data': array, + * 'bstream': array, + * } input item + */ + protected function encodeModeAn(array $inputitem, int $version): array + { + $words = (int) ($inputitem['size'] / 2); + $inputitem['bstream'] = []; + $inputitem['bstream'] = $this->appendNum($inputitem['bstream'], 4, 0x02); + $inputitem['bstream'] = $this->appendNum( + $inputitem['bstream'], + $this->getLengthIndicator(Data::ENC_MODES['AN'], $version), + $inputitem['size'] + ); + for ($idx = 0; $idx < $words; ++$idx) { + $val = $this->lookAnTable(ord($inputitem['data'][($idx * 2)])) * 45; + $val += $this->lookAnTable(ord($inputitem['data'][($idx * 2) + 1])); + $inputitem['bstream'] = $this->appendNum($inputitem['bstream'], 11, $val); + } + + if (($inputitem['size'] & 1) !== 0) { + $val = $this->lookAnTable(ord($inputitem['data'][($words * 2)])); + $inputitem['bstream'] = $this->appendNum($inputitem['bstream'], 6, $val); + } + + return $inputitem; + } + + /** + * encode Mode 8 + * + * @param array{ + * 'mode': int, + * 'size': int, + * 'data': array, + * 'bstream': array, + * } $inputitem input item + * @param int $version Code version + * + * @return array{ + * 'mode': int, + * 'size': int, + * 'data': array, + * 'bstream': array, + * } input item + */ + protected function encodeMode8(array $inputitem, int $version): array + { + $inputitem['bstream'] = []; + $inputitem['bstream'] = $this->appendNum($inputitem['bstream'], 4, 0x4); + $inputitem['bstream'] = $this->appendNum( + $inputitem['bstream'], + $this->getLengthIndicator(Data::ENC_MODES['8B'], $version), + $inputitem['size'] + ); + for ($idx = 0; $idx < $inputitem['size']; ++$idx) { + $inputitem['bstream'] = $this->appendNum($inputitem['bstream'], 8, ord($inputitem['data'][$idx])); + } + + return $inputitem; + } + + /** + * encode Mode Kanji + * + * @param array{ + * 'mode': int, + * 'size': int, + * 'data': array, + * 'bstream': array, + * } $inputitem input item + * @param int $version Code version + * + * @return array{ + * 'mode': int, + * 'size': int, + * 'data': array, + * 'bstream': array, + * } input item + */ + protected function encodeModeKanji(array $inputitem, int $version): array + { + $inputitem['bstream'] = []; + $inputitem['bstream'] = $this->appendNum($inputitem['bstream'], 4, 0x8); + $inputitem['bstream'] = $this->appendNum( + $inputitem['bstream'], + $this->getLengthIndicator(Data::ENC_MODES['KJ'], $version), + (int) ($inputitem['size'] / 2) + ); + for ($idx = 0; $idx < $inputitem['size']; $idx += 2) { + $val = (ord($inputitem['data'][$idx]) << 8) | ord($inputitem['data'][($idx + 1)]); + if ($val <= 0x9ffc) { + $val -= 0x8140; + } else { + $val -= 0xc140; + } + + $val = ($val & 0xff) + (($val >> 8) * 0xc0); + $inputitem['bstream'] = $this->appendNum($inputitem['bstream'], 13, $val); + } + + return $inputitem; + } + + /** + * encode Mode Structure + * + * @param array{ + * 'mode': int, + * 'size': int, + * 'data': array, + * 'bstream': array, + * } $inputitem input item + * + * @return array{ + * 'mode': int, + * 'size': int, + * 'data': array, + * 'bstream': array, + * } input item + */ + protected function encodeModeStructure(array $inputitem): array + { + $inputitem['bstream'] = []; + $inputitem['bstream'] = $this->appendNum($inputitem['bstream'], 4, 0x03); + $inputitem['bstream'] = $this->appendNum($inputitem['bstream'], 4, ord($inputitem['data'][1]) - 1); + $inputitem['bstream'] = $this->appendNum($inputitem['bstream'], 4, ord($inputitem['data'][0]) - 1); + $inputitem['bstream'] = $this->appendNum($inputitem['bstream'], 8, ord($inputitem['data'][2])); + return $inputitem; + } +} diff --git a/vendor/tecnickcom/tc-lib-barcode/src/Type/Square/QrCode/Encoder.php b/vendor/tecnickcom/tc-lib-barcode/src/Type/Square/QrCode/Encoder.php new file mode 100644 index 0000000..8de4d30 --- /dev/null +++ b/vendor/tecnickcom/tc-lib-barcode/src/Type/Square/QrCode/Encoder.php @@ -0,0 +1,208 @@ + + * @copyright 2010-2024 Nicola Asuni - Tecnick.com LTD + * @license http://www.gnu.org/copyleft/lesser.html GNU-LGPL v3 (see LICENSE.TXT) + * @link https://github.com/tecnickcom/tc-lib-barcode + * + * This file is part of tc-lib-barcode software library. + */ + +namespace Com\Tecnick\Barcode\Type\Square\QrCode; + +use Com\Tecnick\Barcode\Exception as BarcodeException; + +/** + * Com\Tecnick\Barcode\Type\Square\QrCode\Encoder + * + * @since 2015-02-21 + * @category Library + * @package Barcode + * @author Nicola Asuni + * @copyright 2010-2024 Nicola Asuni - Tecnick.com LTD + * @license http://www.gnu.org/copyleft/lesser.html GNU-LGPL v3 (see LICENSE.TXT) + * @link https://github.com/tecnickcom/tc-lib-barcode + */ +class Encoder extends \Com\Tecnick\Barcode\Type\Square\QrCode\Init +{ + /** + * Encode mask + * + * @param int $maskNo Mask number (masking mode) + * @param array $datacode Data code to encode + * + * @return array Encoded Mask + */ + public function encodeMask(int $maskNo, array $datacode): array + { + // initialize values + $this->datacode = $datacode; + $spec = $this->spc->getEccSpec($this->version, $this->level, [0, 0, 0, 0, 0]); + $this->bv1 = $this->spc->rsBlockNum1($spec); + $this->dataLength = $this->spc->rsDataLength($spec); + $this->eccLength = $this->spc->rsEccLength($spec); + $this->ecccode = array_fill(0, $this->eccLength, 0); + $this->blocks = $this->spc->rsBlockNum($spec); + $this->init($spec); + $this->count = 0; + $this->width = $this->spc->getWidth($this->version); + $this->frame = $this->spc->createFrame($this->version); + $this->xpos = ($this->width - 1); + $this->ypos = ($this->width - 1); + $this->dir = -1; + $this->bit = -1; + + // interleaved data and ecc codes + for ($idx = 0; $idx < ($this->dataLength + $this->eccLength); ++$idx) { + $code = $this->getCode(); + $bit = 0x80; + for ($jdx = 0; $jdx < 8; ++$jdx) { + $addr = $this->getNextPosition(); + $this->setFrameAt($addr, 0x02 | (($bit & $code) != 0)); + $bit >>= 1; + } + } + + // remainder bits + $rbits = $this->spc->getRemainder($this->version); + for ($idx = 0; $idx < $rbits; ++$idx) { + $addr = $this->getNextPosition(); + $this->setFrameAt($addr, 0x02); + } + + // masking + $this->runLength = array_fill(0, (Data::QRSPEC_WIDTH_MAX + 1), 0); + if ($maskNo < 0) { + if ($this->qr_find_best_mask) { + $mask = $this->mask($this->width, $this->frame, $this->level); + } else { + $mask = $this->makeMask($this->width, $this->frame, ($this->qr_default_mask % 8), $this->level); + } + } else { + $mask = $this->makeMask($this->width, $this->frame, $maskNo, $this->level); + } + + if ($mask == null) { + throw new BarcodeException('Null Mask'); + } + + return $mask; + } + + /** + * Return Reed-Solomon block code + * + * @return int rsblocks + */ + protected function getCode(): int + { + if ($this->count < $this->dataLength) { + $row = ($this->count % $this->blocks); + $col = floor($this->count / $this->blocks); + if ($col >= $this->rsblocks[0]['dataLength']) { + $row += $this->bv1; + } + + $ret = $this->rsblocks[$row]['data'][$col]; + } elseif ($this->count < ($this->dataLength + $this->eccLength)) { + $row = (($this->count - $this->dataLength) % $this->blocks); + $col = floor(($this->count - $this->dataLength) / $this->blocks); + $ret = $this->rsblocks[$row]['ecc'][$col]; + } else { + return 0; + } + + ++$this->count; + return $ret; + } + + /** + * Set frame value at specified position + * + * @param array{'x': int, 'y': int} $pos X,Y position + * @param int $val Value of the character to set + */ + protected function setFrameAt(array $pos, int $val): void + { + $this->frame[$pos['y']][$pos['x']] = chr($val); + } + + /** + * Return the next frame position + * + * @return array{'x': int, 'y': int} of x,y coordinates + */ + protected function getNextPosition(): array + { + do { + if ($this->bit == -1) { + $this->bit = 0; + return [ + 'x' => $this->xpos, + 'y' => $this->ypos, + ]; + } + + $xpos = $this->xpos; + $ypos = $this->ypos; + $wdt = $this->width; + $this->getNextPositionB($xpos, $ypos, $wdt); + if (($xpos < 0) || ($ypos < 0)) { + throw new BarcodeException('Error getting next position'); + } + + $this->xpos = $xpos; + $this->ypos = $ypos; + } while (ord($this->frame[$ypos][$xpos]) & 0x80); + + return [ + 'x' => $xpos, + 'y' => $ypos, + ]; + } + + /** + * Internal cycle for getNextPosition + * + * @param int $xpos X position + * @param int $ypos Y position + * @param int $wdt Width + */ + protected function getNextPositionB(int &$xpos, int &$ypos, int $wdt): void + { + if ($this->bit == 0) { + --$xpos; + ++$this->bit; + } else { + ++$xpos; + $ypos += $this->dir; + --$this->bit; + } + + if ($this->dir < 0) { + if ($ypos < 0) { + $ypos = 0; + $xpos -= 2; + $this->dir = 1; + if ($xpos == 6) { + --$xpos; + $ypos = 9; + } + } + } elseif ($ypos === $wdt) { + $ypos = $wdt - 1; + $xpos -= 2; + $this->dir = -1; + if ($xpos == 6) { + --$xpos; + $ypos -= 8; + } + } + } +} diff --git a/vendor/tecnickcom/tc-lib-barcode/src/Type/Square/QrCode/EncodingMode.php b/vendor/tecnickcom/tc-lib-barcode/src/Type/Square/QrCode/EncodingMode.php new file mode 100644 index 0000000..9532902 --- /dev/null +++ b/vendor/tecnickcom/tc-lib-barcode/src/Type/Square/QrCode/EncodingMode.php @@ -0,0 +1,221 @@ + + * @copyright 2010-2024 Nicola Asuni - Tecnick.com LTD + * @license http://www.gnu.org/copyleft/lesser.html GNU-LGPL v3 (see LICENSE.TXT) + * @link https://github.com/tecnickcom/tc-lib-barcode + * + * This file is part of tc-lib-barcode software library. + */ + +namespace Com\Tecnick\Barcode\Type\Square\QrCode; + +/** + * Com\Tecnick\Barcode\Type\Square\QrCode\EncodingMode + * + * @since 2015-02-21 + * @category Library + * @package Barcode + * @author Nicola Asuni + * @copyright 2010-2024 Nicola Asuni - Tecnick.com LTD + * @license http://www.gnu.org/copyleft/lesser.html GNU-LGPL v3 (see LICENSE.TXT) + * @link https://github.com/tecnickcom/tc-lib-barcode + */ +abstract class EncodingMode extends \Com\Tecnick\Barcode\Type\Square\QrCode\InputItem +{ + /** + * Get the encoding mode to use + * + * @param string $data Data + * @param int $pos Position + * + * @return int mode + */ + public function getEncodingMode(string $data, int $pos): int + { + if (! isset($data[$pos])) { + return Data::ENC_MODES['NL']; + } + + if ($this->isDigitAt($data, $pos)) { + return Data::ENC_MODES['NM']; + } + + if ($this->isAlphanumericAt($data, $pos)) { + return Data::ENC_MODES['AN']; + } + + return $this->getEncodingModeKj($data, $pos); + } + + /** + * Get the encoding mode for KJ or 8B + * + * @param string $data Data + * @param int $pos Position + * + * @return int mode + */ + protected function getEncodingModeKj(string $data, int $pos): int + { + if (($this->hint == Data::ENC_MODES['KJ']) && isset($data[($pos + 1)])) { + $word = ((ord($data[$pos]) << 8) | ord($data[($pos + 1)])); + if ((($word >= 0x8140) && ($word <= 0x9ffc)) || (($word >= 0xe040) && ($word <= 0xebbf))) { + return Data::ENC_MODES['KJ']; + } + } + + return Data::ENC_MODES['8B']; + } + + /** + * Return true if the character at specified position is a number + * + * @param string $str Data + * @param int $pos Character position + */ + public function isDigitAt(string $str, int $pos): bool + { + if (! isset($str[$pos])) { + return false; + } + + return ((ord($str[$pos]) >= ord('0')) && (ord($str[$pos]) <= ord('9'))); + } + + /** + * Return true if the character at specified position is an alphanumeric character + * + * @param string $str Data + * @param int $pos Character position + */ + public function isAlphanumericAt(string $str, int $pos): bool + { + if (! isset($str[$pos])) { + return false; + } + + return ($this->lookAnTable(ord($str[$pos])) >= 0); + } + + /** + * Append one bitstream to another + * + * @param array $bitstream Original bitstream + * @param array $append Bitstream to append + * + * @return array bitstream + */ + protected function appendBitstream(array $bitstream, array $append): array + { + if (count($append) == 0) { + return $bitstream; + } + + if (count($bitstream) == 0) { + return $append; + } + + return array_values(array_merge($bitstream, $append)); + } + + /** + * Append one bitstream created from number to another + * + * @param array $bitstream Original bitstream + * @param int $bits Number of bits + * @param int $num Number + * + * @return array bitstream + */ + protected function appendNum(array $bitstream, int $bits, int $num): array + { + if ($bits == 0) { + return []; + } + + return $this->appendBitstream($bitstream, $this->newFromNum($bits, $num)); + } + + /** + * Append one bitstream created from bytes to another + * + * @param array $bitstream Original bitstream + * @param int $size Size + * @param array $data Bytes + * + * @return array bitstream + */ + protected function appendBytes(array $bitstream, int $size, array $data): array + { + if ($size == 0) { + return []; + } + + return $this->appendBitstream($bitstream, $this->newFromBytes($size, $data)); + } + + /** + * Return new bitstream from number + * + * @param int $bits Number of bits + * @param int $num Number + * + * @return array bitstream + */ + protected function newFromNum(int $bits, int $num): array + { + $bstream = $this->allocate($bits); + $mask = 1 << ($bits - 1); + for ($idx = 0; $idx < $bits; ++$idx) { + $bstream[$idx] = ($num & $mask) !== 0 ? 1 : 0; + + $mask >>= 1; + } + + return $bstream; + } + + /** + * Return new bitstream from bytes + * + * @param int $size Size + * @param array $data Bytes + * + * @return array bitstream + */ + protected function newFromBytes(int $size, array $data): array + { + $bstream = $this->allocate($size * 8); + $pval = 0; + for ($idx = 0; $idx < $size; ++$idx) { + $mask = 0x80; + for ($jdx = 0; $jdx < 8; ++$jdx) { + $bstream[$pval] = ($data[$idx] & $mask) !== 0 ? 1 : 0; + + ++$pval; + $mask >>= 1; + } + } + + return $bstream; + } + + /** + * Return an array with zeros + * + * @param int $setLength Array size + * + * @return array array + */ + protected function allocate(int $setLength): array + { + return array_fill(0, $setLength, 0); + } +} diff --git a/vendor/tecnickcom/tc-lib-barcode/src/Type/Square/QrCode/Estimate.php b/vendor/tecnickcom/tc-lib-barcode/src/Type/Square/QrCode/Estimate.php new file mode 100644 index 0000000..cec070f --- /dev/null +++ b/vendor/tecnickcom/tc-lib-barcode/src/Type/Square/QrCode/Estimate.php @@ -0,0 +1,227 @@ + + * @copyright 2010-2024 Nicola Asuni - Tecnick.com LTD + * @license http://www.gnu.org/copyleft/lesser.html GNU-LGPL v3 (see LICENSE.TXT) + * @link https://github.com/tecnickcom/tc-lib-barcode + * + * This file is part of tc-lib-barcode software library. + */ + +namespace Com\Tecnick\Barcode\Type\Square\QrCode; + +use Com\Tecnick\Barcode\Exception as BarcodeException; + +/** + * Com\Tecnick\Barcode\Type\Square\QrCode\Estimate + * + * @since 2015-02-21 + * @category Library + * @package Barcode + * @author Nicola Asuni + * @copyright 2010-2024 Nicola Asuni - Tecnick.com LTD + * @license http://www.gnu.org/copyleft/lesser.html GNU-LGPL v3 (see LICENSE.TXT) + * @link https://github.com/tecnickcom/tc-lib-barcode + * + * @phpstan-type Item array{ + * 'mode': int, + * 'size': int, + * 'data': array, + * 'bstream': array, + * } + */ +abstract class Estimate +{ + /** + * Encoding mode + */ + protected int $hint = 2; + + /** + * QR code version. + * The Size of QRcode is defined as version. Version is an integer value from 1 to 40. + * Version 1 is 21*21 matrix. And 4 modules increases whenever 1 version increases. + * So version 40 is 177*177 matrix. + */ + public int $version = 0; + + /** + * Error correction level + */ + protected int $level = 0; + + /** + * Return the size of length indicator for the mode and version + * + * @param int $mode Encoding mode + * @param int $version Version + * + * @return int the size of the appropriate length indicator (bits). + */ + public function getLengthIndicator(int $mode, int $version): int + { + if ($mode == Data::ENC_MODES['ST']) { + return 0; + } + + if ($version <= 9) { + $len = 0; + } elseif ($version <= 26) { + $len = 1; + } else { + $len = 2; + } + + return Data::LEN_TABLE_BITS[$mode][$len]; + } + + /** + * estimateBitsModeNum + * + * @return int number of bits + */ + public function estimateBitsModeNum(int $size): int + { + $wdt = (int) ($size / 3); + $bits = ($wdt * 10); + match ($size - ($wdt * 3)) { + 1 => $bits += 4, + 2 => $bits += 7, + default => $bits, + }; + return $bits; + } + + /** + * estimateBitsModeAn + * + * @return int number of bits + */ + public function estimateBitsModeAn(int $size): int + { + $bits = (int) ($size * 5.5); // (size / 2 ) * 11 + if (($size & 1) !== 0) { + $bits += 6; + } + + return $bits; + } + + /** + * estimateBitsMode8 + * + * @return int number of bits + */ + public function estimateBitsMode8(int $size): int + { + return $size * 8; + } + + /** + * estimateBitsModeKanji + * + * @return int number of bits + */ + public function estimateBitsModeKanji(int $size): int + { + return (int) ($size * 6.5); // (size / 2 ) * 13 + } + + /** + * Estimate version + * + * @param array $items Items + * @param int $level Error correction level + * + * @return int version + */ + public function estimateVersion(array $items, int $level): int + { + $version = 0; + $prev = 0; + do { + $prev = $version; + $bits = $this->estimateBitStreamSize($items, $prev); + $version = $this->getMinimumVersion((int) (($bits + 7) / 8), $level); + if ($version < 0) { + return -1; + } + } while ($version > $prev); + + return $version; + } + + /** + * Return a version number that satisfies the input code length. + * + * @param int $size Input code length (bytes) + * @param int $level Error correction level + * + * @return int version number + * + * @throws BarcodeException + */ + protected function getMinimumVersion(int $size, int $level): int + { + for ($idx = 1; $idx <= Data::QRSPEC_VERSION_MAX; ++$idx) { + $words = (Data::CAPACITY[$idx][Data::QRCAP_WORDS] - Data::CAPACITY[$idx][Data::QRCAP_EC][$level]); + if ($words >= $size) { + return $idx; + } + } + + throw new BarcodeException( + 'The size of input data is greater than Data::QR capacity, try to lower the error correction mode' + ); + } + + /** + * estimateBitStreamSize + * + * @param array $items Items + * @param int $version Code version + * + * @return int bits + */ + protected function estimateBitStreamSize(array $items, int $version): int + { + $bits = 0; + if ($version == 0) { + $version = 1; + } + + foreach ($items as $item) { + switch ($item['mode']) { + case Data::ENC_MODES['NM']: + $bits = $this->estimateBitsModeNum($item['size']); + break; + case Data::ENC_MODES['AN']: + $bits = $this->estimateBitsModeAn($item['size']); + break; + case Data::ENC_MODES['8B']: + $bits = $this->estimateBitsMode8($item['size']); + break; + case Data::ENC_MODES['KJ']: + $bits = $this->estimateBitsModeKanji($item['size']); + break; + case Data::ENC_MODES['ST']: + return Data::STRUCTURE_HEADER_BITS; + default: + return 0; + } + + $len = $this->getLengthIndicator($item['mode'], $version); + $mod = 1 << $len; + $num = (int) (($item['size'] + $mod - 1) / $mod); + $bits += $num * (4 + $len); + } + + return $bits; + } +} diff --git a/vendor/tecnickcom/tc-lib-barcode/src/Type/Square/QrCode/Init.php b/vendor/tecnickcom/tc-lib-barcode/src/Type/Square/QrCode/Init.php new file mode 100644 index 0000000..3a29c10 --- /dev/null +++ b/vendor/tecnickcom/tc-lib-barcode/src/Type/Square/QrCode/Init.php @@ -0,0 +1,488 @@ + + * @copyright 2010-2024 Nicola Asuni - Tecnick.com LTD + * @license http://www.gnu.org/copyleft/lesser.html GNU-LGPL v3 (see LICENSE.TXT) + * @link https://github.com/tecnickcom/tc-lib-barcode + * + * This file is part of tc-lib-barcode software library. + */ + +namespace Com\Tecnick\Barcode\Type\Square\QrCode; + +use Com\Tecnick\Barcode\Exception as BarcodeException; + +/** + * Com\Tecnick\Barcode\Type\Square\QrCode\Init + * + * @since 2015-02-21 + * @category Library + * @package Barcode + * @author Nicola Asuni + * @copyright 2010-2024 Nicola Asuni - Tecnick.com LTD + * @license http://www.gnu.org/copyleft/lesser.html GNU-LGPL v3 (see LICENSE.TXT) + * @link https://github.com/tecnickcom/tc-lib-barcode + * + * @phpstan-type RSItem array{ + * 'alpha_to': array, + * 'fcr': int, + * 'genpoly': array, + * 'gfpoly': int, + * 'index_of': array, + * 'iprim': int, + * 'mm': int, + * 'nn': int, + * 'nroots': int, + * 'pad': int, + * 'prim': int, + * } + * + * @phpstan-type RSblock array{ + * 'data': array, + * 'dataLength': int, + * 'ecc': array, + * 'eccLength': int, + * } + */ +abstract class Init extends \Com\Tecnick\Barcode\Type\Square\QrCode\Mask +{ + /** + * Data code + * + * @var array + */ + protected array $datacode = []; + + /** + * Error correction code + * + * @var array + */ + protected array $ecccode = []; + + /** + * Blocks + */ + protected int $blocks; + + /** + * Reed-Solomon blocks + * + * @var array + */ + protected array $rsblocks = []; //of RSblock + + /** + * Counter + */ + protected int $count; + + /** + * Data length + */ + protected int $dataLength; + + /** + * Error correction length + */ + protected int $eccLength; + + /** + * Value bv1 + */ + protected int $bv1; + + /** + * Width. + */ + protected int $width; + + /** + * Frame + * + * @var array + */ + protected array $frame = []; + + /** + * Horizontal bit position + */ + protected int $xpos; + + /** + * Vertical bit position + */ + protected int $ypos; + + /** + * Direction + */ + protected int $dir; + + /** + * Single bit value + */ + protected int $bit; + + /** + * Reed-Solomon items + * + * @var array + */ + protected array $rsitems = []; + + /** + * Initialize code + * + * @param array $spec Array of ECC specification + */ + protected function init(array $spec): void + { + $dlv = $this->spc->rsDataCodes1($spec); + $elv = $this->spc->rsEccCodes1($spec); + $rsv = $this->initRs(8, 0x11d, 0, 1, $elv, 255 - $dlv - $elv); + $blockNo = 0; + $dataPos = 0; + $eccPos = 0; + $ecc = []; + $endfor = $this->spc->rsBlockNum1($spec); + $this->initLoop($endfor, $dlv, $elv, $rsv, $eccPos, $blockNo, $dataPos, $ecc); + if ($this->spc->rsBlockNum2($spec) == 0) { + return; + } + + $dlv = $this->spc->rsDataCodes2($spec); + $elv = $this->spc->rsEccCodes2($spec); + $rsv = $this->initRs(8, 0x11d, 0, 1, $elv, 255 - $dlv - $elv); + if ($rsv == null) { + throw new BarcodeException('Empty RS'); + } + + $endfor = $this->spc->rsBlockNum2($spec); + $this->initLoop($endfor, $dlv, $elv, $rsv, $eccPos, $blockNo, $dataPos, $ecc); + } + + /** + * Internal loop for init + * + * @param int $endfor End for + * @param int $dlv Data length value + * @param int $elv Error correction length value + * @param RSItem $rsv Reed-Solomon values + * @param int $eccPos Error correction code position + * @param int $blockNo Block number + * @param int $dataPos Data position + * @param array $ecc Error correction code + */ + protected function initLoop( + int $endfor, + int $dlv, + int $elv, + array $rsv, + int &$eccPos, + int &$blockNo, + int &$dataPos, + array &$ecc + ): void { + for ($idx = 0; $idx < $endfor; ++$idx) { + $data = array_slice($this->datacode, $dataPos); + $ecc = array_slice($this->ecccode, $eccPos); + $ecc = $this->encodeRsChar($rsv, $data, $ecc); + $this->rsblocks[$blockNo] = [ + 'data' => $data, + 'dataLength' => $dlv, + 'ecc' => $ecc, + 'eccLength' => $elv, + ]; + $this->ecccode = array_merge(array_slice($this->ecccode, 0, $eccPos), $ecc); + $dataPos += $dlv; + $eccPos += $elv; + ++$blockNo; + } + } + + /** + * Initialize a Reed-Solomon codec and add it to existing rsitems + * + * @param int $symsize Symbol size, bits + * @param int $gfpoly Field generator polynomial coefficients + * @param int $fcr First root of RS code generator polynomial, index form + * @param int $prim Primitive element to generate polynomial roots + * @param int $nroots RS code generator polynomial degree (number of roots) + * @param int $pad Padding bytes at front of shortened block + * + * @return RSItem Array of RS values: + * mm = Bits per symbol; + * nn = Symbols per block; + * alpha_to = log lookup table array; + * index_of = Antilog lookup table array; + * genpoly = Generator polynomial array; + * nroots = Number of generator; + * roots = number of parity symbols; + * fcr = First consecutive root, index form; + * prim = Primitive element, index form; + * iprim = prim-th root of 1, index form; + * pad = Padding bytes in shortened block; + * gfpoly. + */ + protected function initRs( + int $symsize, + int $gfpoly, + int $fcr, + int $prim, + int $nroots, + int $pad + ): array { + foreach ($this->rsitems as $rsv) { + if ($rsv['pad'] != $pad) { + continue; + } + + if ($rsv['nroots'] != $nroots) { + continue; + } + + if ($rsv['mm'] != $symsize) { + continue; + } + + if ($rsv['gfpoly'] != $gfpoly) { + continue; + } + + if ($rsv['fcr'] != $fcr) { + continue; + } + + if ($rsv['prim'] != $prim) { + continue; + } + + return $rsv; + } + + $rsv = $this->initRsChar($symsize, $gfpoly, $fcr, $prim, $nroots, $pad); + array_unshift($this->rsitems, $rsv); + return $rsv; + } + + /** + * modnn + * + * @param RSItem $rsv RS values + * @param int $xpos X position + * + * @return int X position + */ + protected function modnn(array $rsv, int $xpos): int + { + while ($xpos >= $rsv['nn']) { + $xpos -= $rsv['nn']; + $xpos = (($xpos >> $rsv['mm']) + ($xpos & $rsv['nn'])); + } + + return $xpos; + } + + /** + * Check the params for the initRsChar and throws an exception in case of error. + * + * @param int $symsize Symbol size, bits + * @param int $fcr First root of RS code generator polynomial, index form + * @param int $prim Primitive element to generate polynomial roots + * + * @throws BarcodeException in case of error + */ + protected function checkRsCharParamsA(int $symsize, int $fcr, int $prim): void + { + $shfsymsize = (1 << $symsize); + if ( + ($symsize < 0) + || ($symsize > 8) + || ($fcr < 0) + || ($fcr >= $shfsymsize) + || ($prim <= 0) + || ($prim >= $shfsymsize) + ) { + throw new BarcodeException('Invalid parameters'); + } + } + + /** + * Check the params for the initRsChar and throws an exception in case of error. + * + * @param int $symsize Symbol size, bits + * @param int $nroots RS code generator polynomial degree (number of roots) + * @param int $pad Padding bytes at front of shortened block + * + * @throws BarcodeException in case of error + */ + protected function checkRsCharParamsB(int $symsize, int $nroots, int $pad): void + { + $shfsymsize = (1 << $symsize); + if ( + ($nroots < 0) + || ($nroots >= $shfsymsize) + || ($pad < 0) + || ($pad >= ($shfsymsize - 1 - $nroots)) + ) { + throw new BarcodeException('Invalid parameters'); + } + } + + /** + * Initialize a Reed-Solomon codec and returns an array of values. + * + * @param int $symsize Symbol size, bits + * @param int $gfpoly Field generator polynomial coefficients + * @param int $fcr First root of RS code generator polynomial, index form + * @param int $prim Primitive element to generate polynomial roots + * @param int $nroots RS code generator polynomial degree (number of roots) + * @param int $pad Padding bytes at front of shortened block + * + * @return RSItem Array of RS values: + * mm = Bits per symbol; + * nn = Symbols per block; + * alpha_to = log lookup table array; + * index_of = Antilog lookup table array; + * genpoly = Generator polynomial array; + * nroots = Number of generator; + * roots = number of parity symbols; + * fcr = First consecutive root, index form; + * prim = Primitive element, index form; + * iprim = prim-th root of 1, index form; + * pad = Padding bytes in shortened block; + * gfpoly. + */ + protected function initRsChar( + int $symsize, + int $gfpoly, + int $fcr, + int $prim, + int $nroots, + int $pad + ): array { + $this->checkRsCharParamsA($symsize, $fcr, $prim); + $this->checkRsCharParamsB($symsize, $nroots, $pad); + $rsv = []; + $rsv['mm'] = $symsize; + $rsv['nn'] = ((1 << $symsize) - 1); + $rsv['pad'] = $pad; + $rsv['alpha_to'] = array_fill(0, ($rsv['nn'] + 1), 0); + $rsv['index_of'] = array_fill(0, ($rsv['nn'] + 1), 0); + // PHP style macro replacement + $nnv = &$rsv['nn']; + $azv = &$nnv; + // Generate Galois field lookup tables + $rsv['index_of'][0] = $azv; // log(zero) = -inf + $rsv['alpha_to'][$azv] = 0; // alpha**-inf = 0 + $srv = 1; + for ($idx = 0; $idx < $rsv['nn']; ++$idx) { + $rsv['index_of'][$srv] = $idx; + $rsv['alpha_to'][$idx] = $srv; + $srv <<= 1; + if (($srv & (1 << $symsize)) !== 0) { + $srv ^= $gfpoly; + } + + $srv &= $rsv['nn']; + } + + if ($srv != 1) { + throw new BarcodeException('field generator polynomial is not primitive!'); + } + + // form RS code generator polynomial from its roots + $rsv['genpoly'] = array_fill(0, ($nroots + 1), 0); + $rsv['fcr'] = $fcr; + $rsv['prim'] = $prim; + $rsv['nroots'] = $nroots; + $rsv['gfpoly'] = $gfpoly; + // find prim-th root of 1, used in decoding + for ($iprim = 1; $iprim % $prim != 0; $iprim += $rsv['nn']) { + ; // intentional empty-body loop! + } + + $rsv['iprim'] = (int) ($iprim / $prim); + $rsv['genpoly'][0] = 1; + for ($idx = 0, $root = ($fcr * $prim); $idx < $nroots; ++$idx, $root += $prim) { + $rsv['genpoly'][($idx + 1)] = 1; + // multiply rs->genpoly[] by @**(root + x) + for ($jdx = $idx; $jdx > 0; --$jdx) { + if ($rsv['genpoly'][$jdx] != 0) { + $rsv['genpoly'][$jdx] = ($rsv['genpoly'][($jdx - 1)] + ^ $rsv['alpha_to'][$this->modnn($rsv, $rsv['index_of'][$rsv['genpoly'][$jdx]] + $root)]); + } else { + $rsv['genpoly'][$jdx] = $rsv['genpoly'][($jdx - 1)]; + } + } + + // rs->genpoly[0] can never be zero + $rsv['genpoly'][0] = $rsv['alpha_to'][$this->modnn($rsv, $rsv['index_of'][$rsv['genpoly'][0]] + $root)]; + } + + // convert rs->genpoly[] to index form for quicker encoding + for ($idx = 0; $idx <= $nroots; ++$idx) { + $rsv['genpoly'][$idx] = $rsv['index_of'][$rsv['genpoly'][$idx]]; + } + + return $rsv; + } + + /** + * Encode a Reed-Solomon codec and returns the parity array + * + * @param RSItem $rsv RS values + * @param array $data Data + * @param array $parity Parity + * + * @return array Parity array + */ + protected function encodeRsChar( + array $rsv, + array $data, + array $parity + ): array { + // the total number of symbols in a RS block + $nnv = &$rsv['nn']; + // the address of an array of NN elements to convert Galois field elements + // in index (log) form to polynomial form + $alphato = &$rsv['alpha_to']; + // the address of an array of NN elements to convert Galois field elements + // in polynomial form to index (log) form + $indexof = &$rsv['index_of']; + // an array of NROOTS+1 elements containing the generator polynomial in index form + $genpoly = &$rsv['genpoly']; + // the number of roots in the RS code generator polynomial, + // which is the same as the number of parity symbols in a block + $nroots = &$rsv['nroots']; + // the number of pad symbols in a block + $pad = &$rsv['pad']; + $azv = &$nnv; + $parity = array_fill(0, $nroots, 0); + for ($idx = 0; $idx < ($nnv - $nroots - $pad); ++$idx) { + $feedback = $indexof[$data[$idx] ^ $parity[0]]; + if ($feedback != $azv) { + // feedback term is non-zero + // This line is unnecessary when GENPOLY[NROOTS] is unity, as it must + // always be for the polynomials constructed by initRs() + $feedback = $this->modnn($rsv, ($nnv - $genpoly[$nroots] + $feedback)); + for ($jdx = 1; $jdx < $nroots; ++$jdx) { + $parity[$jdx] ^= $alphato[$this->modnn($rsv, $feedback + $genpoly[($nroots - $jdx)])]; + } + } + + // Shift + array_shift($parity); + $parity[] = $feedback != $azv ? $alphato[$this->modnn($rsv, $feedback + $genpoly[0])] : 0; + } + + return $parity; + } +} diff --git a/vendor/tecnickcom/tc-lib-barcode/src/Type/Square/QrCode/InputItem.php b/vendor/tecnickcom/tc-lib-barcode/src/Type/Square/QrCode/InputItem.php new file mode 100644 index 0000000..e131794 --- /dev/null +++ b/vendor/tecnickcom/tc-lib-barcode/src/Type/Square/QrCode/InputItem.php @@ -0,0 +1,193 @@ + + * @copyright 2010-2024 Nicola Asuni - Tecnick.com LTD + * @license http://www.gnu.org/copyleft/lesser.html GNU-LGPL v3 (see LICENSE.TXT) + * @link https://github.com/tecnickcom/tc-lib-barcode + * + * This file is part of tc-lib-barcode software library. + */ + +namespace Com\Tecnick\Barcode\Type\Square\QrCode; + +use Com\Tecnick\Barcode\Exception as BarcodeException; + +/** + * Com\Tecnick\Barcode\Type\Square\QrCode\InputItem + * + * @since 2015-02-21 + * @category Library + * @package Barcode + * @author Nicola Asuni + * @copyright 2010-2024 Nicola Asuni - Tecnick.com LTD + * @license http://www.gnu.org/copyleft/lesser.html GNU-LGPL v3 (see LICENSE.TXT) + * @link https://github.com/tecnickcom/tc-lib-barcode + * + * @phpstan-import-type Item from \Com\Tecnick\Barcode\Type\Square\QrCode\Estimate + */ +abstract class InputItem extends \Com\Tecnick\Barcode\Type\Square\QrCode\Estimate +{ + /** + * Look up the alphabet-numeric conversion table (see JIS X0510:2004, pp.19) + * + * @param int $chr Character value + */ + public function lookAnTable(int $chr): int + { + return (($chr > 127) ? -1 : Data::AN_TABLE[$chr]); + } + + /** + * Append data to an input object. + * The data is copied and appended to the input object. + * + * @param array $items Input items + * @param int $mode Encoding mode. + * @param int $size Size of data (byte). + * @param array $data Array of input data. + * + * @return array items + */ + public function appendNewInputItem( + array $items, + int $mode, + int $size, + array $data + ): array { + $newitem = $this->newInputItem($mode, $size, $data); + if ($newitem !== []) { + $items[] = $newitem; + } + + return $items; + } + + /** + * newInputItem + * + * @param int $mode Encoding mode. + * @param int $size Size of data (byte). + * @param array $data Array of input data. + * @param array $bstream Binary stream + * + * @return Item input item + */ + protected function newInputItem( + int $mode, + int $size, + array $data, + array $bstream = [] + ): array { + $setData = array_slice($data, 0, $size); + if (count($setData) < $size) { + $setData = array_merge($setData, array_fill(0, ($size - count($setData)), '0')); + } + + if (! $this->check($mode, $size, $setData)) { + throw new BarcodeException('Invalid input item'); + } + + return [ + 'mode' => $mode, + 'size' => $size, + 'data' => $setData, + 'bstream' => $bstream, + ]; + } + + /** + * Validate the input data. + * + * @param int $mode Encoding mode. + * @param int $size Size of data (byte). + * @param array $data Data to validate + * + * @return bool true in case of valid data, false otherwise + */ + protected function check( + int $mode, + int $size, + array $data + ): bool { + if ($size <= 0) { + return false; + } + + return match ($mode) { + Data::ENC_MODES['NM'] => $this->checkModeNum($size, $data), + Data::ENC_MODES['AN'] => $this->checkModeAn($size, $data), + Data::ENC_MODES['KJ'] => $this->checkModeKanji($size, $data), + Data::ENC_MODES['8B'] => true, + Data::ENC_MODES['ST'] => true, + default => false, + }; + } + + /** + * checkModeNum + * + * @param int $size Size of data (byte). + * @param array $data Data to validate + * + * @return bool true or false + */ + protected function checkModeNum(int $size, array $data): bool + { + for ($idx = 0; $idx < $size; ++$idx) { + if ((ord($data[$idx]) < ord('0')) || (ord($data[$idx]) > ord('9'))) { + return false; + } + } + + return true; + } + + /** + * checkModeAn + * + * @param int $size Size of data (byte). + * @param array $data Data to validate + * + * @return bool true or false + */ + protected function checkModeAn(int $size, array $data): bool + { + for ($idx = 0; $idx < $size; ++$idx) { + if ($this->lookAnTable(ord($data[$idx])) == -1) { + return false; + } + } + + return true; + } + + /** + * checkModeKanji + * + * @param int $size Size of data (byte). + * @param array $data Data to validate + * + * @return bool true or false + */ + protected function checkModeKanji(int $size, array $data): bool + { + if (($size & 1) !== 0) { + return false; + } + + for ($idx = 0; $idx < $size; $idx += 2) { + $val = (ord($data[$idx]) << 8) | ord($data[($idx + 1)]); + if (($val < 0x8140) || (($val > 0x9ffc) && ($val < 0xe040)) || ($val > 0xebbf)) { + return false; + } + } + + return true; + } +} diff --git a/vendor/tecnickcom/tc-lib-barcode/src/Type/Square/QrCode/Mask.php b/vendor/tecnickcom/tc-lib-barcode/src/Type/Square/QrCode/Mask.php new file mode 100644 index 0000000..e1451a4 --- /dev/null +++ b/vendor/tecnickcom/tc-lib-barcode/src/Type/Square/QrCode/Mask.php @@ -0,0 +1,339 @@ + + * @copyright 2010-2024 Nicola Asuni - Tecnick.com LTD + * @license http://www.gnu.org/copyleft/lesser.html GNU-LGPL v3 (see LICENSE.TXT) + * @link https://github.com/tecnickcom/tc-lib-barcode + * + * This file is part of tc-lib-barcode software library. + */ + +namespace Com\Tecnick\Barcode\Type\Square\QrCode; + +/** + * Com\Tecnick\Barcode\Type\Square\QrCode\Mask + * + * @since 2015-02-21 + * @category Library + * @package Barcode + * @author Nicola Asuni + * @copyright 2010-2024 Nicola Asuni - Tecnick.com LTD + * @license http://www.gnu.org/copyleft/lesser.html GNU-LGPL v3 (see LICENSE.TXT) + * @link https://github.com/tecnickcom/tc-lib-barcode + */ +abstract class Mask extends \Com\Tecnick\Barcode\Type\Square\QrCode\MaskNum +{ + /** + * Run length + * + * @var array + */ + protected array $runLength = []; + + /** + * Spec class object + */ + protected Spec $spc; + + /** + * Initialize + * + * @param int $version Code version + * @param int $level Error Correction Level + * @param int $qr_find_from_random If negative, checks all masks available, + * otherwise the value indicates the number of masks to be checked, + * mask ids are random + * @param bool $qr_find_best_mask If true, estimates best mask (slow) + * @param int $qr_default_mask Default mask used when $fbm is false + */ + public function __construct( + /** + * QR code version. + * The Size of QRcode is defined as version. Version is an integer value from 1 to 40. + * Version 1 is 21*21 matrix. And 4 modules increases whenever 1 version increases. + * So version 40 is 177*177 matrix. + */ + public int $version, + /** + * Error correction level + */ + protected int $level, + protected int $qr_find_from_random = -1, + protected bool $qr_find_best_mask = true, + protected int $qr_default_mask = 2 + ) { + $this->spc = new Spec(); + } + + /** + * Get the best mask + * + * @param int $width Width + * @param array $frame Frame + * @param int $level Error Correction lLevel + * + * @return array best mask + */ + protected function mask( + int $width, + array $frame, + int $level + ): array { + $minDemerit = PHP_INT_MAX; + $bestMask = []; + $checked_masks = [0, 1, 2, 3, 4, 5, 6, 7]; + if ($this->qr_find_from_random >= 0) { + $howManuOut = (8 - ($this->qr_find_from_random % 9)); + for ($idx = 0; $idx < $howManuOut; ++$idx) { + $maxpos = (count($checked_masks) - 1); + $remPos = ($maxpos > 0) ? random_int(0, $maxpos) : 0; + unset($checked_masks[$remPos]); + $checked_masks = array_values($checked_masks); + } + } + + $bestMask = $frame; + foreach ($checked_masks as $checked_mask) { + $mask = array_fill(0, $width, str_repeat("\0", $width)); + $demerit = 0; + $blacks = $this->makeMaskNo($checked_mask, $width, $frame, $mask); + $blacks += $this->writeFormatInformation($width, $mask, $checked_mask, $level); + $blacks = (int) (100 * $blacks / ($width * $width)); + $demerit = (int) (abs($blacks - 50) / 5) * Data::N4; + $demerit += $this->evaluateSymbol($width, $mask); + if ($demerit < $minDemerit) { + $minDemerit = $demerit; + $bestMask = $mask; + } + } + + return $bestMask; + } + + /** + * Make a mask + * + * @param int $width Mask width + * @param array $frame Frame + * @param int $maskNo Mask number + * @param int $level Error Correction level + * + * @return array mask + */ + protected function makeMask( + int $width, + array $frame, + int $maskNo, + int $level + ): array { + $mask = []; + $this->makeMaskNo($maskNo, $width, $frame, $mask); + $this->writeFormatInformation($width, $mask, $maskNo, $level); + return $mask; + } + + /** + * Write Format Information on the frame and returns the number of black bits + * + * @param int $width Mask width + * @param array $frame Frame + * @param int $maskNo Mask number + * @param int $level Error Correction level + * + * @return int blacks + */ + protected function writeFormatInformation( + int $width, + array &$frame, + int $maskNo, + int $level + ): int { + $blacks = 0; + $spec = new Spec(); + $format = $spec->getFormatInfo($maskNo, $level); + for ($idx = 0; $idx < 8; ++$idx) { + if (($format & 1) !== 0) { + $blacks += 2; + $val = 0x85; + } else { + $val = 0x84; + } + + $frame[8][($width - 1 - $idx)] = chr($val); + if ($idx < 6) { + $frame[$idx][8] = chr($val); + } else { + $frame[($idx + 1)][8] = chr($val); + } + + $format >>= 1; + } + + for ($idx = 0; $idx < 7; ++$idx) { + if (($format & 1) !== 0) { + $blacks += 2; + $val = 0x85; + } else { + $val = 0x84; + } + + $frame[($width - 7 + $idx)][8] = chr($val); + if ($idx == 0) { + $frame[8][7] = chr($val); + } else { + $frame[8][(6 - $idx)] = chr($val); + } + + $format >>= 1; + } + + return $blacks; + } + + /** + * Evaluate Symbol and returns demerit value. + * + * @param int $width Width + * @param array $frame Frame + */ + protected function evaluateSymbol(int $width, array $frame): int + { + $frameY = $frame[0]; + $frameYM = $frame[0]; + for ($ypos = 0; $ypos < $width; ++$ypos) { + $frameY = $frame[$ypos]; + $frameYM = $ypos > 0 ? $frame[($ypos - 1)] : $frameY; + } + + $demerit = $this->evaluateSymbolB($ypos, $width, $frameY, $frameYM); + for ($xpos = 0; $xpos < $width; ++$xpos) { + $head = 0; + $this->runLength[0] = 1; + for ($ypos = 0; $ypos < $width; ++$ypos) { + if (($ypos == 0) && (ord($frame[$ypos][$xpos]) & 1)) { + $this->runLength[0] = -1; + $head = 1; + $this->runLength[$head] = 1; + } elseif ($ypos > 0) { + if (((ord($frame[$ypos][$xpos]) ^ ord($frame[($ypos - 1)][$xpos])) & 1) !== 0) { + ++$head; + $this->runLength[$head] = 1; + } else { + ++$this->runLength[$head]; + } + } + } + + $demerit += $this->calcN1N3($head + 1); + } + + return $demerit; + } + + /** + * Evaluate Symbol + * + * @param int $ypos Y position + * @param int $width Width + * + * @return int demerit + */ + protected function evaluateSymbolB( + int $ypos, + int $width, + string $frameY, + string $frameYM + ): int { + $head = 0; + $demerit = 0; + $this->runLength[0] = 1; + for ($xpos = 0; $xpos < $width; ++$xpos) { + if (($xpos > 0) && ($ypos > 0)) { + $b22 = ord($frameY[$xpos]) + & ord($frameY[($xpos - 1)]) + & ord($frameYM[$xpos]) + & ord($frameYM[($xpos - 1)]); + $w22 = ord($frameY[$xpos]) + | ord($frameY[($xpos - 1)]) + | ord($frameYM[$xpos]) + | ord($frameYM[($xpos - 1)]); + if ((($b22 | ($w22 ^ 1)) & 1) !== 0) { + $demerit += Data::N2; + } + } + + if (($xpos == 0) && (ord($frameY[$xpos]) & 1)) { + $this->runLength[0] = -1; + $head = 1; + $this->runLength[$head] = 1; + } elseif ($xpos > 0) { + if (((ord($frameY[$xpos]) ^ ord($frameY[($xpos - 1)])) & 1) !== 0) { + ++$head; + $this->runLength[$head] = 1; + } else { + ++$this->runLength[$head]; + } + } + } + + return ($demerit + $this->calcN1N3($head + 1)); + } + + /** + * Calc N1 N3 + * + * @param int $length Length + * + * @return int demerit + */ + protected function calcN1N3(int $length): int + { + $demerit = 0; + for ($idx = 0; $idx < $length; ++$idx) { + if ($this->runLength[$idx] >= 5) { + $demerit += (Data::N1 + ($this->runLength[$idx] - 5)); + } + + if (($idx & 1) && ($idx >= 3) && ($idx < ($length - 2)) && ($this->runLength[$idx] % 3 == 0)) { + $demerit += $this->calcN1N3delta($length, $idx); + } + } + + return $demerit; + } + + /** + * Calc N1 N3 delta + * + * @param int $length Length + * @param int $idx Index + * + * @return int demerit delta + */ + protected function calcN1N3delta(int $length, int $idx): int + { + $fact = (int) ($this->runLength[$idx] / 3); + if ( + ($this->runLength[($idx - 2)] == $fact) + && ($this->runLength[($idx - 1)] == $fact) + && ($this->runLength[($idx + 1)] == $fact) + && ($this->runLength[($idx + 2)] == $fact) + ) { + if (($this->runLength[($idx - 3)] < 0) || ($this->runLength[($idx - 3)] >= (4 * $fact))) { + return Data::N3; + } + + if ((($idx + 3) >= $length) || ($this->runLength[($idx + 3)] >= (4 * $fact))) { + return Data::N3; + } + } + + return 0; + } +} diff --git a/vendor/tecnickcom/tc-lib-barcode/src/Type/Square/QrCode/MaskNum.php b/vendor/tecnickcom/tc-lib-barcode/src/Type/Square/QrCode/MaskNum.php new file mode 100644 index 0000000..ce49c6d --- /dev/null +++ b/vendor/tecnickcom/tc-lib-barcode/src/Type/Square/QrCode/MaskNum.php @@ -0,0 +1,102 @@ + + * @copyright 2010-2024 Nicola Asuni - Tecnick.com LTD + * @license http://www.gnu.org/copyleft/lesser.html GNU-LGPL v3 (see LICENSE.TXT) + * @link https://github.com/tecnickcom/tc-lib-barcode + * + * This file is part of tc-lib-barcode software library. + */ + +namespace Com\Tecnick\Barcode\Type\Square\QrCode; + +/** + * Com\Tecnick\Barcode\Type\Square\QrCode\MaskNum + * + * @since 2015-02-21 + * @category Library + * @package Barcode + * @author Nicola Asuni + * @copyright 2010-2024 Nicola Asuni - Tecnick.com LTD + * @license http://www.gnu.org/copyleft/lesser.html GNU-LGPL v3 (see LICENSE.TXT) + * @link https://github.com/tecnickcom/tc-lib-barcode + */ +abstract class MaskNum +{ + /** + * Make Mask Number + * + * @param int $maskNo Mask number + * @param int $width Width + * @param array $frame Frame + * @param array $mask Mask + * + * @return int mask number + */ + protected function makeMaskNo( + int $maskNo, + int $width, + array $frame, + array &$mask + ): int { + $bnum = 0; + $bitMask = $this->generateMaskNo($maskNo, $width, $frame); + $mask = $frame; + for ($ypos = 0; $ypos < $width; ++$ypos) { + for ($xpos = 0; $xpos < $width; ++$xpos) { + if ($bitMask[$ypos][$xpos] == 1) { + $mask[$ypos][$xpos] = chr(ord($frame[$ypos][$xpos]) ^ ((int) ($bitMask[$ypos][$xpos]))); + } + + $bnum += ord($mask[$ypos][$xpos]) & 1; + } + } + + return $bnum; + } + + /** + * Return bit mask + * + * @param int $maskNo Mask number + * @param int $width Width + * @param array $frame Frame + * + * @return array> bit mask + */ + protected function generateMaskNo( + int $maskNo, + int $width, + array $frame + ): array { + $bitMask = array_fill(0, $width, array_fill(0, $width, 0)); + for ($ypos = 0; $ypos < $width; ++$ypos) { + for ($xpos = 0; $xpos < $width; ++$xpos) { + if ((ord($frame[$ypos][$xpos]) & 0x80) !== 0) { + $bitMask[$ypos][$xpos] = 0; + continue; + } + $maskFunc = match ($maskNo) { + 0 => (($xpos + $ypos) & 1), + 1 => ($ypos & 1), + 2 => ($xpos % 3), + 3 => (($xpos + $ypos) % 3), + 4 => ((((int) ($ypos / 2)) + ((int) ($xpos / 3))) & 1), + 5 => ((($xpos * $ypos) & 1) + ($xpos * $ypos) % 3), + 6 => (((($xpos * $ypos) & 1) + ($xpos * $ypos) % 3) & 1), + 7 => (((($xpos * $ypos) % 3) + (($xpos + $ypos) & 1)) & 1), + default => 1, + }; + $bitMask[$ypos][$xpos] = (($maskFunc == 0) ? 1 : 0); + } + } + + return $bitMask; + } +} diff --git a/vendor/tecnickcom/tc-lib-barcode/src/Type/Square/QrCode/Spec.php b/vendor/tecnickcom/tc-lib-barcode/src/Type/Square/QrCode/Spec.php new file mode 100644 index 0000000..e9cfde0 --- /dev/null +++ b/vendor/tecnickcom/tc-lib-barcode/src/Type/Square/QrCode/Spec.php @@ -0,0 +1,181 @@ + + * @copyright 2010-2024 Nicola Asuni - Tecnick.com LTD + * @license http://www.gnu.org/copyleft/lesser.html GNU-LGPL v3 (see LICENSE.TXT) + * @link https://github.com/tecnickcom/tc-lib-barcode + * + * This file is part of tc-lib-barcode software library. + */ + +namespace Com\Tecnick\Barcode\Type\Square\QrCode; + +/** + * Com\Tecnick\Barcode\Type\Square\QrCode\Spec + * + * @since 2015-02-21 + * @category Library + * @package Barcode + * @author Nicola Asuni + * @copyright 2010-2024 Nicola Asuni - Tecnick.com LTD + * @license http://www.gnu.org/copyleft/lesser.html GNU-LGPL v3 (see LICENSE.TXT) + * @link https://github.com/tecnickcom/tc-lib-barcode + * + * @phpstan-type EccSpec array{ + * 0: int, + * 1: int, + * 2: int, + * 3: int, + * 4: int, + * } + */ +class Spec extends \Com\Tecnick\Barcode\Type\Square\QrCode\SpecRs +{ + /** + * Return maximum data code length (bytes) for the version. + * + * @param int $version Version + * @param int $level Error correction level + * + * @return int maximum size (bytes) + */ + public function getDataLength(int $version, int $level): int + { + return (Data::CAPACITY[$version][Data::QRCAP_WORDS] - Data::CAPACITY[$version][Data::QRCAP_EC][$level]); + } + + /** + * Return maximum error correction code length (bytes) for the version. + * + * @param int $version Version + * @param int $level Error correction level + * + * @return int ECC size (bytes) + */ + public function getECCLength(int $version, int $level): int + { + return Data::CAPACITY[$version][Data::QRCAP_EC][$level]; + } + + /** + * Return the width of the symbol for the version. + * + * @param int $version Version + * + * @return int width + */ + public function getWidth(int $version): int + { + return Data::CAPACITY[$version][Data::QRCAP_WIDTH]; + } + + /** + * Return the numer of remainder bits. + * + * @param int $version Version + * + * @return int number of remainder bits + */ + public function getRemainder(int $version): int + { + return Data::CAPACITY[$version][Data::QRCAP_REMINDER]; + } + + /** + * Return the maximum length for the mode and version. + * + * @param int $mode Encoding mode + * @param int $version Version + * + * @return int the maximum length (bytes) + */ + public function maximumWords(int $mode, int $version): int + { + if ($mode == Data::ENC_MODES['ST']) { + return 3; + } + + if ($version <= 9) { + $lval = 0; + } elseif ($version <= 26) { + $lval = 1; + } else { + $lval = 2; + } + + $bits = Data::LEN_TABLE_BITS[$mode][$lval]; + $words = (1 << $bits) - 1; + if ($mode == Data::ENC_MODES['KJ']) { + $words *= 2; // the number of bytes is required + } + + return $words; + } + + /** + * Return an array of ECC specification. + * + * @param int $version Version + * @param int $level Error correction level + * @param EccSpec $spec Array of ECC specification + * + * @return EccSpec spec: + * 0 = # of type1 blocks + * 1 = # of data code + * 2 = # of ecc code + * 3 = # of type2 blocks + * 4 = # of data code + */ + public function getEccSpec(int $version, int $level, array $spec): array + { + if (count($spec) < 5) { + $spec = [0, 0, 0, 0, 0]; + } + + $bv1 = Data::ECC_TABLE[$version][$level][0]; + $bv2 = Data::ECC_TABLE[$version][$level][1]; + $data = $this->getDataLength($version, $level); + $ecc = $this->getECCLength($version, $level); + if ($bv2 === 0) { + $spec[0] = $bv1; + $spec[1] = (int) ($data / $bv1); /* @phpstan-ignore-line */ + $spec[2] = (int) ($ecc / $bv1); /* @phpstan-ignore-line */ + $spec[3] = 0; + $spec[4] = 0; + } else { + $spec[0] = $bv1; + $spec[1] = (int) ($data / ($bv1 + $bv2)); + $spec[2] = (int) ($ecc / ($bv1 + $bv2)); + $spec[3] = $bv2; + $spec[4] = $spec[1] + 1; + } + + return $spec; + } + + /** + * Return BCH encoded format information pattern. + * + * @param int $maskNo Mask number + * @param int $level Error correction level + */ + public function getFormatInfo(int $maskNo, int $level): int + { + if ( + ($maskNo < 0) + || ($maskNo > 7) + || ($level < 0) + || ($level > 3) + ) { + return 0; + } + + return Data::FORMAT_INFO[$level][$maskNo]; + } +} diff --git a/vendor/tecnickcom/tc-lib-barcode/src/Type/Square/QrCode/SpecRs.php b/vendor/tecnickcom/tc-lib-barcode/src/Type/Square/QrCode/SpecRs.php new file mode 100644 index 0000000..45d6d11 --- /dev/null +++ b/vendor/tecnickcom/tc-lib-barcode/src/Type/Square/QrCode/SpecRs.php @@ -0,0 +1,370 @@ + + * @copyright 2010-2024 Nicola Asuni - Tecnick.com LTD + * @license http://www.gnu.org/copyleft/lesser.html GNU-LGPL v3 (see LICENSE.TXT) + * @link https://github.com/tecnickcom/tc-lib-barcode + * + * This file is part of tc-lib-barcode software library. + */ + +namespace Com\Tecnick\Barcode\Type\Square\QrCode; + +/** + * Com\Tecnick\Barcode\Type\Square\QrCode\SpecRs + * + * @since 2015-02-21 + * @category Library + * @package Barcode + * @author Nicola Asuni + * @copyright 2010-2024 Nicola Asuni - Tecnick.com LTD + * @license http://www.gnu.org/copyleft/lesser.html GNU-LGPL v3 (see LICENSE.TXT) + * @link https://github.com/tecnickcom/tc-lib-barcode + * + * @SuppressWarnings("PHPMD.TooManyPublicMethods") + */ +abstract class SpecRs +{ + /** + * Return block number 0 + * + * @param array $spec Spec + * + * @return int value + */ + public function rsBlockNum(array $spec): int + { + return ($spec[0] + $spec[3]); + } + + /** + * Return block number 1 + * + * @param array $spec Spec + * + * @return int value + */ + public function rsBlockNum1(array $spec): int + { + return $spec[0]; + } + + /** + * Return data codes 1 + * + * @param array $spec Spec + * + * @return int value + */ + public function rsDataCodes1(array $spec): int + { + return $spec[1]; + } + + /** + * Return ecc codes 1 + * + * @param array $spec Spec + * + * @return int value + */ + public function rsEccCodes1(array $spec): int + { + return $spec[2]; + } + + /** + * Return block number 2 + * + * @param array $spec Spec + * + * @return int value + */ + public function rsBlockNum2(array $spec): int + { + return $spec[3]; + } + + /** + * Return data codes 2 + * + * @param array $spec Spec + * + * @return int value + */ + public function rsDataCodes2(array $spec): int + { + return $spec[4]; + } + + /** + * Return ecc codes 2 + * + * @param array $spec Spec + * + * @return int value + */ + public function rsEccCodes2(array $spec): int + { + return $spec[2]; + } + + /** + * Return data length + * + * @param array $spec Spec + * + * @return int value + */ + public function rsDataLength(array $spec): int + { + return ($spec[0] * $spec[1]) + ($spec[3] * $spec[4]); + } + + /** + * Return ecc length + * + * @param array $spec Spec + * + * @return int value + */ + public function rsEccLength(array $spec): int + { + return ($spec[0] + $spec[3]) * $spec[2]; + } + + /** + * Return a copy of initialized frame. + * + * @param int $version Version + * + * @return array of unsigned char. + */ + public function createFrame(int $version): array + { + $width = Data::CAPACITY[$version][Data::QRCAP_WIDTH]; + $frameLine = str_repeat("\0", $width); + $frame = array_fill(0, $width, $frameLine); + // Finder pattern + $frame = $this->putFinderPattern($frame, 0, 0); + $frame = $this->putFinderPattern($frame, $width - 7, 0); + $frame = $this->putFinderPattern($frame, 0, $width - 7); + // Separator + $yOffset = $width - 7; + for ($ypos = 0; $ypos < 7; ++$ypos) { + $frame[$ypos][7] = "\xc0"; + $frame[$ypos][$width - 8] = "\xc0"; + $frame[$yOffset][7] = "\xc0"; + ++$yOffset; + } + + $setPattern = str_repeat("\xc0", 8); + $frame = $this->qrstrset($frame, 0, 7, $setPattern); + $frame = $this->qrstrset($frame, $width - 8, 7, $setPattern); + $frame = $this->qrstrset($frame, 0, $width - 8, $setPattern); + // Format info + $setPattern = str_repeat("\x84", 9); + $frame = $this->qrstrset($frame, 0, 8, $setPattern); + $frame = $this->qrstrset($frame, $width - 8, 8, $setPattern, 8); + + $yOffset = $width - 8; + for ($ypos = 0; $ypos < 8; ++$ypos, ++$yOffset) { + $frame[$ypos][8] = "\x84"; + $frame[$yOffset][8] = "\x84"; + } + + // Timing pattern + $wdo = $width - 15; + for ($idx = 1; $idx < $wdo; ++$idx) { + $frame[6][(7 + $idx)] = chr(0x90 | ($idx & 1)); + $frame[(7 + $idx)][6] = chr(0x90 | ($idx & 1)); + } + + // Alignment pattern + $frame = $this->putAlignmentPattern($version, $frame, $width); + // Version information + if ($version >= 7) { + $vinf = $this->getVersionPattern($version); + $val = $vinf; + for ($xpos = 0; $xpos < 6; ++$xpos) { + for ($ypos = 0; $ypos < 3; ++$ypos) { + $frame[(($width - 11) + $ypos)][$xpos] = chr(0x88 | ($val & 1)); + $val >>= 1; + } + } + + $val = $vinf; + for ($ypos = 0; $ypos < 6; ++$ypos) { + for ($xpos = 0; $xpos < 3; ++$xpos) { + $frame[$ypos][($xpos + ($width - 11))] = chr(0x88 | ($val & 1)); + $val >>= 1; + } + } + } + + // and a little bit... + $frame[$width - 8][8] = "\x81"; + return $frame; + } + + /** + * Replace a value on the array at the specified position + * + * @param array $srctab Source table + * @param int $xpos X position + * @param int $ypos Y position + * @param string $repl Value to replace + * @param int|null $replLen Length of the repl string + * + * @return array srctab + */ + public function qrstrset( + array $srctab, + int $xpos, + int $ypos, + string $repl, + ?int $replLen = null + ): array { + $srctab[$ypos] = substr_replace( + $srctab[$ypos], + ($replLen !== null) ? substr($repl, 0, $replLen) : $repl, + $xpos, + $replLen ?? strlen($repl) + ); + return $srctab; + } + + /** + * Put an alignment marker. + * + * @param array $frame Frame + * @param int $pox X center coordinate of the pattern + * @param int $poy Y center coordinate of the pattern + * + * @return array frame + */ + public function putAlignmentMarker( + array $frame, + int $pox, + int $poy + ): array { + $finder = [ + "\xa1\xa1\xa1\xa1\xa1", + "\xa1\xa0\xa0\xa0\xa1", + "\xa1\xa0\xa1\xa0\xa1", + "\xa1\xa0\xa0\xa0\xa1", + "\xa1\xa1\xa1\xa1\xa1", + ]; + $yStart = $poy - 2; + $xStart = $pox - 2; + for ($ydx = 0; $ydx < 5; ++$ydx) { + $frame = $this->qrstrset($frame, $xStart, ($yStart + $ydx), $finder[$ydx]); + } + + return $frame; + } + + /** + * Put a finder pattern. + * + * @param array $frame Frame + * @param int $pox X center coordinate of the pattern + * @param int $poy Y center coordinate of the pattern + * + * @return array frame + */ + public function putFinderPattern( + array $frame, + int $pox, + int $poy + ): array { + $finder = [ + "\xc1\xc1\xc1\xc1\xc1\xc1\xc1", + "\xc1\xc0\xc0\xc0\xc0\xc0\xc1", + "\xc1\xc0\xc1\xc1\xc1\xc0\xc1", + "\xc1\xc0\xc1\xc1\xc1\xc0\xc1", + "\xc1\xc0\xc1\xc1\xc1\xc0\xc1", + "\xc1\xc0\xc0\xc0\xc0\xc0\xc1", + "\xc1\xc1\xc1\xc1\xc1\xc1\xc1", + ]; + for ($ypos = 0; $ypos < 7; ++$ypos) { + $frame = $this->qrstrset($frame, $pox, ($poy + $ypos), $finder[$ypos]); + } + + return $frame; + } + + /** + * Return BCH encoded version information pattern that is used for the symbol of version 7 or greater. + * Use lower 18 bits. + * + * @param int $version Version + */ + public function getVersionPattern(int $version): int + { + if (($version < 7) || ($version > Data::QRSPEC_VERSION_MAX)) { + return 0; + } + + return Data::VERSION_PATTERN[($version - 7)]; + } + + /** + * Put an alignment pattern. + * + * @param int $version Version + * @param array $frame Frame + * @param int $width Width + * + * @return array frame + */ + public function putAlignmentPattern( + int $version, + array $frame, + int $width + ): array { + if ($version < 2) { + return $frame; + } + + $dval = Data::ALIGN_PATTERN[$version][1] - Data::ALIGN_PATTERN[$version][0]; + if ($dval < 0) { + $wdt = 2; + } else { + $wdt = (int) (($width - Data::ALIGN_PATTERN[$version][0]) / $dval + 2); + } + + if ($wdt * $wdt - 3 == 1) { + $psx = Data::ALIGN_PATTERN[$version][0]; + $psy = Data::ALIGN_PATTERN[$version][0]; + return $this->putAlignmentMarker($frame, $psx, $psy); + } + + $cpx = Data::ALIGN_PATTERN[$version][0]; + $wdo = $wdt - 1; + for ($xpos = 1; $xpos < $wdo; ++$xpos) { + $frame = $this->putAlignmentMarker($frame, 6, $cpx); + $frame = $this->putAlignmentMarker($frame, $cpx, 6); + $cpx += $dval; + } + + $cpy = Data::ALIGN_PATTERN[$version][0]; + for ($y = 0; $y < $wdo; ++$y) { + $cpx = Data::ALIGN_PATTERN[$version][0]; + for ($xpos = 0; $xpos < $wdo; ++$xpos) { + $frame = $this->putAlignmentMarker($frame, $cpx, $cpy); + $cpx += $dval; + } + + $cpy += $dval; + } + + return $frame; + } +} diff --git a/vendor/tecnickcom/tc-lib-barcode/src/Type/Square/QrCode/Split.php b/vendor/tecnickcom/tc-lib-barcode/src/Type/Square/QrCode/Split.php new file mode 100644 index 0000000..df0ed9d --- /dev/null +++ b/vendor/tecnickcom/tc-lib-barcode/src/Type/Square/QrCode/Split.php @@ -0,0 +1,290 @@ + + * @copyright 2010-2024 Nicola Asuni - Tecnick.com LTD + * @license http://www.gnu.org/copyleft/lesser.html GNU-LGPL v3 (see LICENSE.TXT) + * @link https://github.com/tecnickcom/tc-lib-barcode + * + * This file is part of tc-lib-barcode software library. + */ + +namespace Com\Tecnick\Barcode\Type\Square\QrCode; + +use Com\Tecnick\Barcode\Exception as BarcodeException; + +/** + * Com\Tecnick\Barcode\Type\Square\QrCode\Split + * + * @since 2015-02-21 + * @category Library + * @package Barcode + * @author Nicola Asuni + * @copyright 2010-2024 Nicola Asuni - Tecnick.com LTD + * @license http://www.gnu.org/copyleft/lesser.html GNU-LGPL v3 (see LICENSE.TXT) + * @link https://github.com/tecnickcom/tc-lib-barcode + * + * @phpstan-import-type Item from \Com\Tecnick\Barcode\Type\Square\QrCode\Estimate + */ +class Split +{ + /** + * Input items + * + * @var array + */ + protected array $items = []; + + /** + * Initialize + * + * @param ByteStream $encodingMode ByteStream Class object + * @param int $hint Encoding mode + * @param int $version Code version + */ + public function __construct( + /** + * EncodingMode class object + */ + protected EncodingMode $encodingMode, + /** + * Encoding mode + */ + protected int $hint, + /** + * QR code version. + * The Size of QRcode is defined as version. Version is an integer value from 1 to 40. + * Version 1 is 21*21 matrix. And 4 modules increases whenever 1 version increases. + * So version 40 is 177*177 matrix. + */ + protected int $version + ) { + } + + /** + * Split the input string + * + * @param string $data Data + * + * @return array items + */ + public function getSplittedString(string $data): array + { + while (strlen($data) > 0) { + $mode = $this->encodingMode->getEncodingMode($data, 0); + switch ($mode) { + case Data::ENC_MODES['NM']: + $length = $this->eatNum($data); + break; + case Data::ENC_MODES['AN']: + $length = $this->eatAn($data); + break; + case Data::ENC_MODES['KJ']: + if ($this->hint == Data::ENC_MODES['KJ']) { + $length = $this->eatKanji($data); + } else { + $length = $this->eat8($data); + } + + break; + default: + $length = $this->eat8($data); + break; + } + + if ($length == 0) { + break; + } + + if ($length < 0) { + throw new BarcodeException('Error while splitting the input data'); + } + + $data = substr($data, $length); + } + + return $this->items; + } + + /** + * eatNum + * + * @param string $data Data + * + * @return int run + */ + protected function eatNum(string $data): int + { + $lng = $this->encodingMode->getLengthIndicator(Data::ENC_MODES['NM'], $this->version); + $pos = 0; + while ($this->encodingMode->isDigitAt($data, $pos)) { + ++$pos; + } + + $mode = $this->encodingMode->getEncodingMode($data, $pos); + if ($mode == Data::ENC_MODES['8B']) { + $dif = $this->encodingMode->estimateBitsModeNum($pos) + 4 + $lng + + $this->encodingMode->estimateBitsMode8(1) // + 4 + l8 + - $this->encodingMode->estimateBitsMode8($pos + 1); // - 4 - l8 + if ($dif > 0) { + return $this->eat8($data); + } + } + + if ($mode == Data::ENC_MODES['AN']) { + $dif = $this->encodingMode->estimateBitsModeNum($pos) + 4 + $lng + + $this->encodingMode->estimateBitsModeAn(1) // + 4 + la + - $this->encodingMode->estimateBitsModeAn($pos + 1); // - 4 - la + if ($dif > 0) { + return $this->eatAn($data); + } + } + + $this->items = $this->encodingMode->appendNewInputItem( + $this->items, + Data::ENC_MODES['NM'], + $pos, + str_split($data) + ); + return $pos; + } + + /** + * eatAn + * + * @param string $data Data + * + * @return int run + */ + protected function eatAn(string $data): int + { + $lag = $this->encodingMode->getLengthIndicator(Data::ENC_MODES['AN'], $this->version); + $lng = $this->encodingMode->getLengthIndicator(Data::ENC_MODES['NM'], $this->version); + $pos = 1; + while ($this->encodingMode->isAlphanumericAt($data, $pos)) { + if ($this->encodingMode->isDigitAt($data, $pos)) { + $qix = $pos; + while ($this->encodingMode->isDigitAt($data, $qix)) { + ++$qix; + } + + $dif = $this->encodingMode->estimateBitsModeAn($pos) // + 4 + lag + + $this->encodingMode->estimateBitsModeNum($qix - $pos) + 4 + $lng + - $this->encodingMode->estimateBitsModeAn($qix); // - 4 - la + if ($dif < 0) { + break; + } else { + $pos = $qix; + } + } else { + ++$pos; + } + } + + if (! $this->encodingMode->isAlphanumericAt($data, $pos)) { + $dif = $this->encodingMode->estimateBitsModeAn($pos) + 4 + $lag + + $this->encodingMode->estimateBitsMode8(1) // + 4 + l8 + - $this->encodingMode->estimateBitsMode8($pos + 1); // - 4 - l8 + if ($dif > 0) { + return $this->eat8($data); + } + } + + $this->items = $this->encodingMode->appendNewInputItem( + $this->items, + Data::ENC_MODES['AN'], + $pos, + str_split($data) + ); + return $pos; + } + + /** + * eatKanji + * + * @param string $data Data + * + * @return int run + */ + protected function eatKanji(string $data): int + { + $pos = 0; + while ($this->encodingMode->getEncodingMode($data, $pos) == Data::ENC_MODES['KJ']) { + $pos += 2; + } + + $this->items = $this->encodingMode->appendNewInputItem( + $this->items, + Data::ENC_MODES['KJ'], + $pos, + str_split($data) + ); + return $pos; + } + + /** + * eat8 + * + * @param string $data Data + * + * @return int run + */ + protected function eat8(string $data): int + { + $lag = $this->encodingMode->getLengthIndicator(Data::ENC_MODES['AN'], $this->version); + $lng = $this->encodingMode->getLengthIndicator(Data::ENC_MODES['NM'], $this->version); + $pos = 1; + $dataStrLen = strlen($data); + while ($pos < $dataStrLen) { + $mode = $this->encodingMode->getEncodingMode($data, $pos); + if ($mode == Data::ENC_MODES['KJ']) { + break; + } + + if ($mode == Data::ENC_MODES['NM']) { + $qix = $pos; + while ($this->encodingMode->isDigitAt($data, $qix)) { + ++$qix; + } + + $dif = $this->encodingMode->estimateBitsMode8($pos) // + 4 + l8 + + $this->encodingMode->estimateBitsModeNum($qix - $pos) + 4 + $lng + - $this->encodingMode->estimateBitsMode8($qix); // - 4 - l8 + if ($dif < 0) { + break; + } else { + $pos = $qix; + } + } elseif ($mode == Data::ENC_MODES['AN']) { + $qix = $pos; + while ($this->encodingMode->isAlphanumericAt($data, $qix)) { + ++$qix; + } + + $dif = $this->encodingMode->estimateBitsMode8($pos) // + 4 + l8 + + $this->encodingMode->estimateBitsModeAn($qix - $pos) + 4 + $lag + - $this->encodingMode->estimateBitsMode8($qix); // - 4 - l8 + if ($dif < 0) { + break; + } else { + $pos = $qix; + } + } else { + ++$pos; + } + } + + $this->items = $this->encodingMode->appendNewInputItem( + $this->items, + Data::ENC_MODES['8B'], + $pos, + str_split($data) + ); + return $pos; + } +} diff --git a/vendor/tecnickcom/tc-lib-barcode/src/Type/Square/Raw.php b/vendor/tecnickcom/tc-lib-barcode/src/Type/Square/Raw.php new file mode 100644 index 0000000..f0fe928 --- /dev/null +++ b/vendor/tecnickcom/tc-lib-barcode/src/Type/Square/Raw.php @@ -0,0 +1,48 @@ + + * @copyright 2010-2024 Nicola Asuni - Tecnick.com LTD + * @license http://www.gnu.org/copyleft/lesser.html GNU-LGPL v3 (see LICENSE.TXT) + * @link https://github.com/tecnickcom/tc-lib-barcode + * + * This file is part of tc-lib-barcode software library. + */ + +namespace Com\Tecnick\Barcode\Type\Square; + +/** + * Com\Tecnick\Barcode\Type\Square\Raw + * + * Raw Barcode type class + * RAW MODE (comma-separated rows) + * + * @since 2015-02-21 + * @category Library + * @package Barcode + * @author Nicola Asuni + * @copyright 2010-2024 Nicola Asuni - Tecnick.com LTD + * @license http://www.gnu.org/copyleft/lesser.html GNU-LGPL v3 (see LICENSE.TXT) + * @link https://github.com/tecnickcom/tc-lib-barcode + */ +class Raw extends \Com\Tecnick\Barcode\Type\Raw +{ + /** + * Barcode type + * + * @var string + */ + protected const TYPE = 'square'; + + /** + * Barcode format + * + * @var string + */ + protected const FORMAT = 'SRAW'; +} diff --git a/vendor/tecnickcom/tc-lib-barcode/test/BarcodeTest.php b/vendor/tecnickcom/tc-lib-barcode/test/BarcodeTest.php new file mode 100644 index 0000000..567bfe6 --- /dev/null +++ b/vendor/tecnickcom/tc-lib-barcode/test/BarcodeTest.php @@ -0,0 +1,388 @@ + + * @copyright 2015-2024 Nicola Asuni - Tecnick.com LTD + * @license http://www.gnu.org/copyleft/lesser.html GNU-LGPL v3 (see LICENSE.TXT) + * @link https://github.com/tecnickcom/tc-lib-barcode + * + * This file is part of tc-lib-barcode software library. + */ + +namespace Test; + +/** + * Barcode class test + * + * @since 2015-02-21 + * @category Library + * @package Barcode + * @author Nicola Asuni + * @copyright 2015-2024 Nicola Asuni - Tecnick.com LTD + * @license http://www.gnu.org/copyleft/lesser.html GNU-LGPL v3 (see LICENSE.TXT) + * @link https://github.com/tecnickcom/tc-lib-barcode + */ +class BarcodeTest extends TestUtil +{ + protected function getTestObject(): \Com\Tecnick\Barcode\Barcode + { + return new \Com\Tecnick\Barcode\Barcode(); + } + + public function testGetBarcodeObjException(): void + { + $this->bcExpectException('\\' . \Com\Tecnick\Barcode\Exception::class); + $barcode = $this->getTestObject(); + $barcode->getBarcodeObj( + 'ERROR', + '01001100011100001111,10110011100011110000', + -2, + -2, + 'purple' + ); + } + + public function testSetPaddingException(): void + { + $this->bcExpectException('\\' . \Com\Tecnick\Barcode\Exception::class); + $barcode = $this->getTestObject(); + $barcode->getBarcodeObj( + 'LRAW,AB,12,E3F', + '01001100011100001111,10110011100011110000', + -2, + -2, + 'purple', + [10] //@phpstan-ignore-line + ); + } + + public function testEmptyColumns(): void + { + $this->bcExpectException('\\' . \Com\Tecnick\Barcode\Exception::class); + $barcode = $this->getTestObject(); + $barcode->getBarcodeObj('LRAW', ''); + } + + public function testEmptyInput(): void + { + $this->bcExpectException('\\' . \Com\Tecnick\Barcode\Exception::class); + $barcode = $this->getTestObject(); + $barcode->getBarcodeObj('LRAW', ''); + } + + public function testSpotColor(): void + { + $barcode = $this->getTestObject(); + $type = $barcode->getBarcodeObj( + 'LRAW', + '01001100011100001111,10110011100011110000', + -2, + -2, + 'all', + [-2, 3, 0, 1] + ); + $bobjarr = $type->getArray(); + $this->assertEquals('#000000ff', $bobjarr['color_obj']->getRgbaHexColor()); + $this->assertNUll($bobjarr['bg_color_obj']); + } + + public function testBackgroundColor(): void + { + $barcode = $this->getTestObject(); + $type = $barcode->getBarcodeObj( + 'LRAW', + '01001100011100001111,10110011100011110000', + -2, + -2, + 'all', + [-2, 3, 0, 1] + )->setBackgroundColor('mediumaquamarine'); + $bobjarr = $type->getArray(); + $this->assertNotNull($bobjarr['bg_color_obj']); + $this->assertEquals('#66cdaaff', $bobjarr['bg_color_obj']->getRgbaHexColor()); + } + + public function testNoColorException(): void + { + $this->bcExpectException('\\' . \Com\Tecnick\Barcode\Exception::class); + $barcode = $this->getTestObject(); + $barcode->getBarcodeObj( + 'LRAW', + '01001100011100001111,10110011100011110000', + -2, + -2, + '', + [-2, 3, 0, 1] + ); + } + + public function testExportMethods(): void + { + $barcode = $this->getTestObject(); + $type = $barcode->getBarcodeObj( + 'LRAW,AB,12,E3F', + '01001100011100001111,10110011100011110000', + -2, + -2, + 'purple', + [-2, 3, 0, 1] + ); + + $this->assertEquals('01001100011100001111,10110011100011110000', $type->getExtendedCode()); + + $barr = $type->getArray(); + $this->assertEquals('linear', $barr['type']); + $this->assertEquals('LRAW', $barr['format']); + $this->assertEquals(['AB', '12', 'E3F'], $barr['params']); + $this->assertEquals('01001100011100001111,10110011100011110000', $barr['code']); + $this->assertEquals('01001100011100001111,10110011100011110000', $barr['extcode']); + $this->assertEquals(20, $barr['ncols']); + $this->assertEquals(2, $barr['nrows']); + $this->assertEquals(40, $barr['width']); + $this->assertEquals(4, $barr['height']); + $this->assertEquals(2, $barr['width_ratio']); + $this->assertEquals(2, $barr['height_ratio']); + $this->assertEquals([ + 'T' => 4, + 'R' => 3, + 'B' => 0, + 'L' => 1, + ], $barr['padding']); + $this->assertEquals(44, $barr['full_width']); + $this->assertEquals(8, $barr['full_height']); + + $expected = [ + [1, 0, 1, 1], + [4, 0, 2, 1], + [9, 0, 3, 1], + [16, 0, 4, 1], + [0, 1, 1, 1], + [2, 1, 2, 1], + [6, 1, 3, 1], + [12, 1, 4, 1], + ]; + $this->assertEquals($expected, $barr['bars']); + $this->assertEquals('#800080ff', $barr['color_obj']->getRgbaHexColor()); + + $grid = $type->getGrid('A', 'B'); + $expected = "ABAABBAAABBBAAAABBBB\nBABBAABBBAAABBBBAAAA\n"; + $this->assertEquals($expected, $grid); + + $svg = $type->setBackgroundColor('yellow')->getSvgCode(); + $expected = ' + + 01001100011100001111,10110011100011110000 + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +'; + $this->assertEquals($expected, $svg); + + $hdiv = $type->setBackgroundColor('lightcoral')->getHtmlDiv(); + $expected = '
+
 
+
 
+
 
+
 
+
 
+
 
+
 
+
 
+
 
+
 
+
 
+
 
+
 
+
 
+
 
+
 
+
 
+
 
+
 
+
 
+
 
+
 
+
 
+
 
+
 
+
 
+
 
+
 
+
+'; + $this->assertEquals($expected, $hdiv); + + if (extension_loaded('imagick')) { + $pngik = $type->setBackgroundColor('white')->getPngData(true); + $this->assertEquals('PNG', substr($pngik, 1, 3)); + } + + $pnggd = $type->setBackgroundColor('white')->getPngData(false); + $this->assertEquals('PNG', substr($pnggd, 1, 3)); + + $pnggd = $type->setBackgroundColor('')->getPngData(false); + $this->assertEquals('PNG', substr($pnggd, 1, 3)); + } + + public function testGetSvg(): void + { + $barcode = $this->getTestObject(); + $type = $barcode->getBarcodeObj( + 'LRAW,AB,12,E3F', + '01001100011100001111,10110011100011110000', + -2, + -2, + 'purple' + ); + + // empty filename + ob_start(); + $type->getSvg(); + $svg = ob_get_clean(); + $this->assertNotFalse($svg); + $this->assertEquals('114f33435c265345f7c6cdf673922292', md5($svg)); + $headers = xdebug_get_headers(); + $this->assertEquals( + 'Content-Disposition: inline; filename="114f33435c265345f7c6cdf673922292.svg";', + $headers[5] + ); + + // invalid filename + ob_start(); + $type->getSvg('#~'); + $svg = ob_get_clean(); + $this->assertNotFalse($svg); + $this->assertEquals('114f33435c265345f7c6cdf673922292', md5($svg)); + $headers = xdebug_get_headers(); + $this->assertEquals( + 'Content-Disposition: inline; filename="114f33435c265345f7c6cdf673922292.svg";', + $headers[5] + ); + + // valid filename + ob_start(); + $type->getSvg('test_SVG_filename-001'); + $svg = ob_get_clean(); + $this->assertNotFalse($svg); + $this->assertEquals('114f33435c265345f7c6cdf673922292', md5($svg)); + $headers = xdebug_get_headers(); + $this->assertEquals( + 'Content-Disposition: inline; filename="test_SVG_filename-001.svg";', + $headers[5] + ); + } + + public function testGetPng(): void + { + $barcode = $this->getTestObject(); + $type = $barcode->getBarcodeObj( + 'LRAW,AB,12,E3F', + '01001100011100001111,10110011100011110000', + -2, + -2, + 'purple' + ); + + // empty filename + ob_start(); + $type->getPng(); + $png = ob_get_clean(); + $this->assertNotFalse($png); + $this->assertEquals('PNG', substr($png, 1, 3)); + $headers = xdebug_get_headers(); + $this->assertNotEmpty($headers[5]); + + // invalid filename + ob_start(); + $type->getPng('#~'); + $png = ob_get_clean(); + $this->assertNotFalse($png); + $this->assertEquals('PNG', substr($png, 1, 3)); + $headers = xdebug_get_headers(); + $this->assertNotEmpty($headers[5]); + + // valid filename + ob_start(); + $type->getPng('test_PNG_filename-001'); + $png = ob_get_clean(); + $this->assertNotFalse($png); + $this->assertEquals('PNG', substr($png, 1, 3)); + $headers = xdebug_get_headers(); + $this->assertEquals( + 'Content-Disposition: inline; filename="test_PNG_filename-001.png";', + $headers[5] + ); + } +} diff --git a/vendor/tecnickcom/tc-lib-barcode/test/Linear/CodabarTest.php b/vendor/tecnickcom/tc-lib-barcode/test/Linear/CodabarTest.php new file mode 100644 index 0000000..acac260 --- /dev/null +++ b/vendor/tecnickcom/tc-lib-barcode/test/Linear/CodabarTest.php @@ -0,0 +1,55 @@ + + * @copyright 2015-2024 Nicola Asuni - Tecnick.com LTD + * @license http://www.gnu.org/copyleft/lesser.html GNU-LGPL v3 (see LICENSE.TXT) + * @link https://github.com/tecnickcom/tc-lib-barcode + * + * This file is part of tc-lib-barcode software library. + */ + +namespace Test\Linear; + +use Test\TestUtil; + +/** + * Barcode class test + * + * @since 2015-02-21 + * @category Library + * @package Barcode + * @author Nicola Asuni + * @copyright 2015-2024 Nicola Asuni - Tecnick.com LTD + * @license http://www.gnu.org/copyleft/lesser.html GNU-LGPL v3 (see LICENSE.TXT) + * @link https://github.com/tecnickcom/tc-lib-barcode + */ +class CodabarTest extends TestUtil +{ + protected function getTestObject(): \Com\Tecnick\Barcode\Barcode + { + return new \Com\Tecnick\Barcode\Barcode(); + } + + public function testGetGrid(): void + { + $barcode = $this->getTestObject(); + $type = $barcode->getBarcodeObj('CODABAR', '0123456789'); + $grid = $type->getGrid(); + $expected = "10110010010101010011010101100101010010110110010101010110" + . "10010110101001010010101101001011010100110101011010010101011001001\n"; + $this->assertEquals($expected, $grid); + } + + public function testInvalidInput(): void + { + $this->bcExpectException('\\' . \Com\Tecnick\Barcode\Exception::class); + $barcode = $this->getTestObject(); + $barcode->getBarcodeObj('CODABAR', chr(218)); + } +} diff --git a/vendor/tecnickcom/tc-lib-barcode/test/Linear/CodeNineThreeTest.php b/vendor/tecnickcom/tc-lib-barcode/test/Linear/CodeNineThreeTest.php new file mode 100644 index 0000000..3ae77ef --- /dev/null +++ b/vendor/tecnickcom/tc-lib-barcode/test/Linear/CodeNineThreeTest.php @@ -0,0 +1,63 @@ + + * @copyright 2015-2024 Nicola Asuni - Tecnick.com LTD + * @license http://www.gnu.org/copyleft/lesser.html GNU-LGPL v3 (see LICENSE.TXT) + * @link https://github.com/tecnickcom/tc-lib-barcode + * + * This file is part of tc-lib-barcode software library. + */ + +namespace Test\Linear; + +use Test\TestUtil; + +/** + * Barcode class test + * + * @since 2015-02-21 + * @category Library + * @package Barcode + * @author Nicola Asuni + * @copyright 2015-2024 Nicola Asuni - Tecnick.com LTD + * @license http://www.gnu.org/copyleft/lesser.html GNU-LGPL v3 (see LICENSE.TXT) + * @link https://github.com/tecnickcom/tc-lib-barcode + */ +class CodeNineThreeTest extends TestUtil +{ + protected function getTestObject(): \Com\Tecnick\Barcode\Barcode + { + return new \Com\Tecnick\Barcode\Barcode(); + } + + public function testGetGrid(): void + { + $barcode = $this->getTestObject(); + $bobj = $barcode->getBarcodeObj('C93', '0123456789'); + $grid = $bobj->getGrid(); + $expected = "101011110100010100101001000101000100101000010100101000100" + . "1001001001000101010100001000100101000010101001011001001100101010111101\n"; + $this->assertEquals($expected, $grid); + + $bobj = $barcode->getBarcodeObj('C93', '012345678901234567890123456789'); + $grid = $bobj->getGrid(); + $expected = "10101111010001010010100100010100010010100001010010100010010010010010001010101" + . "000010001001010000101010001010010100100010100010010100001010010100010010010010010001" + . "010101000010001001010000101010001010010100100010100010010100001010010100010010010010" + . "01000101010100001000100101000010101001001001001010001010111101\n"; + $this->assertEquals($expected, $grid); + } + + public function testInvalidInput(): void + { + $this->bcExpectException('\\' . \Com\Tecnick\Barcode\Exception::class); + $barcode = $this->getTestObject(); + $barcode->getBarcodeObj('C93', chr(255)); + } +} diff --git a/vendor/tecnickcom/tc-lib-barcode/test/Linear/CodeOneOneTest.php b/vendor/tecnickcom/tc-lib-barcode/test/Linear/CodeOneOneTest.php new file mode 100644 index 0000000..14bee1e --- /dev/null +++ b/vendor/tecnickcom/tc-lib-barcode/test/Linear/CodeOneOneTest.php @@ -0,0 +1,66 @@ + + * @copyright 2015-2024 Nicola Asuni - Tecnick.com LTD + * @license http://www.gnu.org/copyleft/lesser.html GNU-LGPL v3 (see LICENSE.TXT) + * @link https://github.com/tecnickcom/tc-lib-barcode + * + * This file is part of tc-lib-barcode software library. + */ + +namespace Test\Linear; + +use Test\TestUtil; + +/** + * Barcode class test + * + * @since 2015-02-21 + * @category Library + * @package Barcode + * @author Nicola Asuni + * @copyright 2015-2024 Nicola Asuni - Tecnick.com LTD + * @license http://www.gnu.org/copyleft/lesser.html GNU-LGPL v3 (see LICENSE.TXT) + * @link https://github.com/tecnickcom/tc-lib-barcode + */ +class CodeOneOneTest extends TestUtil +{ + protected function getTestObject(): \Com\Tecnick\Barcode\Barcode + { + return new \Com\Tecnick\Barcode\Barcode(); + } + + public function testGetGrid(): void + { + $barcode = $this->getTestObject(); + $bobj = $barcode->getBarcodeObj('CODE11', '0123456789'); + $grid = $bobj->getGrid(); + $expected = "10110010101011011010110100101101100101010110110110" + . "11010100110101010011011010010110101010101101011001\n"; + $this->assertEquals($expected, $grid); + + $bobj = $barcode->getBarcodeObj('CODE11', '123-456-789'); + $grid = $bobj->getGrid(); + $expected = "10110010110101101001011011001010101101010110110110110" + . "10100110101011010101001101101001011010101101101011010101011001\n"; + $this->assertEquals($expected, $grid); + + $bobj = $barcode->getBarcodeObj('CODE11', '-'); + $grid = $bobj->getGrid(); + $expected = "10110010101101010110101011001\n"; + $this->assertEquals($expected, $grid); + } + + public function testInvalidInput(): void + { + $this->bcExpectException('\\' . \Com\Tecnick\Barcode\Exception::class); + $barcode = $this->getTestObject(); + $barcode->getBarcodeObj('CODE11', chr(255)); + } +} diff --git a/vendor/tecnickcom/tc-lib-barcode/test/Linear/CodeOneTwoEight/CodeOneTwoEightATest.php b/vendor/tecnickcom/tc-lib-barcode/test/Linear/CodeOneTwoEight/CodeOneTwoEightATest.php new file mode 100644 index 0000000..6e9cb95 --- /dev/null +++ b/vendor/tecnickcom/tc-lib-barcode/test/Linear/CodeOneTwoEight/CodeOneTwoEightATest.php @@ -0,0 +1,67 @@ + + * @copyright 2015-2024 Nicola Asuni - Tecnick.com LTD + * @license http://www.gnu.org/copyleft/lesser.html GNU-LGPL v3 (see LICENSE.TXT) + * @link https://github.com/tecnickcom/tc-lib-barcode + * + * This file is part of tc-lib-barcode software library. + */ + +namespace Test\Linear\CodeOneTwoEight; + +use Test\TestUtil; + +/** + * Barcode class test + * + * @since 2015-02-21 + * @category Library + * @package Barcode + * @author Nicola Asuni + * @copyright 2015-2024 Nicola Asuni - Tecnick.com LTD + * @license http://www.gnu.org/copyleft/lesser.html GNU-LGPL v3 (see LICENSE.TXT) + * @link https://github.com/tecnickcom/tc-lib-barcode + */ +class CodeOneTwoEightATest extends TestUtil +{ + protected function getTestObject(): \Com\Tecnick\Barcode\Barcode + { + return new \Com\Tecnick\Barcode\Barcode(); + } + + public function testGetGrid(): void + { + $barcode = $this->getTestObject(); + $bobj = $barcode->getBarcodeObj('C128A', 'ABCDEFG'); + $grid = $bobj->getGrid(); + $expected = "110100001001010001100010001011000100010001101011000100010001101000100011000101101" + . "0001000100110010001100011101011\n"; + $this->assertEquals($expected, $grid); + + $bobj = $barcode->getBarcodeObj('C128A', '0123456789'); + $grid = $bobj->getGrid(); + $expected = "110100001001001110110010011100110110011100101100101110011001001110110111001001100" + . "1110100111011011101110100110011100101100111101110101100011101011\n"; + $this->assertEquals($expected, $grid); + + $bobj = $barcode->getBarcodeObj('C128A', chr(241) . '01234567891'); + $grid = $bobj->getGrid(); + $expected = "110100001001111010111010011101100100111001101100111001011001011100110010011101101" + . "11001001100111010011101101110111010011001110010110010011100110100001101001100011101011\n"; + $this->assertEquals($expected, $grid); + } + + public function testInvalidInput(): void + { + $this->bcExpectException('\\' . \Com\Tecnick\Barcode\Exception::class); + $barcode = $this->getTestObject(); + $barcode->getBarcodeObj('C128A', chr(246) . '01234567891'); + } +} diff --git a/vendor/tecnickcom/tc-lib-barcode/test/Linear/CodeOneTwoEight/CodeOneTwoEightBTest.php b/vendor/tecnickcom/tc-lib-barcode/test/Linear/CodeOneTwoEight/CodeOneTwoEightBTest.php new file mode 100644 index 0000000..f95a361 --- /dev/null +++ b/vendor/tecnickcom/tc-lib-barcode/test/Linear/CodeOneTwoEight/CodeOneTwoEightBTest.php @@ -0,0 +1,61 @@ + + * @copyright 2015-2024 Nicola Asuni - Tecnick.com LTD + * @license http://www.gnu.org/copyleft/lesser.html GNU-LGPL v3 (see LICENSE.TXT) + * @link https://github.com/tecnickcom/tc-lib-barcode + * + * This file is part of tc-lib-barcode software library. + */ + +namespace Test\Linear\CodeOneTwoEight; + +use Test\TestUtil; + +/** + * Barcode class test + * + * @since 2015-02-21 + * @category Library + * @package Barcode + * @author Nicola Asuni + * @copyright 2015-2024 Nicola Asuni - Tecnick.com LTD + * @license http://www.gnu.org/copyleft/lesser.html GNU-LGPL v3 (see LICENSE.TXT) + * @link https://github.com/tecnickcom/tc-lib-barcode + */ +class CodeOneTwoEightBTest extends TestUtil +{ + protected function getTestObject(): \Com\Tecnick\Barcode\Barcode + { + return new \Com\Tecnick\Barcode\Barcode(); + } + + public function testGetGrid(): void + { + $barcode = $this->getTestObject(); + $bobj = $barcode->getBarcodeObj('C128B', '0123456789'); + $grid = $bobj->getGrid(); + $expected = "11010010000100111011001001110011011001110010110010111001100100111011011100" + . "10011001110100111011011101110100110011100101100110000101001100011101011\n"; + $this->assertEquals($expected, $grid); + + $bobj = $barcode->getBarcodeObj('C128B', chr(241) . '01234567891'); + $grid = $bobj->getGrid(); + $expected = "11010010000111101011101001110110010011100110110011100101100101110011001001" + . "110110111001001100111010011101101110111010011001110010110010011100110100001100101100011101011\n"; + $this->assertEquals($expected, $grid); + } + + public function testInvalidInput(): void + { + $this->bcExpectException('\\' . \Com\Tecnick\Barcode\Exception::class); + $barcode = $this->getTestObject(); + $barcode->getBarcodeObj('C128B', chr(246) . '01234567891'); + } +} diff --git a/vendor/tecnickcom/tc-lib-barcode/test/Linear/CodeOneTwoEight/CodeOneTwoEightCTest.php b/vendor/tecnickcom/tc-lib-barcode/test/Linear/CodeOneTwoEight/CodeOneTwoEightCTest.php new file mode 100644 index 0000000..8086461 --- /dev/null +++ b/vendor/tecnickcom/tc-lib-barcode/test/Linear/CodeOneTwoEight/CodeOneTwoEightCTest.php @@ -0,0 +1,80 @@ + + * @copyright 2015-2024 Nicola Asuni - Tecnick.com LTD + * @license http://www.gnu.org/copyleft/lesser.html GNU-LGPL v3 (see LICENSE.TXT) + * @link https://github.com/tecnickcom/tc-lib-barcode + * + * This file is part of tc-lib-barcode software library. + */ + +namespace Test\Linear\CodeOneTwoEight; + +use Test\TestUtil; + +/** + * Barcode class test + * + * @since 2015-02-21 + * @category Library + * @package Barcode + * @author Nicola Asuni + * @copyright 2015-2024 Nicola Asuni - Tecnick.com LTD + * @license http://www.gnu.org/copyleft/lesser.html GNU-LGPL v3 (see LICENSE.TXT) + * @link https://github.com/tecnickcom/tc-lib-barcode + */ +class CodeOneTwoEightCTest extends TestUtil +{ + protected function getTestObject(): \Com\Tecnick\Barcode\Barcode + { + return new \Com\Tecnick\Barcode\Barcode(); + } + + public function testGetGrid(): void + { + $barcode = $this->getTestObject(); + $bobj = $barcode->getBarcodeObj('C128C', '0123456789'); + $grid = $bobj->getGrid(); + $expected = "110100111001100110110011101101110101110110001000010110011011011110100001101001100011101011\n"; + $this->assertEquals($expected, $grid); + + $bobj = $barcode->getBarcodeObj('C128C', chr(241) . '0123456789'); + $grid = $bobj->getGrid(); + $expected = "11010011100111101011101100110110011101101110101110110001000010110011011011110111101101101100" + . "011101011\n"; + $this->assertEquals($expected, $grid); + + $bobj = $barcode->getBarcodeObj('C128C', chr(241) . '00123456780000000001'); + $grid = $bobj->getGrid(); + $expected = "11010011100111101011101101100110010110011100100010110001110001011011000010100110110011001101" + . "1001100110110011001101100110011001101100100010011001100011101011\n"; + $this->assertEquals($expected, $grid); + + $bobj = $barcode->getBarcodeObj('C128C', chr(241) . '42029651' . chr(241) . '9405510200864168997758'); + $grid = $bobj->getGrid(); + $expected = "11010011100111101011101011011100011001100110101111000101101110100011110101110100010111101000" + . "100110011011101000110011001101101100110011110100100110001000101000010011010111011110111101110101110" + . "1100010111100101001100011101011\n"; + $this->assertEquals($expected, $grid); + } + + public function testInvalidLength(): void + { + $this->bcExpectException('\\' . \Com\Tecnick\Barcode\Exception::class); + $barcode = $this->getTestObject(); + $barcode->getBarcodeObj('C128C', '12345678901'); + } + + public function testInvalidChar(): void + { + $this->bcExpectException('\\' . \Com\Tecnick\Barcode\Exception::class); + $barcode = $this->getTestObject(); + $barcode->getBarcodeObj('C128C', '1A2345678901'); + } +} diff --git a/vendor/tecnickcom/tc-lib-barcode/test/Linear/CodeOneTwoEightTest.php b/vendor/tecnickcom/tc-lib-barcode/test/Linear/CodeOneTwoEightTest.php new file mode 100644 index 0000000..eab0f2c --- /dev/null +++ b/vendor/tecnickcom/tc-lib-barcode/test/Linear/CodeOneTwoEightTest.php @@ -0,0 +1,173 @@ + + * @copyright 2015-2024 Nicola Asuni - Tecnick.com LTD + * @license http://www.gnu.org/copyleft/lesser.html GNU-LGPL v3 (see LICENSE.TXT) + * @link https://github.com/tecnickcom/tc-lib-barcode + * + * This file is part of tc-lib-barcode software library. + */ + +namespace Test\Linear; + +use Test\TestUtil; + +/** + * Barcode class test + * + * @since 2015-02-21 + * @category Library + * @package Barcode + * @author Nicola Asuni + * @copyright 2015-2024 Nicola Asuni - Tecnick.com LTD + * @license http://www.gnu.org/copyleft/lesser.html GNU-LGPL v3 (see LICENSE.TXT) + * @link https://github.com/tecnickcom/tc-lib-barcode + */ +class CodeOneTwoEightTest extends TestUtil +{ + protected function getTestObject(): \Com\Tecnick\Barcode\Barcode + { + return new \Com\Tecnick\Barcode\Barcode(); + } + + public function testGetGrid(): void + { + $barcode = $this->getTestObject(); + $bobj = $barcode->getBarcodeObj('C128', '0123456789'); + $grid = $bobj->getGrid(); + $expected = "110100111001100110110011101101110101110110001000010110011011011110100001101001100011101011\n"; + $this->assertEquals($expected, $grid); + + $bobj = $barcode->getBarcodeObj('C128', '1PBK500EI'); + $grid = $bobj->getGrid(); + $expected = "110100100001001110011011101110110100010110001011000111011011100100100111011001001" + . "11011001000110100011000100010111011001001100011101011\n"; + $this->assertEquals($expected, $grid); + + $bobj = $barcode->getBarcodeObj('C128', 'SCB500J1C3Y'); + $grid = $bobj->getGrid(); + $expected = "110100100001101110100010001000110100010110001101110010010011101100100111011001011" + . "011100010011100110100010001101100101110011101101000110110111101100011101011\n"; + $this->assertEquals($expected, $grid); + + $bobj = $barcode->getBarcodeObj('C128', '067023611120229212'); + $grid = $bobj->getGrid(); + $expected = "110100111001001100100010110000100111011011101100100001011000100100110010011101100111010010101111" + . "00010110011100110110111101100011101011\n"; + $this->assertEquals($expected, $grid); + + $bobj = $barcode->getBarcodeObj('C128', 'Data:28102003'); + $grid = $bobj->getGrid(); + $expected = "110100100001011000100010010110000100111101001001011000011100100110101110111101110011010011001000" + . "1001100100111010010011000100010001101100011101011\n"; + $this->assertEquals($expected, $grid); + + $bobj = $barcode->getBarcodeObj('C128', '12345678901'); + $grid = $bobj->getGrid(); + $expected = "110100100001001110011010111011110111011011101011101100010000101100110110111101100110110011001100" + . "1101100011101011\n"; + $this->assertEquals($expected, $grid); + + $bobj = $barcode->getBarcodeObj('C128', '1234'); + $grid = $bobj->getGrid(); + $expected = "110100111001011001110010001011000100100111101100011101011\n"; + $this->assertEquals($expected, $grid); + + $bobj = $barcode->getBarcodeObj('C128', 'hello'); + $grid = $bobj->getGrid(); + $expected = "110100100001001100001010110010000110010100001100101000010001111010100010011001100011101011\n"; + $this->assertEquals($expected, $grid); + + $bobj = $barcode->getBarcodeObj('C128', 'HI345678'); + $grid = $bobj->getGrid(); + $expected = "110100100001100010100011000100010101110111101000101100011100010110110000101001000010011011000" + . "11101011\n"; + $this->assertEquals($expected, $grid); + + $bobj = $barcode->getBarcodeObj('C128', 'HI34567A'); + $grid = $bobj->getGrid(); + $expected = "1101001000011000101000110001000101100101110010111011110101110110001000010110010111101110101000" + . "11000100100011001100011101011\n"; + $this->assertEquals($expected, $grid); + + $bobj = $barcode->getBarcodeObj('C128', 'Barcode 1'); + $grid = $bobj->getGrid(); + $expected = "110100100001000101100010010110000100100111101000010110010001111010100001001101011001" + . "00001101100110010011100110111011000101100011101011\n"; + $this->assertEquals($expected, $grid); + + $bobj = $barcode->getBarcodeObj('C128', "C1\tC2\tC3"); + $grid = $bobj->getGrid(); + $expected = "11010000100100010001101001110011010000110100100010001101100111001010000110100100010001101100101" + . "1100100110011101100011101011\n"; + $this->assertEquals($expected, $grid); + + $bobj = $barcode->getBarcodeObj('C128', 'A1b2c3D4e5'); + $grid = $bobj->getGrid(); + $expected = "1101001000010100011000100111001101001000011011001110010100001011001100101110010110001" + . "000110010011101011001000011011100100100001101001100011101011\n"; + $this->assertEquals($expected, $grid); + + $bobj = $barcode->getBarcodeObj('C128', chr(241) . '0000801234999999999'); + $grid = $bobj->getGrid(); + $expected = "1101001000011110101110100111011001011101111011011001100100011001001100110110011101101" + . "1101101000111010111011110101110111101011101111010111011110110100010001100011101011\n"; + $this->assertEquals($expected, $grid); + + $bobj = $barcode->getBarcodeObj('C128', chr(241) . "000000\tABCDEF"); + $grid = $bobj->getGrid(); + $expected = "1101001110011110101110111101011101101100110011011001100110110011001110101111010000110100101000" + . "110001000101100010001000110101100010001000110100010001100010100001100101100011101011\n"; + $this->assertEquals($expected, $grid); + + $bobj = $barcode->getBarcodeObj('C128', "\tABCD\tEFGH"); + $grid = $bobj->getGrid(); + $expected = "1101000010010000110100101000110001000101100010001000110101100010001000011010010001101000100011" + . "000101101000100011000101000100011101101100011101011\n"; + $this->assertEquals($expected, $grid); + + $bobj = $barcode->getBarcodeObj('C128', "\tABCD\tabc\tABCdef"); + $grid = $bobj->getGrid(); + $expected = "1101000010010000110100101000110001000101100010001000110101100010001000011010010111101110100101" + . "10000100100001101000010110011101011110100001101001010001100010001011000100010001101011110111010000100" + . "1101011001000010110000100100001100101100011101011\n"; + $this->assertEquals($expected, $grid); + + $bobj = $barcode->getBarcodeObj('C128', "\tABCD\tabc\tdef"); + $grid = $bobj->getGrid(); + $expected = "1101000010010000110100101000110001000101100010001000110101100010001000011010010111101110100101" + . "10000100100001101000010110011110100010100001101001000010011010110010000101100001001111010100011000111" + . "01011\n"; + $this->assertEquals($expected, $grid); + + $bobj = $barcode->getBarcodeObj('C128', chr(241) . "\tABCD"); + $grid = $bobj->getGrid(); + $expected = "1101000010011110101110111101011101000011010010100011000100010110001000100011010110001000110111" + . "011101100011101011\n"; + $this->assertEquals($expected, $grid); + + $bobj = $barcode->getBarcodeObj('C128', "\ta"); + $grid = $bobj->getGrid(); + $expected = "11010000100100001101001111010001010010110000110111000101100011101011\n"; + $this->assertEquals($expected, $grid); + + $bobj = $barcode->getBarcodeObj('C128', chr(241) . '00123456780000000001'); + $grid = $bobj->getGrid(); + $expected = "1101001110011110101110111101011101101100110010110011100100010110001110001011011000010100110110" + . "0110011011001100110110011001101100110011001101100100101111001100011101011\n"; + $this->assertEquals($expected, $grid); + + $bobj = $barcode->getBarcodeObj('C128', chr(241) . '42029651' . chr(241) . '9405510200864168997758'); + $grid = $bobj->getGrid(); + $expected = "11010011100111101011101111010111010110111000110011001101011110001011011101000101111011101111010" + . "1110101110111101000101111010001001100110111010001100110011011011001100111101001001100010001010" + . "000100110101110111101111011101011101100010100100110001100011101011\n"; + $this->assertEquals($expected, $grid); + } +} diff --git a/vendor/tecnickcom/tc-lib-barcode/test/Linear/CodeThreeNineCheckTest.php b/vendor/tecnickcom/tc-lib-barcode/test/Linear/CodeThreeNineCheckTest.php new file mode 100644 index 0000000..91b6f85 --- /dev/null +++ b/vendor/tecnickcom/tc-lib-barcode/test/Linear/CodeThreeNineCheckTest.php @@ -0,0 +1,49 @@ + + * @copyright 2015-2024 Nicola Asuni - Tecnick.com LTD + * @license http://www.gnu.org/copyleft/lesser.html GNU-LGPL v3 (see LICENSE.TXT) + * @link https://github.com/tecnickcom/tc-lib-barcode + * + * This file is part of tc-lib-barcode software library. + */ + +namespace Test\Linear; + +use Test\TestUtil; + +/** + * Barcode class test + * + * @since 2015-02-21 + * @category Library + * @package Barcode + * @author Nicola Asuni + * @copyright 2015-2024 Nicola Asuni - Tecnick.com LTD + * @license http://www.gnu.org/copyleft/lesser.html GNU-LGPL v3 (see LICENSE.TXT) + * @link https://github.com/tecnickcom/tc-lib-barcode + */ +class CodeThreeNineCheckTest extends TestUtil +{ + protected function getTestObject(): \Com\Tecnick\Barcode\Barcode + { + return new \Com\Tecnick\Barcode\Barcode(); + } + + public function testGetGrid(): void + { + $barcode = $this->getTestObject(); + $type = $barcode->getBarcodeObj('C39+', '0123456789'); + $grid = $type->getGrid(); + $expected = "10001011101110101010001110111010111010001010111010111000101011101110111000101010101000" + . "111010111011101000111010101011100011101010101000101110111011101000101110101011100010111010101" + . "1100010101110100010111011101\n"; + $this->assertEquals($expected, $grid); + } +} diff --git a/vendor/tecnickcom/tc-lib-barcode/test/Linear/CodeThreeNineExtCheckTest.php b/vendor/tecnickcom/tc-lib-barcode/test/Linear/CodeThreeNineExtCheckTest.php new file mode 100644 index 0000000..c9a1147 --- /dev/null +++ b/vendor/tecnickcom/tc-lib-barcode/test/Linear/CodeThreeNineExtCheckTest.php @@ -0,0 +1,56 @@ + + * @copyright 2015-2024 Nicola Asuni - Tecnick.com LTD + * @license http://www.gnu.org/copyleft/lesser.html GNU-LGPL v3 (see LICENSE.TXT) + * @link https://github.com/tecnickcom/tc-lib-barcode + * + * This file is part of tc-lib-barcode software library. + */ + +namespace Test\Linear; + +use Test\TestUtil; + +/** + * Barcode class test + * + * @since 2015-02-21 + * @category Library + * @package Barcode + * @author Nicola Asuni + * @copyright 2015-2024 Nicola Asuni - Tecnick.com LTD + * @license http://www.gnu.org/copyleft/lesser.html GNU-LGPL v3 (see LICENSE.TXT) + * @link https://github.com/tecnickcom/tc-lib-barcode + */ +class CodeThreeNineExtCheckTest extends TestUtil +{ + protected function getTestObject(): \Com\Tecnick\Barcode\Barcode + { + return new \Com\Tecnick\Barcode\Barcode(); + } + + public function testGetGrid(): void + { + $barcode = $this->getTestObject(); + $type = $barcode->getBarcodeObj('C39E+', '0123456789'); + $grid = $type->getGrid(); + $expected = "10001011101110101010001110111010111010001010111010111000101011101110111000101010101000" + . "111010111011101000111010101011100011101010101000101110111011101000101110101011100010111010101" + . "1100010101110100010111011101\n"; + $this->assertEquals($expected, $grid); + } + + public function testInvalidInput(): void + { + $this->bcExpectException('\\' . \Com\Tecnick\Barcode\Exception::class); + $barcode = $this->getTestObject(); + $barcode->getBarcodeObj('C39E+', chr(218)); + } +} diff --git a/vendor/tecnickcom/tc-lib-barcode/test/Linear/CodeThreeNineExtTest.php b/vendor/tecnickcom/tc-lib-barcode/test/Linear/CodeThreeNineExtTest.php new file mode 100644 index 0000000..07c7cf6 --- /dev/null +++ b/vendor/tecnickcom/tc-lib-barcode/test/Linear/CodeThreeNineExtTest.php @@ -0,0 +1,49 @@ + + * @copyright 2015-2024 Nicola Asuni - Tecnick.com LTD + * @license http://www.gnu.org/copyleft/lesser.html GNU-LGPL v3 (see LICENSE.TXT) + * @link https://github.com/tecnickcom/tc-lib-barcode + * + * This file is part of tc-lib-barcode software library. + */ + +namespace Test\Linear; + +use Test\TestUtil; + +/** + * Barcode class test + * + * @since 2015-02-21 + * @category Library + * @package Barcode + * @author Nicola Asuni + * @copyright 2015-2024 Nicola Asuni - Tecnick.com LTD + * @license http://www.gnu.org/copyleft/lesser.html GNU-LGPL v3 (see LICENSE.TXT) + * @link https://github.com/tecnickcom/tc-lib-barcode + */ +class CodeThreeNineExtTest extends TestUtil +{ + protected function getTestObject(): \Com\Tecnick\Barcode\Barcode + { + return new \Com\Tecnick\Barcode\Barcode(); + } + + public function testGetGrid(): void + { + $barcode = $this->getTestObject(); + $type = $barcode->getBarcodeObj('C39E', '0123456789'); + $grid = $type->getGrid(); + $expected = "10001011101110101010001110111010111010001010111010111000101011101110111000101010101000" + . "111010111011101000111010101011100011101010101000101110111011101000101110101011100010111010100" + . "010111011101\n"; + $this->assertEquals($expected, $grid); + } +} diff --git a/vendor/tecnickcom/tc-lib-barcode/test/Linear/CodeThreeNineTest.php b/vendor/tecnickcom/tc-lib-barcode/test/Linear/CodeThreeNineTest.php new file mode 100644 index 0000000..e6134e6 --- /dev/null +++ b/vendor/tecnickcom/tc-lib-barcode/test/Linear/CodeThreeNineTest.php @@ -0,0 +1,56 @@ + + * @copyright 2015-2024 Nicola Asuni - Tecnick.com LTD + * @license http://www.gnu.org/copyleft/lesser.html GNU-LGPL v3 (see LICENSE.TXT) + * @link https://github.com/tecnickcom/tc-lib-barcode + * + * This file is part of tc-lib-barcode software library. + */ + +namespace Test\Linear; + +use Test\TestUtil; + +/** + * Barcode class test + * + * @since 2015-02-21 + * @category Library + * @package Barcode + * @author Nicola Asuni + * @copyright 2015-2024 Nicola Asuni - Tecnick.com LTD + * @license http://www.gnu.org/copyleft/lesser.html GNU-LGPL v3 (see LICENSE.TXT) + * @link https://github.com/tecnickcom/tc-lib-barcode + */ +class CodeThreeNineTest extends TestUtil +{ + protected function getTestObject(): \Com\Tecnick\Barcode\Barcode + { + return new \Com\Tecnick\Barcode\Barcode(); + } + + public function testGetGrid(): void + { + $barcode = $this->getTestObject(); + $type = $barcode->getBarcodeObj('C39', '0123456789'); + $grid = $type->getGrid(); + $expected = "10001011101110101010001110111010111010001010111010111000101011101110" + . "111000101010101000111010111011101000111010101011100011101010101000101110111" + . "011101000101110101011100010111010100010111011101\n"; + $this->assertEquals($expected, $grid); + } + + public function testInvalidInput(): void + { + $this->bcExpectException('\\' . \Com\Tecnick\Barcode\Exception::class); + $barcode = $this->getTestObject(); + $barcode->getBarcodeObj('C39', chr(218)); + } +} diff --git a/vendor/tecnickcom/tc-lib-barcode/test/Linear/EanEightTest.php b/vendor/tecnickcom/tc-lib-barcode/test/Linear/EanEightTest.php new file mode 100644 index 0000000..811630c --- /dev/null +++ b/vendor/tecnickcom/tc-lib-barcode/test/Linear/EanEightTest.php @@ -0,0 +1,50 @@ + + * @copyright 2015-2024 Nicola Asuni - Tecnick.com LTD + * @license http://www.gnu.org/copyleft/lesser.html GNU-LGPL v3 (see LICENSE.TXT) + * @link https://github.com/tecnickcom/tc-lib-barcode + * + * This file is part of tc-lib-barcode software library. + */ + +namespace Test\Linear; + +use Test\TestUtil; + +/** + * Barcode class test + * + * @since 2015-02-21 + * @category Library + * @package Barcode + * @author Nicola Asuni + * @copyright 2015-2024 Nicola Asuni - Tecnick.com LTD + * @license http://www.gnu.org/copyleft/lesser.html GNU-LGPL v3 (see LICENSE.TXT) + * @link https://github.com/tecnickcom/tc-lib-barcode + */ +class EanEightTest extends TestUtil +{ + protected function getTestObject(): \Com\Tecnick\Barcode\Barcode + { + return new \Com\Tecnick\Barcode\Barcode(); + } + + public function testGetGrid(): void + { + $barcode = $this->getTestObject(); + $type = $barcode->getBarcodeObj( + 'EAN8', + '1234567' + ); + $grid = $type->getGrid(); + $expected = "1010011001001001101111010100011010101001110101000010001001110010101\n"; + $this->assertEquals($expected, $grid); + } +} diff --git a/vendor/tecnickcom/tc-lib-barcode/test/Linear/EanFiveTest.php b/vendor/tecnickcom/tc-lib-barcode/test/Linear/EanFiveTest.php new file mode 100644 index 0000000..40da653 --- /dev/null +++ b/vendor/tecnickcom/tc-lib-barcode/test/Linear/EanFiveTest.php @@ -0,0 +1,50 @@ + + * @copyright 2015-2024 Nicola Asuni - Tecnick.com LTD + * @license http://www.gnu.org/copyleft/lesser.html GNU-LGPL v3 (see LICENSE.TXT) + * @link https://github.com/tecnickcom/tc-lib-barcode + * + * This file is part of tc-lib-barcode software library. + */ + +namespace Test\Linear; + +use Test\TestUtil; + +/** + * Barcode class test + * + * @since 2015-02-21 + * @category Library + * @package Barcode + * @author Nicola Asuni + * @copyright 2015-2024 Nicola Asuni - Tecnick.com LTD + * @license http://www.gnu.org/copyleft/lesser.html GNU-LGPL v3 (see LICENSE.TXT) + * @link https://github.com/tecnickcom/tc-lib-barcode + */ +class EanFiveTest extends TestUtil +{ + protected function getTestObject(): \Com\Tecnick\Barcode\Barcode + { + return new \Com\Tecnick\Barcode\Barcode(); + } + + public function testGetGrid(): void + { + $barcode = $this->getTestObject(); + $type = $barcode->getBarcodeObj( + 'EAN5', + '12345' + ); + $grid = $type->getGrid(); + $expected = "10110110011010010011010100001010100011010110001\n"; + $this->assertEquals($expected, $grid); + } +} diff --git a/vendor/tecnickcom/tc-lib-barcode/test/Linear/EanOneThreeTest.php b/vendor/tecnickcom/tc-lib-barcode/test/Linear/EanOneThreeTest.php new file mode 100644 index 0000000..45a2c33 --- /dev/null +++ b/vendor/tecnickcom/tc-lib-barcode/test/Linear/EanOneThreeTest.php @@ -0,0 +1,63 @@ + + * @copyright 2015-2024 Nicola Asuni - Tecnick.com LTD + * @license http://www.gnu.org/copyleft/lesser.html GNU-LGPL v3 (see LICENSE.TXT) + * @link https://github.com/tecnickcom/tc-lib-barcode + * + * This file is part of tc-lib-barcode software library. + */ + +namespace Test\Linear; + +use Test\TestUtil; + +/** + * Barcode class test + * + * @since 2015-02-21 + * @category Library + * @package Barcode + * @author Nicola Asuni + * @copyright 2015-2024 Nicola Asuni - Tecnick.com LTD + * @license http://www.gnu.org/copyleft/lesser.html GNU-LGPL v3 (see LICENSE.TXT) + * @link https://github.com/tecnickcom/tc-lib-barcode + */ +class EanOneThreeTest extends TestUtil +{ + protected function getTestObject(): \Com\Tecnick\Barcode\Barcode + { + return new \Com\Tecnick\Barcode\Barcode(); + } + + public function testGetGrid(): void + { + $barcode = $this->getTestObject(); + $type = $barcode->getBarcodeObj('EAN13', '0123456789'); + $grid = $type->getGrid(); + $expected = "10100011010001101001100100100110111101010001101010100111010100001000100100100011101001001110101\n"; + $this->assertEquals($expected, $grid); + + $this->assertEquals('0001234567895', $type->getExtendedCode()); + } + + public function testInvalidInput(): void + { + $this->bcExpectException('\\' . \Com\Tecnick\Barcode\Exception::class); + $barcode = $this->getTestObject(); + $barcode->getBarcodeObj('EAN13', '}{'); + } + + public function testInvalidLength(): void + { + $this->bcExpectException('\\' . \Com\Tecnick\Barcode\Exception::class); + $barcode = $this->getTestObject(); + $barcode->getBarcodeObj('EAN13', '1111111111111'); + } +} diff --git a/vendor/tecnickcom/tc-lib-barcode/test/Linear/EanTwoTest.php b/vendor/tecnickcom/tc-lib-barcode/test/Linear/EanTwoTest.php new file mode 100644 index 0000000..adc9c3a --- /dev/null +++ b/vendor/tecnickcom/tc-lib-barcode/test/Linear/EanTwoTest.php @@ -0,0 +1,50 @@ + + * @copyright 2015-2024 Nicola Asuni - Tecnick.com LTD + * @license http://www.gnu.org/copyleft/lesser.html GNU-LGPL v3 (see LICENSE.TXT) + * @link https://github.com/tecnickcom/tc-lib-barcode + * + * This file is part of tc-lib-barcode software library. + */ + +namespace Test\Linear; + +use Test\TestUtil; + +/** + * Barcode class test + * + * @since 2015-02-21 + * @category Library + * @package Barcode + * @author Nicola Asuni + * @copyright 2015-2024 Nicola Asuni - Tecnick.com LTD + * @license http://www.gnu.org/copyleft/lesser.html GNU-LGPL v3 (see LICENSE.TXT) + * @link https://github.com/tecnickcom/tc-lib-barcode + */ +class EanTwoTest extends TestUtil +{ + protected function getTestObject(): \Com\Tecnick\Barcode\Barcode + { + return new \Com\Tecnick\Barcode\Barcode(); + } + + public function testGetGrid(): void + { + $barcode = $this->getTestObject(); + $type = $barcode->getBarcodeObj( + 'EAN2', + '12' + ); + $grid = $type->getGrid(); + $expected = "10110011001010010011\n"; + $this->assertEquals($expected, $grid); + } +} diff --git a/vendor/tecnickcom/tc-lib-barcode/test/Linear/ImbPreTest.php b/vendor/tecnickcom/tc-lib-barcode/test/Linear/ImbPreTest.php new file mode 100644 index 0000000..71fb02f --- /dev/null +++ b/vendor/tecnickcom/tc-lib-barcode/test/Linear/ImbPreTest.php @@ -0,0 +1,62 @@ + + * @copyright 2015-2024 Nicola Asuni - Tecnick.com LTD + * @license http://www.gnu.org/copyleft/lesser.html GNU-LGPL v3 (see LICENSE.TXT) + * @link https://github.com/tecnickcom/tc-lib-barcode + * + * This file is part of tc-lib-barcode software library. + */ + +namespace Test\Linear; + +use Test\TestUtil; + +/** + * Barcode class test + * + * @since 2015-02-21 + * @category Library + * @package Barcode + * @author Nicola Asuni + * @copyright 2015-2024 Nicola Asuni - Tecnick.com LTD + * @license http://www.gnu.org/copyleft/lesser.html GNU-LGPL v3 (see LICENSE.TXT) + * @link https://github.com/tecnickcom/tc-lib-barcode + */ +class ImbPreTest extends TestUtil +{ + protected function getTestObject(): \Com\Tecnick\Barcode\Barcode + { + return new \Com\Tecnick\Barcode\Barcode(); + } + + public function testGetGrid(): void + { + $barcode = $this->getTestObject(); + $type = $barcode->getBarcodeObj( + 'IMBPRE', + 'fatdfatdfatdfatdfatdfatdfatdfatdfatdfatdfatdfatdfatdfatdfatdfatdf' + ); + $grid = $type->getGrid(); + $expected = "101000001010000010100000101000001010000010100000101000001010" + . "000010100000101000001010000010100000101000001010000010100000101000001\n" + . "1010101010101010101010101010101010101010101010101010101010101010101" + . "01010101010101010101010101010101010101010101010101010101010101\n" + . "1000001010000010100000101000001010000010100000101000001010000010100" + . "00010100000101000001010000010100000101000001010000010100000101\n"; + $this->assertEquals($expected, $grid); + } + + public function testInvalidInput(): void + { + $this->bcExpectException('\\' . \Com\Tecnick\Barcode\Exception::class); + $barcode = $this->getTestObject(); + $barcode->getBarcodeObj('IMBPRE', 'fatd'); + } +} diff --git a/vendor/tecnickcom/tc-lib-barcode/test/Linear/ImbTest.php b/vendor/tecnickcom/tc-lib-barcode/test/Linear/ImbTest.php new file mode 100644 index 0000000..0fb9c38 --- /dev/null +++ b/vendor/tecnickcom/tc-lib-barcode/test/Linear/ImbTest.php @@ -0,0 +1,119 @@ + + * @copyright 2015-2024 Nicola Asuni - Tecnick.com LTD + * @license http://www.gnu.org/copyleft/lesser.html GNU-LGPL v3 (see LICENSE.TXT) + * @link https://github.com/tecnickcom/tc-lib-barcode + * + * This file is part of tc-lib-barcode software library. + */ + +namespace Test\Linear; + +use Test\TestUtil; + +/** + * Barcode class test + * + * @since 2015-02-21 + * @category Library + * @package Barcode + * @author Nicola Asuni + * @copyright 2015-2024 Nicola Asuni - Tecnick.com LTD + * @license http://www.gnu.org/copyleft/lesser.html GNU-LGPL v3 (see LICENSE.TXT) + * @link https://github.com/tecnickcom/tc-lib-barcode + */ +class ImbTest extends TestUtil +{ + protected function getTestObject(): \Com\Tecnick\Barcode\Barcode + { + return new \Com\Tecnick\Barcode\Barcode(); + } + + public function testGetGrid(): void + { + $barcode = $this->getTestObject(); + $bobj = $barcode->getBarcodeObj('IMB', '00000-'); + $grid = $bobj->getGrid(); + $expected = "100000101010001000101000101000000010000010100010001010100000" + . "100010001000000010101000001010101000100000000000100010001000100000001\n" + . "1010101010101010101010101010101010101010101010101010101010101010101" + . "01010101010101010101010101010101010101010101010101010101010101\n" + . "0000101000000010000010001000000000101010000010000000001000101010001" + . "01010001010001010000010101000101000101000000000001000001000100\n"; + $this->assertEquals($expected, $grid); + + $bobj = $barcode->getBarcodeObj('IMB', '0123456789'); + $grid = $bobj->getGrid(); + $expected = "001010100010101000100010001010101010001000001000101010001010" + . "101010100000000000000010101000000010001010100010001000101010001000001\n" + . "1010101010101010101010101010101010101010101010101010101010101010101" + . "01010101010101010101010101010101010101010101010101010101010101\n" + . "1010101010101000001010000010101000000000000010100010001010000000000" + . "00010100000100010001000001010101000001010000010101010100010101\n"; + $this->assertEquals($expected, $grid); + + $bobj = $barcode->getBarcodeObj('IMB', '01234567094987654321-01234567891'); + $grid = $bobj->getGrid(); + $expected = "10100000101000100000100000101000101000100000000010101000000000000000101010001" + . "0000000001010100000000000100010101010001000001010001\n" + . "101010101010101010101010101010101010101010101010101010101010101010101010101010101010" + . "101010101010101010101010101010101010101010101\n" + . "000010001010101000100010000000100000001010001010000000101000100000100010001000101010" + . "001010101010000000001010000000101000100000100\n"; + $this->assertEquals($expected, $grid); + + $bobj = $barcode->getBarcodeObj('IMB', '01234567094987654321-012345678'); + $grid = $bobj->getGrid(); + $expected = "10001000001010000000000010100000100000101010001000100010000010101010000010001" + . "0001000000000000000100000001000100010000000101000101\n" + . "101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010" + . "101010101010101010101010101010101\n" + . "001010000000101000000000100000000010000000000010001000000010000000101010001000000000100010000010" + . "101000100000001000100010101000100\n"; + $this->assertEquals($expected, $grid); + + $bobj = $barcode->getBarcodeObj('IMB', '01234567094987654321-01234'); + $grid = $bobj->getGrid(); + $expected = "00000010101000000000100000001000100000000010001000101010001010000000100010101" + . "0100000001000101010100000100000001010000000000010100\n" + . "101010101010101010101010101010101010101010101010101010101010101010101010101010101010" + . "101010101010101010101010101010101010101010101\n" + . "100000001000101000001000100010001010001010001000100010001010000010101000000000101000" + . "000010100000000010101000101000101010001010100\n"; + $this->assertEquals($expected, $grid); + + $bobj = $barcode->getBarcodeObj('IMB', '01234567094987654321-'); + $grid = $bobj->getGrid(); + $expected = "10000010100000000000100000101000000000000010000000101000001010001000100010101" + . "0101000100010101010100000101000001010001000100000000\n" + . "101010101010101010101010101010101010101010101010101010101010101010101010101010101010" + . "101010101010101010101010101010101010101010101\n" + . "000000100000001000000010000000000010001000000000100010101010001010101000101010101000" + . "000010000000000010101000100000101000101000100\n"; + $this->assertEquals($expected, $grid); + + $bobj = $barcode->getBarcodeObj('IMB', '01234567094987654321-01234567891'); + $grid = $bobj->getGrid(); + $expected = "10100000101000100000100000101000101000100000000010101000000000000000101010001" + . "0000000001010100000000000100010101010001000001010001\n" + . "101010101010101010101010101010101010101010101010101010101010101010101010101010101010" + . "101010101010101010101010101010101010101010101\n" + . "000010001010101000100010000000100000001010001010000000101000100000100010001000101010" + . "001010101010000000001010000000101000100000100\n"; + $this->assertEquals($expected, $grid); + } + + public function testInvalidRoutingCode(): void + { + $this->bcExpectException('\\' . \Com\Tecnick\Barcode\Exception::class); + $barcode = $this->getTestObject(); + $barcode->getBarcodeObj('IMB', '01234567094987654321-1'); + } +} diff --git a/vendor/tecnickcom/tc-lib-barcode/test/Linear/InterleavedTwoOfFiveCheckTest.php b/vendor/tecnickcom/tc-lib-barcode/test/Linear/InterleavedTwoOfFiveCheckTest.php new file mode 100644 index 0000000..c1b65f9 --- /dev/null +++ b/vendor/tecnickcom/tc-lib-barcode/test/Linear/InterleavedTwoOfFiveCheckTest.php @@ -0,0 +1,57 @@ + + * @copyright 2015-2024 Nicola Asuni - Tecnick.com LTD + * @license http://www.gnu.org/copyleft/lesser.html GNU-LGPL v3 (see LICENSE.TXT) + * @link https://github.com/tecnickcom/tc-lib-barcode + * + * This file is part of tc-lib-barcode software library. + */ + +namespace Test\Linear; + +use Test\TestUtil; + +/** + * Barcode class test + * + * @since 2015-02-21 + * @category Library + * @package Barcode + * @author Nicola Asuni + * @copyright 2015-2024 Nicola Asuni - Tecnick.com LTD + * @license http://www.gnu.org/copyleft/lesser.html GNU-LGPL v3 (see LICENSE.TXT) + * @link https://github.com/tecnickcom/tc-lib-barcode + */ +class InterleavedTwoOfFiveCheckTest extends TestUtil +{ + protected function getTestObject(): \Com\Tecnick\Barcode\Barcode + { + return new \Com\Tecnick\Barcode\Barcode(); + } + + public function testGetGrid(): void + { + $barcode = $this->getTestObject(); + $type = $barcode->getBarcodeObj( + 'I25+', + '0123456789' + ); + $grid = $type->getGrid(); + $expected = "10101010110011001011010010101100110110100101001101001100101010010101100110100110100110101101\n"; + $this->assertEquals($expected, $grid); + } + + public function testInvalidInput(): void + { + $this->bcExpectException('\\' . \Com\Tecnick\Barcode\Exception::class); + $barcode = $this->getTestObject(); + $barcode->getBarcodeObj('I25+', 'GHI'); + } +} diff --git a/vendor/tecnickcom/tc-lib-barcode/test/Linear/InterleavedTwoOfFiveTest.php b/vendor/tecnickcom/tc-lib-barcode/test/Linear/InterleavedTwoOfFiveTest.php new file mode 100644 index 0000000..d8dd0fe --- /dev/null +++ b/vendor/tecnickcom/tc-lib-barcode/test/Linear/InterleavedTwoOfFiveTest.php @@ -0,0 +1,50 @@ + + * @copyright 2015-2024 Nicola Asuni - Tecnick.com LTD + * @license http://www.gnu.org/copyleft/lesser.html GNU-LGPL v3 (see LICENSE.TXT) + * @link https://github.com/tecnickcom/tc-lib-barcode + * + * This file is part of tc-lib-barcode software library. + */ + +namespace Test\Linear; + +use Test\TestUtil; + +/** + * Barcode class test + * + * @since 2015-02-21 + * @category Library + * @package Barcode + * @author Nicola Asuni + * @copyright 2015-2024 Nicola Asuni - Tecnick.com LTD + * @license http://www.gnu.org/copyleft/lesser.html GNU-LGPL v3 (see LICENSE.TXT) + * @link https://github.com/tecnickcom/tc-lib-barcode + */ +class InterleavedTwoOfFiveTest extends TestUtil +{ + protected function getTestObject(): \Com\Tecnick\Barcode\Barcode + { + return new \Com\Tecnick\Barcode\Barcode(); + } + + public function testGetGrid(): void + { + $barcode = $this->getTestObject(); + $type = $barcode->getBarcodeObj( + 'I25', + '0123456789' + ); + $grid = $type->getGrid(); + $expected = "101010010110110100100110010101101001011001011010110110100100110100101100101101\n"; + $this->assertEquals($expected, $grid); + } +} diff --git a/vendor/tecnickcom/tc-lib-barcode/test/Linear/KlantIndexTest.php b/vendor/tecnickcom/tc-lib-barcode/test/Linear/KlantIndexTest.php new file mode 100644 index 0000000..c89c528 --- /dev/null +++ b/vendor/tecnickcom/tc-lib-barcode/test/Linear/KlantIndexTest.php @@ -0,0 +1,49 @@ + + * @copyright 2015-2024 Nicola Asuni - Tecnick.com LTD + * @license http://www.gnu.org/copyleft/lesser.html GNU-LGPL v3 (see LICENSE.TXT) + * @link https://github.com/tecnickcom/tc-lib-barcode + * + * This file is part of tc-lib-barcode software library. + */ + +namespace Test\Linear; + +use Test\TestUtil; + +/** + * Barcode class test + * + * @since 2015-02-21 + * @category Library + * @package Barcode + * @author Nicola Asuni + * @copyright 2015-2024 Nicola Asuni - Tecnick.com LTD + * @license http://www.gnu.org/copyleft/lesser.html GNU-LGPL v3 (see LICENSE.TXT) + * @link https://github.com/tecnickcom/tc-lib-barcode + */ +class KlantIndexTest extends TestUtil +{ + protected function getTestObject(): \Com\Tecnick\Barcode\Barcode + { + return new \Com\Tecnick\Barcode\Barcode(); + } + + public function testGetGrid(): void + { + $barcode = $this->getTestObject(); + $type = $barcode->getBarcodeObj('KIX', '0123456789'); + $grid = $type->getGrid(); + $expected = "00001010000010100000101000001010000010100000101000100010001000100010001000100010\n" + . "10101010101010101010101010101010101010101010101010101010101010101010101010101010\n" + . "00001010001000100010100010000010100010001010000000001010001000100010100010000010\n"; + $this->assertEquals($expected, $grid); + } +} diff --git a/vendor/tecnickcom/tc-lib-barcode/test/Linear/MsiCheckTest.php b/vendor/tecnickcom/tc-lib-barcode/test/Linear/MsiCheckTest.php new file mode 100644 index 0000000..17069a6 --- /dev/null +++ b/vendor/tecnickcom/tc-lib-barcode/test/Linear/MsiCheckTest.php @@ -0,0 +1,56 @@ + + * @copyright 2015-2024 Nicola Asuni - Tecnick.com LTD + * @license http://www.gnu.org/copyleft/lesser.html GNU-LGPL v3 (see LICENSE.TXT) + * @link https://github.com/tecnickcom/tc-lib-barcode + * + * This file is part of tc-lib-barcode software library. + */ + +namespace Test\Linear; + +use Test\TestUtil; + +/** + * Barcode class test + * + * @since 2015-02-21 + * @category Library + * @package Barcode + * @author Nicola Asuni + * @copyright 2015-2024 Nicola Asuni - Tecnick.com LTD + * @license http://www.gnu.org/copyleft/lesser.html GNU-LGPL v3 (see LICENSE.TXT) + * @link https://github.com/tecnickcom/tc-lib-barcode + */ +class MsiCheckTest extends TestUtil +{ + protected function getTestObject(): \Com\Tecnick\Barcode\Barcode + { + return new \Com\Tecnick\Barcode\Barcode(); + } + + public function testGetGrid(): void + { + $barcode = $this->getTestObject(); + $type = $barcode->getBarcodeObj('MSI+', '0123456789ABCDEF'); + $grid = $type->getGrid(); + $expected = "110100100100100100100100110100100110100100100110110100110100100100110100110100110110100" + . "1001101101101101001001001101001001101101001101001101001101101101101001001101101001101101101101" + . "001101101101101001001001101001\n"; + $this->assertEquals($expected, $grid); + } + + public function testInvalidInput(): void + { + $this->bcExpectException('\\' . \Com\Tecnick\Barcode\Exception::class); + $barcode = $this->getTestObject(); + $barcode->getBarcodeObj('MSI+', 'GHI'); + } +} diff --git a/vendor/tecnickcom/tc-lib-barcode/test/Linear/MsiTest.php b/vendor/tecnickcom/tc-lib-barcode/test/Linear/MsiTest.php new file mode 100644 index 0000000..b94bacb --- /dev/null +++ b/vendor/tecnickcom/tc-lib-barcode/test/Linear/MsiTest.php @@ -0,0 +1,48 @@ + + * @copyright 2015-2024 Nicola Asuni - Tecnick.com LTD + * @license http://www.gnu.org/copyleft/lesser.html GNU-LGPL v3 (see LICENSE.TXT) + * @link https://github.com/tecnickcom/tc-lib-barcode + * + * This file is part of tc-lib-barcode software library. + */ + +namespace Test\Linear; + +use Test\TestUtil; + +/** + * Barcode class test + * + * @since 2015-02-21 + * @category Library + * @package Barcode + * @author Nicola Asuni + * @copyright 2015-2024 Nicola Asuni - Tecnick.com LTD + * @license http://www.gnu.org/copyleft/lesser.html GNU-LGPL v3 (see LICENSE.TXT) + * @link https://github.com/tecnickcom/tc-lib-barcode + */ +class MsiTest extends TestUtil +{ + protected function getTestObject(): \Com\Tecnick\Barcode\Barcode + { + return new \Com\Tecnick\Barcode\Barcode(); + } + + public function testGetGrid(): void + { + $barcode = $this->getTestObject(); + $type = $barcode->getBarcodeObj('MSI', '0123456789'); + $grid = $type->getGrid(); + $expected = "110100100100100100100100110100100110100100100110110100110100" + . "1001001101001101001101101001001101101101101001001001101001001101001\n"; + $this->assertEquals($expected, $grid); + } +} diff --git a/vendor/tecnickcom/tc-lib-barcode/test/Linear/PharmaTest.php b/vendor/tecnickcom/tc-lib-barcode/test/Linear/PharmaTest.php new file mode 100644 index 0000000..260acbc --- /dev/null +++ b/vendor/tecnickcom/tc-lib-barcode/test/Linear/PharmaTest.php @@ -0,0 +1,48 @@ + + * @copyright 2015-2024 Nicola Asuni - Tecnick.com LTD + * @license http://www.gnu.org/copyleft/lesser.html GNU-LGPL v3 (see LICENSE.TXT) + * @link https://github.com/tecnickcom/tc-lib-barcode + * + * This file is part of tc-lib-barcode software library. + */ + +namespace Test\Linear; + +use Test\TestUtil; + +/** + * Barcode class test + * + * @since 2015-02-21 + * @category Library + * @package Barcode + * @author Nicola Asuni + * @copyright 2015-2024 Nicola Asuni - Tecnick.com LTD + * @license http://www.gnu.org/copyleft/lesser.html GNU-LGPL v3 (see LICENSE.TXT) + * @link https://github.com/tecnickcom/tc-lib-barcode + */ +class PharmaTest extends TestUtil +{ + protected function getTestObject(): \Com\Tecnick\Barcode\Barcode + { + return new \Com\Tecnick\Barcode\Barcode(); + } + + public function testGetGrid(): void + { + $barcode = $this->getTestObject(); + $type = $barcode->getBarcodeObj('PHARMA', '0123456789'); + $grid = $type->getGrid(); + $expected = "111001110010011100100111001110010011100111001110011100100" + . "1001110011100100111001001001001110010011100111001\n"; + $this->assertEquals($expected, $grid); + } +} diff --git a/vendor/tecnickcom/tc-lib-barcode/test/Linear/PharmaTwoTracksTest.php b/vendor/tecnickcom/tc-lib-barcode/test/Linear/PharmaTwoTracksTest.php new file mode 100644 index 0000000..d96333c --- /dev/null +++ b/vendor/tecnickcom/tc-lib-barcode/test/Linear/PharmaTwoTracksTest.php @@ -0,0 +1,47 @@ + + * @copyright 2015-2024 Nicola Asuni - Tecnick.com LTD + * @license http://www.gnu.org/copyleft/lesser.html GNU-LGPL v3 (see LICENSE.TXT) + * @link https://github.com/tecnickcom/tc-lib-barcode + * + * This file is part of tc-lib-barcode software library. + */ + +namespace Test\Linear; + +use Test\TestUtil; + +/** + * Barcode class test + * + * @since 2015-02-21 + * @category Library + * @package Barcode + * @author Nicola Asuni + * @copyright 2015-2024 Nicola Asuni - Tecnick.com LTD + * @license http://www.gnu.org/copyleft/lesser.html GNU-LGPL v3 (see LICENSE.TXT) + * @link https://github.com/tecnickcom/tc-lib-barcode + */ +class PharmaTwoTracksTest extends TestUtil +{ + protected function getTestObject(): \Com\Tecnick\Barcode\Barcode + { + return new \Com\Tecnick\Barcode\Barcode(); + } + + public function testGetGrid(): void + { + $barcode = $this->getTestObject(); + $type = $barcode->getBarcodeObj('PHARMA2T', '0123456789'); + $grid = $type->getGrid(); + $expected = "101000001010100010001010001000101\n000010101010001010101000100010001\n"; + $this->assertEquals($expected, $grid); + } +} diff --git a/vendor/tecnickcom/tc-lib-barcode/test/Linear/PlanetTest.php b/vendor/tecnickcom/tc-lib-barcode/test/Linear/PlanetTest.php new file mode 100644 index 0000000..3683e6f --- /dev/null +++ b/vendor/tecnickcom/tc-lib-barcode/test/Linear/PlanetTest.php @@ -0,0 +1,50 @@ + + * @copyright 2015-2024 Nicola Asuni - Tecnick.com LTD + * @license http://www.gnu.org/copyleft/lesser.html GNU-LGPL v3 (see LICENSE.TXT) + * @link https://github.com/tecnickcom/tc-lib-barcode + * + * This file is part of tc-lib-barcode software library. + */ + +namespace Test\Linear; + +use Test\TestUtil; + +/** + * Barcode class test + * + * @since 2015-02-21 + * @category Library + * @package Barcode + * @author Nicola Asuni + * @copyright 2015-2024 Nicola Asuni - Tecnick.com LTD + * @license http://www.gnu.org/copyleft/lesser.html GNU-LGPL v3 (see LICENSE.TXT) + * @link https://github.com/tecnickcom/tc-lib-barcode + */ +class PlanetTest extends TestUtil +{ + protected function getTestObject(): \Com\Tecnick\Barcode\Barcode + { + return new \Com\Tecnick\Barcode\Barcode(); + } + + public function testGetGrid(): void + { + $barcode = $this->getTestObject(); + $type = $barcode->getBarcodeObj('PLANET', '0123456789'); + $grid = $type->getGrid(); + $expected = "100000101010101010000010100010001010000010100010100010" + . "00100010100000101000101010000010100010001000101010001000101\n" + . "1010101010101010101010101010101010101010101010101010101010101" + . "0101010101010101010101010101010101010101010101010101\n"; + $this->assertEquals($expected, $grid); + } +} diff --git a/vendor/tecnickcom/tc-lib-barcode/test/Linear/PostnetTest.php b/vendor/tecnickcom/tc-lib-barcode/test/Linear/PostnetTest.php new file mode 100644 index 0000000..ecc8028 --- /dev/null +++ b/vendor/tecnickcom/tc-lib-barcode/test/Linear/PostnetTest.php @@ -0,0 +1,57 @@ + + * @copyright 2015-2024 Nicola Asuni - Tecnick.com LTD + * @license http://www.gnu.org/copyleft/lesser.html GNU-LGPL v3 (see LICENSE.TXT) + * @link https://github.com/tecnickcom/tc-lib-barcode + * + * This file is part of tc-lib-barcode software library. + */ + +namespace Test\Linear; + +use Test\TestUtil; + +/** + * Barcode class test + * + * @since 2015-02-21 + * @category Library + * @package Barcode + * @author Nicola Asuni + * @copyright 2015-2024 Nicola Asuni - Tecnick.com LTD + * @license http://www.gnu.org/copyleft/lesser.html GNU-LGPL v3 (see LICENSE.TXT) + * @link https://github.com/tecnickcom/tc-lib-barcode + */ +class PostnetTest extends TestUtil +{ + protected function getTestObject(): \Com\Tecnick\Barcode\Barcode + { + return new \Com\Tecnick\Barcode\Barcode(); + } + + public function testGetGrid(): void + { + $barcode = $this->getTestObject(); + $type = $barcode->getBarcodeObj('POSTNET', '0123456789'); + $grid = $type->getGrid(); + $expected = "101010000000000000101000001000100000101000001000001000" + . "10001000001010000010000000101000001000100010000000100010001\n" + . "1010101010101010101010101010101010101010101010101010101010101" + . "0101010101010101010101010101010101010101010101010101\n"; + $this->assertEquals($expected, $grid); + } + + public function testInvalidInput(): void + { + $this->bcExpectException('\\' . \Com\Tecnick\Barcode\Exception::class); + $barcode = $this->getTestObject(); + $barcode->getBarcodeObj('POSTNET', '}{'); + } +} diff --git a/vendor/tecnickcom/tc-lib-barcode/test/Linear/RawTest.php b/vendor/tecnickcom/tc-lib-barcode/test/Linear/RawTest.php new file mode 100644 index 0000000..4e82762 --- /dev/null +++ b/vendor/tecnickcom/tc-lib-barcode/test/Linear/RawTest.php @@ -0,0 +1,52 @@ + + * @copyright 2015-2024 Nicola Asuni - Tecnick.com LTD + * @license http://www.gnu.org/copyleft/lesser.html GNU-LGPL v3 (see LICENSE.TXT) + * @link https://github.com/tecnickcom/tc-lib-barcode + * + * This file is part of tc-lib-barcode software library. + */ + +namespace Test\Linear; + +use Test\TestUtil; + +/** + * Barcode class test + * + * @since 2015-02-21 + * @category Library + * @package Barcode + * @author Nicola Asuni + * @copyright 2015-2024 Nicola Asuni - Tecnick.com LTD + * @license http://www.gnu.org/copyleft/lesser.html GNU-LGPL v3 (see LICENSE.TXT) + * @link https://github.com/tecnickcom/tc-lib-barcode + */ +class RawTest extends TestUtil +{ + protected function getTestObject(): \Com\Tecnick\Barcode\Barcode + { + return new \Com\Tecnick\Barcode\Barcode(); + } + + public function testGetGrid(): void + { + $testObj = $this->getTestObject(); + $testObj = $this->getTestObject(); + + $type = $testObj->getBarcodeObj( + 'LRAW', + '01001100011100001111,10110011100011110000' + ); + $grid = $type->getGrid(); + $expected = "01001100011100001111\n10110011100011110000\n"; + $this->assertEquals($expected, $grid); + } +} diff --git a/vendor/tecnickcom/tc-lib-barcode/test/Linear/RoyalMailFourCcTest.php b/vendor/tecnickcom/tc-lib-barcode/test/Linear/RoyalMailFourCcTest.php new file mode 100644 index 0000000..f8ba432 --- /dev/null +++ b/vendor/tecnickcom/tc-lib-barcode/test/Linear/RoyalMailFourCcTest.php @@ -0,0 +1,56 @@ + + * @copyright 2015-2024 Nicola Asuni - Tecnick.com LTD + * @license http://www.gnu.org/copyleft/lesser.html GNU-LGPL v3 (see LICENSE.TXT) + * @link https://github.com/tecnickcom/tc-lib-barcode + * + * This file is part of tc-lib-barcode software library. + */ + +namespace Test\Linear; + +use Test\TestUtil; + +/** + * Barcode class test + * + * @since 2015-02-21 + * @category Library + * @package Barcode + * @author Nicola Asuni + * @copyright 2015-2024 Nicola Asuni - Tecnick.com LTD + * @license http://www.gnu.org/copyleft/lesser.html GNU-LGPL v3 (see LICENSE.TXT) + * @link https://github.com/tecnickcom/tc-lib-barcode + */ +class RoyalMailFourCcTest extends TestUtil +{ + protected function getTestObject(): \Com\Tecnick\Barcode\Barcode + { + return new \Com\Tecnick\Barcode\Barcode(); + } + + public function testGetGrid(): void + { + $barcode = $this->getTestObject(); + $type = $barcode->getBarcodeObj('RMS4CC', '0123456789'); + $grid = $type->getGrid(); + $expected = "1000001010000010100000101000001010000010100000101000100010001000100010001000100010001000101\n" + . "1010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101\n" + . "0000001010001000100010100010000010100010001010000000001010001000100010100010000010000010101\n"; + $this->assertEquals($expected, $grid); + } + + public function testInvalidInput(): void + { + $this->bcExpectException('\\' . \Com\Tecnick\Barcode\Exception::class); + $barcode = $this->getTestObject(); + $barcode->getBarcodeObj('RMS4CC', '}{'); + } +} diff --git a/vendor/tecnickcom/tc-lib-barcode/test/Linear/StandardTwoOfFiveCheckTest.php b/vendor/tecnickcom/tc-lib-barcode/test/Linear/StandardTwoOfFiveCheckTest.php new file mode 100644 index 0000000..902c749 --- /dev/null +++ b/vendor/tecnickcom/tc-lib-barcode/test/Linear/StandardTwoOfFiveCheckTest.php @@ -0,0 +1,55 @@ + + * @copyright 2015-2024 Nicola Asuni - Tecnick.com LTD + * @license http://www.gnu.org/copyleft/lesser.html GNU-LGPL v3 (see LICENSE.TXT) + * @link https://github.com/tecnickcom/tc-lib-barcode + * + * This file is part of tc-lib-barcode software library. + */ + +namespace Test\Linear; + +use Test\TestUtil; + +/** + * Barcode class test + * + * @since 2015-02-21 + * @category Library + * @package Barcode + * @author Nicola Asuni + * @copyright 2015-2024 Nicola Asuni - Tecnick.com LTD + * @license http://www.gnu.org/copyleft/lesser.html GNU-LGPL v3 (see LICENSE.TXT) + * @link https://github.com/tecnickcom/tc-lib-barcode + */ +class StandardTwoOfFiveCheckTest extends TestUtil +{ + protected function getTestObject(): \Com\Tecnick\Barcode\Barcode + { + return new \Com\Tecnick\Barcode\Barcode(); + } + + public function testGetGrid(): void + { + $barcode = $this->getTestObject(); + $type = $barcode->getBarcodeObj('S25+', '0123456789'); + $grid = $type->getGrid(); + $expected = '111011101010101110111010101011101110101110101010111010111010101110111011101010101010111010' + . '1110111010111010101011101110101010101011101110111010101110101011101011101011101011101010111010111' . "\n"; + $this->assertEquals($expected, $grid); + } + + public function testInvalidInput(): void + { + $this->bcExpectException('\\' . \Com\Tecnick\Barcode\Exception::class); + $barcode = $this->getTestObject(); + $barcode->getBarcodeObj('S25+', '}{'); + } +} diff --git a/vendor/tecnickcom/tc-lib-barcode/test/Linear/StandardTwoOfFiveTest.php b/vendor/tecnickcom/tc-lib-barcode/test/Linear/StandardTwoOfFiveTest.php new file mode 100644 index 0000000..26c87ea --- /dev/null +++ b/vendor/tecnickcom/tc-lib-barcode/test/Linear/StandardTwoOfFiveTest.php @@ -0,0 +1,48 @@ + + * @copyright 2015-2024 Nicola Asuni - Tecnick.com LTD + * @license http://www.gnu.org/copyleft/lesser.html GNU-LGPL v3 (see LICENSE.TXT) + * @link https://github.com/tecnickcom/tc-lib-barcode + * + * This file is part of tc-lib-barcode software library. + */ + +namespace Test\Linear; + +use Test\TestUtil; + +/** + * Barcode class test + * + * @since 2015-02-21 + * @category Library + * @package Barcode + * @author Nicola Asuni + * @copyright 2015-2024 Nicola Asuni - Tecnick.com LTD + * @license http://www.gnu.org/copyleft/lesser.html GNU-LGPL v3 (see LICENSE.TXT) + * @link https://github.com/tecnickcom/tc-lib-barcode + */ +class StandardTwoOfFiveTest extends TestUtil +{ + protected function getTestObject(): \Com\Tecnick\Barcode\Barcode + { + return new \Com\Tecnick\Barcode\Barcode(); + } + + public function testGetGrid(): void + { + $barcode = $this->getTestObject(); + $type = $barcode->getBarcodeObj('S25', '0123456789'); + $grid = $type->getGrid(); + $expected = '111011101010101110111010111010101011101011101010111011101110101010101011101011101110101110101010' + . '111011101010101010111011101110101011101010111010111010111010111' . "\n"; + $this->assertEquals($expected, $grid); + } +} diff --git a/vendor/tecnickcom/tc-lib-barcode/test/Linear/UpcATest.php b/vendor/tecnickcom/tc-lib-barcode/test/Linear/UpcATest.php new file mode 100644 index 0000000..5040a08 --- /dev/null +++ b/vendor/tecnickcom/tc-lib-barcode/test/Linear/UpcATest.php @@ -0,0 +1,52 @@ + + * @copyright 2015-2024 Nicola Asuni - Tecnick.com LTD + * @license http://www.gnu.org/copyleft/lesser.html GNU-LGPL v3 (see LICENSE.TXT) + * @link https://github.com/tecnickcom/tc-lib-barcode + * + * This file is part of tc-lib-barcode software library. + */ + +namespace Test\Linear; + +use Test\TestUtil; + +/** + * Barcode class test + * + * @since 2015-02-21 + * @category Library + * @package Barcode + * @author Nicola Asuni + * @copyright 2015-2024 Nicola Asuni - Tecnick.com LTD + * @license http://www.gnu.org/copyleft/lesser.html GNU-LGPL v3 (see LICENSE.TXT) + * @link https://github.com/tecnickcom/tc-lib-barcode + */ +class UpcATest extends TestUtil +{ + protected function getTestObject(): \Com\Tecnick\Barcode\Barcode + { + return new \Com\Tecnick\Barcode\Barcode(); + } + + public function testGetGrid(): void + { + $barcode = $this->getTestObject(); + $bobj = $barcode->getBarcodeObj('UPCA', '0123456789'); + $grid = $bobj->getGrid(); + $expected = "10100011010001101001100100100110111101010001101010100111010100001000100100100011101001001110101\n"; + $this->assertEquals($expected, $grid); + + $bobj = $barcode->getBarcodeObj('UPCA', '012345678912'); + $grid = $bobj->getGrid(); + $expected = "10100011010011001001001101111010100011011000101010101000010001001001000111010011001101101100101\n"; + $this->assertEquals($expected, $grid); + } +} diff --git a/vendor/tecnickcom/tc-lib-barcode/test/Linear/UpcETest.php b/vendor/tecnickcom/tc-lib-barcode/test/Linear/UpcETest.php new file mode 100644 index 0000000..dcf9892 --- /dev/null +++ b/vendor/tecnickcom/tc-lib-barcode/test/Linear/UpcETest.php @@ -0,0 +1,117 @@ + + * @copyright 2015-2024 Nicola Asuni - Tecnick.com LTD + * @license http://www.gnu.org/copyleft/lesser.html GNU-LGPL v3 (see LICENSE.TXT) + * @link https://github.com/tecnickcom/tc-lib-barcode + * + * This file is part of tc-lib-barcode software library. + */ + +namespace Test\Linear; + +use Test\TestUtil; + +/** + * Barcode class test + * + * @since 2015-02-21 + * @category Library + * @package Barcode + * @author Nicola Asuni + * @copyright 2015-2024 Nicola Asuni - Tecnick.com LTD + * @license http://www.gnu.org/copyleft/lesser.html GNU-LGPL v3 (see LICENSE.TXT) + * @link https://github.com/tecnickcom/tc-lib-barcode + */ +class UpcETest extends TestUtil +{ + protected function getTestObject(): \Com\Tecnick\Barcode\Barcode + { + return new \Com\Tecnick\Barcode\Barcode(); + } + + public function testGetGrid(): void + { + $barcode = $this->getTestObject(); + $bobj = $barcode->getBarcodeObj('UPCE', '725270'); + $grid = $bobj->getGrid(); + $expected = "101001000100100110110001001101101110110100111010101\n"; + $this->assertEquals($expected, $grid); + + $bobj = $barcode->getBarcodeObj('UPCE', '725271'); + $grid = $bobj->getGrid(); + $expected = "101001000100100110111001001001101110110110011010101\n"; + $this->assertEquals($expected, $grid); + + $bobj = $barcode->getBarcodeObj('UPCE', '725272'); + $grid = $bobj->getGrid(); + $expected = "101001000100100110111001001001100100010010011010101\n"; + $this->assertEquals($expected, $grid); + + $bobj = $barcode->getBarcodeObj('UPCE', '725273'); + $grid = $bobj->getGrid(); + $expected = "101001000100100110110001001101101110110100001010101\n"; + $this->assertEquals($expected, $grid); + + $bobj = $barcode->getBarcodeObj('UPCE', '725274'); + $grid = $bobj->getGrid(); + $expected = "101001000100100110110001001101100100010100011010101\n"; + $this->assertEquals($expected, $grid); + + $bobj = $barcode->getBarcodeObj('UPCE', '725275'); + $grid = $bobj->getGrid(); + $expected = "101001000100100110111001001101101110110110001010101\n"; + $this->assertEquals($expected, $grid); + + $bobj = $barcode->getBarcodeObj('UPCE', '725276'); + $grid = $bobj->getGrid(); + $expected = "101001000100110110110001001101101110110101111010101\n"; + $this->assertEquals($expected, $grid); + + $bobj = $barcode->getBarcodeObj('UPCE', '725277'); + $grid = $bobj->getGrid(); + $expected = "101001000100100110111001001001101110110010001010101\n"; + $this->assertEquals($expected, $grid); + + $bobj = $barcode->getBarcodeObj('UPCE', '725278'); + $grid = $bobj->getGrid(); + $expected = "101001000100100110110001001101100100010110111010101\n"; + $this->assertEquals($expected, $grid); + + $bobj = $barcode->getBarcodeObj('UPCE', '725279'); + $grid = $bobj->getGrid(); + $expected = "101001000100110110110001001001100100010001011010101\n"; + $this->assertEquals($expected, $grid); + + $bobj = $barcode->getBarcodeObj('UPCE', '0123456789'); + $grid = $bobj->getGrid(); + $expected = "101010011100110010010011010000100111010001011010101\n"; + $this->assertEquals($expected, $grid); + + $bobj = $barcode->getBarcodeObj('UPCE', '012345678912'); + $grid = $bobj->getGrid(); + $expected = "101011001100110110111101010001101110010011001010101\n"; + $this->assertEquals($expected, $grid); + + $bobj = $barcode->getBarcodeObj('UPCE', '4210000526'); + $grid = $bobj->getGrid(); + $expected = "101001110100100110111001001101101011110011001010101\n"; + $this->assertEquals($expected, $grid); + + $bobj = $barcode->getBarcodeObj('UPCE', '4240000526'); + $grid = $bobj->getGrid(); + $expected = "101001110100110110100011001101101011110111101010101\n"; + $this->assertEquals($expected, $grid); + + $bobj = $barcode->getBarcodeObj('UPCE', '4241000526'); + $grid = $bobj->getGrid(); + $expected = "101001110100100110011101001100101011110011101010101\n"; + $this->assertEquals($expected, $grid); + } +} diff --git a/vendor/tecnickcom/tc-lib-barcode/test/Square/AztecTest.php b/vendor/tecnickcom/tc-lib-barcode/test/Square/AztecTest.php new file mode 100644 index 0000000..97acb48 --- /dev/null +++ b/vendor/tecnickcom/tc-lib-barcode/test/Square/AztecTest.php @@ -0,0 +1,237 @@ + + * @copyright 2023-2024 Nicola Asuni - Tecnick.com LTD + * @license http://www.gnu.org/copyleft/lesser.html GNU-LGPL v3 (see LICENSE.TXT) + * @link https://github.com/tecnickcom/tc-lib-barcode + * + * This file is part of tc-lib-barcode software library. + */ + +namespace Test\Square; + +use Test\TestUtil; +use PHPUnit\Framework\Attributes\DataProvider; + +/** + * AZTEC Barcode class test + * + * @since 2023-10-20 + * @category Library + * @package Barcode + * @author Nicola Asuni + * @copyright 2023-2024 Nicola Asuni - Tecnick.com LTD + * @license http://www.gnu.org/copyleft/lesser.html GNU-LGPL v3 (see LICENSE.TXT) + * @link https://github.com/tecnickcom/tc-lib-barcode + */ +class AztecTest extends TestUtil +{ + protected function getTestObject(): \Com\Tecnick\Barcode\Barcode + { + return new \Com\Tecnick\Barcode\Barcode(); + } + + public function testInvalidInput(): void + { + $this->bcExpectException('\\' . \Com\Tecnick\Barcode\Exception::class); + $barcode = $this->getTestObject(); + $barcode->getBarcodeObj('AZTEC', ''); + } + + public function testCapacityException(): void + { + $this->bcExpectException('\\' . \Com\Tecnick\Barcode\Exception::class); + $barcode = $this->getTestObject(); + $code = str_pad('', 2000, '0123456789'); + $barcode->getBarcodeObj('AZTEC,100,B,F,3', $code); + } + + #[DataProvider('getGridDataProvider')] + public function testGetGrid(string $options, string $code, mixed $expected): void + { + $barcode = $this->getTestObject(); + $type = $barcode->getBarcodeObj('AZTEC' . $options, $code); + $grid = $type->getGrid(); + $this->assertEquals($expected, md5($grid)); + } + + /** + * @return array + */ + public static function getGridDataProvider(): array + { + return [ + [ + ',100,A,A,0', + 'A', + 'c48da49052f674edc66fa02e52334b17', + ], + [ + '', + ' ABCDEFGHIJKLMNOPQRSTUVWXYZ', + '74f1e68830f0c635cd01167245743098', + ], + [ + '', + ' abcdefghijklmnopqrstuvwxyz', + '100ebf910c88922b0ccee88256ba0c81', + ], + [ + '', + ' ,.0123456789', + 'ee2a70b7c88a9e0956b1896983e93f91', + ], + [ + '', + "\r" . '!"#$%&\'()*+,-./:;<=>?[]{}', + '6965459e50f7c3029de42ef5dc5c1fdf', + ], + [ + '', + "\x01\x02\x03\x04\x05\x06\x07\x08\x09\x0A" + . "\x0B\x0C\x0D\x1B\x1C\x1D\x1E\x1F\x40\x5C" + . "\x5E\x5F\x60\x7C\x7E\x7F", + 'b8961abf38519b529f7dc6a20e8f3e59', + ], + [ + '', + 'AaB0C#D' . "\x7E", + '9b1f2af28b8d9d222de93dfe6a09a047', + ], + [ + '', + 'aAb0c#d' . "\x7E", + 'f4c58cabbdb5d94fa0cc1c31d510936a', + ], + [ + '', + '#A$a%0&' . "\x7E", + 'a17634a1db6372efbf8ea25a303c38f8', + ], + [ + '', + "\x01A\x01a\x010\x01#", + 'c1a585888c7a1eb424ff98bbf7b32d46', + ], + [ + '', + 'PUNCT pairs , . : ' . "\r\n", + '35281793cc5247b291abb8e3fe5ed853', + ], + [ + '', + 'ABCDEabcdeABCDE012345ABCDE?[]{}ABCDE' + . "\x01\x02\x03\x04\x05", + '4ae19b80469a1afff8e490f5afaa8b73', + ], + [ + '', + 'abcdeABCDEabcde012345abcde?[]{}abcde' + . "\x01\x02\x03\x04\x05", + 'b0158bfe19c6fe20042128d59e40ca3b', + ], + [ + '', + '?[]{}ABCDE?[]{}abcde?[]{}012345?[]{}' + . "\x01\x02\x03\x04\x05", + '71ba0ed8c308c93af6af7cd23a76355a', + ], + [ + '', + "\x01\x02\x03\x04\x05" . 'ABCDE' + . "\x01\x02\x03\x04\x05" . 'abcde' + . "\x01\x02\x03\x04\x05" . '012345' + . "\x01\x02\x03\x04\x05" . '?[]{}', + 'f31e14be0b2c1f903e77af11e6c901b0', + ], + [ + '', + 'Lorem ipsum dolor sit amet, consectetur adipiscing elit,' + . ' sed do eiusmod tempor incididunt ut labore et dolore magna aliqua.' + . ' Ut enim ad minim veniam, quis nostrud exercitation ullamco laboris' + . ' nisi ut aliquip ex ea commodo consequat.' + . ' Duis aute irure dolor in reprehenderit in voluptate velit esse' + . ' cillum dolore eu fugiat nulla pariatur. Excepteur sint occaecat' + . ' cupidatat non proident,' . + ' sunt in culpa qui officia deserunt mollit anim id est laborum.', + 'bb2b103d59e035a581fed0619090f89c', + ], + [ + '', + "\x80\x81\x82\x83\x84", + 'da92b009c1f4430e2f62c76c5f708121', + ], + [ + '', + "\x80\x81\x82\x83\x84\x85\x86\x87\x88\x89" + . "\x8A\x8B\x8C\x8D\x8E\x8F\x90\x91\x92\x93" + . "\x94\x95\x96\x97\x98\x99\x9A\x9B\x9C\x9D" + . "\x9E\x9F\xA0", + 'f3dfdda6d6fdbd747c86f042fc649193', + ], + [ + '', + "\x80\x81\x82\x83\x84\x85\x86\x87\x88\x89" + . "\x8A\x8B\x8C\x8D\x8E\x8F\x90\x91\x92\x93" + . "\x94\x95\x96\x97\x98\x99\x9A\x9B\x9C\x9D" + . "\x9E\x9F\xA0\xA1\xA2\xA3\xA4\xA5\xA6\xA7" + . "\xA8\xA9\xAA\xAB\xAC\xAD\xAE\xAF\xB0\xB1" + . "\xB2\xB3\xB4\xB5\xB6\xB7\xB8\xB9\xBA\xBB" + . "\xBC\xBD\xBE", + 'ee473dc76e160671f3d1991777894323', + ], + [ + '', + '012345: : : : : : : : ', + 'b7ae80e65d754dc17fe116aaddd33c24', + ], + [ + '', + '012345. , ', + '92b442e5f1b33be91c576eddc12bcca7', + ], + [ + '', + '012345. , . , . , . , ', + '598fd97d8a28b1514cd0bf88369c68e9', + ], + [ + '', + '~~~~~~. , ', + 'c40fc61717a7e802d7458897197227b1', + ], + [ + '', + '******. , ', + 'abbe0bdfdc10ad059ad2c415e79dab31', + ], + [ + '', + "\xBC\xBD\xBE" . '. , ', + 'c9ae209e0c6d03014753363affffee8b', + ], + ]; + } + + #[DataProvider('getStringDataProvider')] + public function testStrings(string $code): void + { + $barcode = $this->getTestObject(); + $type = $barcode->getBarcodeObj('AZTEC,50,B,F', $code); + $this->assertNotNull($type); // @phpstan-ignore method.alreadyNarrowedType + } + + /** + * @return array + */ + public static function getStringDataProvider() + { + return \Test\TestStrings::$data; + } +} diff --git a/vendor/tecnickcom/tc-lib-barcode/test/Square/DatamatrixTest.php b/vendor/tecnickcom/tc-lib-barcode/test/Square/DatamatrixTest.php new file mode 100644 index 0000000..8073eee --- /dev/null +++ b/vendor/tecnickcom/tc-lib-barcode/test/Square/DatamatrixTest.php @@ -0,0 +1,447 @@ + + * @copyright 2015-2024 Nicola Asuni - Tecnick.com LTD + * @license http://www.gnu.org/copyleft/lesser.html GNU-LGPL v3 (see LICENSE.TXT) + * @link https://github.com/tecnickcom/tc-lib-barcode + * + * This file is part of tc-lib-barcode software library. + */ + +namespace Test\Square; + +use Test\TestUtil; +use PHPUnit\Framework\Attributes\DataProvider; + +/** + * Datamatrix Barcode class test + * + * @since 2015-02-21 + * @category Library + * @package Barcode + * @author Nicola Asuni + * @copyright 2015-2024 Nicola Asuni - Tecnick.com LTD + * @license http://www.gnu.org/copyleft/lesser.html GNU-LGPL v3 (see LICENSE.TXT) + * @link https://github.com/tecnickcom/tc-lib-barcode + */ +class DatamatrixTest extends TestUtil +{ + protected function getTestObject(): \Com\Tecnick\Barcode\Barcode + { + return new \Com\Tecnick\Barcode\Barcode(); + } + + public function testInvalidInput(): void + { + $this->bcExpectException('\\' . \Com\Tecnick\Barcode\Exception::class); + $barcode = $this->getTestObject(); + $barcode->getBarcodeObj('DATAMATRIX', ''); + } + + public function testCapacityException(): void + { + $this->bcExpectException('\\' . \Com\Tecnick\Barcode\Exception::class); + $barcode = $this->getTestObject(); + $code = str_pad('', 3000, 'X'); + $barcode->getBarcodeObj('DATAMATRIX', $code); + } + + public function testEncodeTXTC40shiftException(): void + { + $this->bcExpectException('\\' . \Com\Tecnick\Barcode\Exception::class); + $encode = new \Com\Tecnick\Barcode\Type\Square\Datamatrix\Encode(); + $chr = -1; + $enc = -1; + $temp_cw = []; + $ptr = 0; + $encode->encodeTXTC40shift($chr, $enc, $temp_cw, $ptr); + } + + public function testEncodeTXTC40Exception(): void + { + $this->bcExpectException('\\' . \Com\Tecnick\Barcode\Exception::class); + $encode = new \Com\Tecnick\Barcode\Type\Square\Datamatrix\Encode(); + $data = "\x80"; + $enc = \Com\Tecnick\Barcode\Type\Square\Datamatrix\Data::ENC_X12; + $temp_cw = []; + $ptr = 0; + $epos = 0; + $charset = []; + $encode->encodeTXTC40($data, $enc, $temp_cw, $ptr, $epos, $charset); + } + + #[DataProvider('getGridDataProvider')] + public function testGetGrid(string $mode, string $code, mixed $expected): void + { + $barcode = $this->getTestObject(); + $type = $barcode->getBarcodeObj($mode, $code); + $grid = $type->getGrid(); + $this->assertEquals($expected, md5($grid)); + } + + /** + * @return array + */ + public static function getGridDataProvider(): array + { + return [ + + [ + 'DATAMATRIX', + '0&0&0&0&0&0&_', + 'fffdfdaec33af0788d24cdfa8cba5ac6', + ], + [ + 'DATAMATRIX', + '0&0&0&0&0&0&0', + '10d0faf5a6e7b71829f268218df7e6af', + ], + [ + 'DATAMATRIX', + '-=-1-=-2-=-3', + '75c6038d90476cec641ad07690989b36', + ], + [ + 'DATAMATRIX', + '-=-1-=-2-=-3x', + 'f020e44d0926d17af7eb21febdb38d53', + ], + [ + 'DATAMATRIX', + '-=-1-=-2-=-3xyz', + '17420fbffefddb5f1b8abd0d05de724d', + ], + [ + 'DATAMATRIX', + '-=-1-=-2-=-3-', + 'a63372ce839b51294964f0da0ae0f9f9', + ], + [ + 'DATAMATRIX', + '-=-1-=-2-=-3-xy', + 'f65ab07c374c53e2a93016776041de42', + ], + [ + 'DATAMATRIX', + '-=-1-=-2-=-3-=x', + '7a30efdf7616397a1ea2fd5fd95fed2c', + ], + [ + 'DATAMATRIX', + '(400)BS2WZ64PA(00)0', + '9cb7f1c2aa5989909229ef8e4252d61d', + ], + [ + 'DATAMATRIX', + '(400)BS2WZ64QA(00)0', + '0494f709138a1feef5a1c9f14852dbe5', + ], + [ + 'DATAMATRIX', + 'LD2B 1 CLNGP', + 'f806889d1dbe0908dcfb530f86098041', + ], + [ + 'DATAMATRIX', + 'XXXXXXXXXNGP', + 'c6f2b7b293a2943bae74f2a191ec4aea', + ], + [ + 'DATAMATRIX', + 'XXXXXXXXXXXXNGP', + 'f7679d5a7ab4a8edf12571a6866d92bc', + ], + [ + 'DATAMATRIX', + 'ABCDABCDAB' . "\x80" . 'DABCD', + '39aca5ed58b922bee369e5ab8e3add8c', + ], + [ + 'DATAMATRIX', + '123aabcdefghijklmnopqrstuvwxyzc', + 'b2d1e957af10655d7a8c3bae86696314', + ], + [ + 'DATAMATRIX', + 'abcdefghijklmnopqrstuvwxyzabcdefghijklmnopq', + 'c45bd372694ad7a20fca7d45f3d459ab', + ], + [ + 'DATAMATRIX', + 'abcdefghijklmnop', + '4fc7940fe3d19fca12454340c38e3421', + ], + [ + 'DATAMATRIX', + 'abcdefghijklmnopq', + 'a452e658e3096d8187969cbdc930909c', + ], + [ + 'DATAMATRIX', + 'abcdefghij', + '8ec27153e5d173aa2cb907845334e68c', + ], + [ + 'DATAMATRIX', + '30Q324343430794|', + '4993e149fd20569c8a4f0d758b6dfa76', + ], + [ + 'DATAMATRIX', + '!"£$', + '792181edb48c6722217dc7e2e4cd4095', + ], + [ + 'DATAMATRIX', + 'abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ1234567890!@#$%^&*(),./\\1234567890', + '7360a5a6c25476711139ae1244f56c29', + ], + [ + 'DATAMATRIX', + "\xFE\xFD" + . 'abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ1234567890!@#$%^&*(),./\\' + . "\xFC\xFB", + '0f078e5e5735396312245740484fa6d1', + ], + [ + 'DATAMATRIX', + 'aABCDEFG', + 'f074dee3f0f386d9b2f30b1ce4ad08a8', + ], + [ + 'DATAMATRIX', + '123 45678', + '6c2e6503625e408fe9a4e392743f31a8', + ], + [ + 'DATAMATRIX', + 'DATA MATRIX', + '3ba4f4ef8449d795813b353ddcce4d23', + ], + [ + 'DATAMATRIX', + '123ABCD89', + '7ce2f8433b82c16e80f4a4c59cad5d10', + ], + [ + 'DATAMATRIX', + 'AB/C123-X', + '703318e1964c63d5d500d14a821827cd', + ], + [ + 'DATAMATRIX', + str_pad('', 300, "\xFE\xFD\xFC\xFB"), + 'e524bb17821d0461f3db6f313d35018f', + ], + [ + 'DATAMATRIX', + 'ec:b47' . "\x7F" . '4#P d*b}gI2#DB|hl{!~[EYH*=cmR{lf' + . "\x7F" . '=gcGIa.st286. #*"!eG[.Ryr?Kn,1mIyQqC3 6\'3N>', + '57fbb9bfb7d542e2e5eadb615e6be549', + ], + [ + 'DATAMATRIX', + 'eA211101A2raJTGL/r9o93CVk4gtpEvWd2A2Qz8jvPc7l8ybD3m' + . 'Wel91ih727kldinPeHJCjhr7fIBX1KQQfsN7BFMX00nlS8FlZG+', + 'b2f0d45920c7da5b298bbab5cff5d402', + ], + // Square + [ + 'DATAMATRIX,S', + "\xFF\xFE\xFD\xFC\xFB\xFA\xF9\xF8\xF7\xF6" + . "\xF5\xF4\xF3\xF2\xF1\xF0\xEF\xEE\xED\xEC" + . "\xEB\xEA\xE9\xE8\xE7\xE6\xE5\xE4\xE3\xE2" + . "\xE1\xE0\xDF\xDE\xDD\xDC\xDB\xDA\xD9\xD8" + . "\xD7\xD6\xD5\xD4\xD3\xD2\xD1\xD0\xCF\xCE" + . "\xCD\xCC\xCB\xCA\xC9\xC8\xC7\xC6\xC5\xC4" + . "\xC3\xC2\xC1\xC0\xBF\xBE\xBD\xBC\xBB\xBA" + . "\xB9\xB8\xB7\xB6\xB5\xB4\xB3\xB2\xB1\xB0" + . "\xAF\xAE\xAD\xAC\xAB\xAA\xA9\xA8\xA7\xA6" + . "\xA5\xA4\xA3\xA2\xA1\xA0\x9F\x9E\x9D\x9C" + . "\x9B\x9A\x99\x98\x97\x96\x95\x94\x93\x92" + . "\x91\x90\x8F\x8E\x8D\x8C\x8B\x8A\x89\x88" + . "\x87\x86\x85\x84\x83\x82\x81\x80\x7F\x7E" + . "\x7D\x7C\x7B\x7A\x79\x78\x77\x76\x75\x74" + . "\x73\x72\x71\x70\x6F\x6E\x6D\x6C\x6B\x6A" + . "\x69\x68\x67\x66\x65\x64\x63\x62\x61\x60" + . "\x5F\x5E\x5D\x5C\x5B\x5A\x59\x58\x57\x56" + . "\x55\x54\x53\x52\x51\x50\x4F\x4E\x4D\x4C" + . "\x4B\x4A\x49\x48\x47\x46\x45\x44\x43\x42" + . "\x41\x40\x3F\x3E\x3D\x3C\x3B\x3A\x39\x38" + . "\x37\x36\x35\x34\x33\x32\x31\x30\x2F\x2E" + . "\x2D\x2C\x2B\x2A\x29\x28\x27\x26\x25\x24" + . "\x23\x22\x21\x20\x1F\x1E\x1D\x1C\x1B\x1A" + . "\x19\x18\x17\x16\x15\x14\x13\x12\x11\x10" + . "\x0F\x0E\x0D\x0C\x0B\x0A\x09\x08\x07\x06" + . "\x05\x04\x03\x02\x01", + '514963c4fde0cee7ff91f76dd56015cc', + ], + // Rectangular shape + [ + 'DATAMATRIX,R', + '01234567890', + 'd3811e018f960beed6d3fa5e675e290e', + ], + [ + 'DATAMATRIX,R', + '01234567890123456789', + 'fe3ecb042dabc4b40c5017e204df105b', + ], + [ + 'DATAMATRIX,R', + '012345678901234567890123456789', + '3f8e9aa4413b90f7e1c2e85b4471fd20', + ], + [ + 'DATAMATRIX,R', + '0123456789012345678901234567890123456789', + 'b748b02c1c4cae621a84c8dbba97c710', + ], + // Rectangular GS1 + [ + 'DATAMATRIX,R,GS1', + "\xE8" . '01034531200000111719112510ABCD1234', + 'f55524d239fc95072d99eafe5363cfeb', + ], + [ + 'DATAMATRIX,R,GS1', + "\xE8" . '01095011010209171719050810ABCD1234' . "\xE8" . '2110', + 'e17f2a052271a18cdc00b161908eccb9', + ], + [ + 'DATAMATRIX,R,GS1', + "\xE8" . '01034531200000111712050810ABCD1234' . "\xE8" . '4109501101020917', + '31759950f3253805b100fedf3e536575', + ], + // Square GS1 + [ + 'DATAMATRIX,S,GS1', + "\xE8" . '01034531200000111719112510ABCD1234', + 'c9efb69a62114fb6a3d2b52f139a372a', + ], + [ + 'DATAMATRIX,S,GS1', + "\xE8" . '01095011010209171719050810ABCD1234' . "\xE8" . '2110', + '9630bdba9fc79b4a4911fc465aa08951', + ], + [ + 'DATAMATRIX,S,GS1', + "\xE8" . '01034531200000111712050810ABCD1234' . "\xE8" . '4109501101020917', + 'a29a330a01cce34a346cf7049e2259ee', + ], + // Different encoding datamatrix + [ + 'DATAMATRIX,S,N,ASCII', + '01234567890', + 'ac7dd9e1ebdb42d07fe928fb33cd307b' + ], + [ + 'DATAMATRIX,S,N,C40', + '01234567890', + '958a7a3bcd036d7135489eb703a25633' + ], + [ + 'DATAMATRIX,S,N,TXT', + '01234567890', + '057981dfbf527b029ae59d65fb55f61d' + ], + [ + 'DATAMATRIX,S,N,X12', + '01234567890', + '8d75b0fcfb2d0977abd95004a6ba98dd' + ], + [ + 'DATAMATRIX,S,N,EDF', + '01234567890', + '989eab3ca16c97e05dd2307bef32f64b' + ], + [ + 'DATAMATRIX,S,N,BASE256', + '01234567890', + '8b4f688a774130bc654e39dfcfadb482' + ], + [ + 'DATAMATRIX,S,GS1,C40', + "\xE8" . '01095011010209171719050810ABCD1234' . "\xE8" . '2110', + 'ba117111dfa40a40e1bb968c719d2eef' + ] + ]; + } + + #[DataProvider('getStringDataProvider')] + public function testStrings(string $code): void + { + $barcode = $this->getTestObject(); + $type = $barcode->getBarcodeObj('DATAMATRIX', $code); + $this->assertNotNull($type); // @phpstan-ignore method.alreadyNarrowedType + } + + /** + * @return array + */ + public static function getStringDataProvider() + { + return \Test\TestStrings::$data; + } +} diff --git a/vendor/tecnickcom/tc-lib-barcode/test/Square/PdfFourOneSevenTest.php b/vendor/tecnickcom/tc-lib-barcode/test/Square/PdfFourOneSevenTest.php new file mode 100644 index 0000000..c4180b2 --- /dev/null +++ b/vendor/tecnickcom/tc-lib-barcode/test/Square/PdfFourOneSevenTest.php @@ -0,0 +1,268 @@ + + * @copyright 2015-2024 Nicola Asuni - Tecnick.com LTD + * @license http://www.gnu.org/copyleft/lesser.html GNU-LGPL v3 (see LICENSE.TXT) + * @link https://github.com/tecnickcom/tc-lib-barcode + * + * This file is part of tc-lib-barcode software library. + */ + +namespace Test\Square; + +use Test\TestUtil; +use PHPUnit\Framework\Attributes\DataProvider; + +/** + * PDF417 Barcode class test + * + * @since 2015-02-21 + * @category Library + * @package Barcode + * @author Nicola Asuni + * @copyright 2015-2024 Nicola Asuni - Tecnick.com LTD + * @license http://www.gnu.org/copyleft/lesser.html GNU-LGPL v3 (see LICENSE.TXT) + * @link https://github.com/tecnickcom/tc-lib-barcode + */ +class PdfFourOneSevenTest extends TestUtil +{ + protected function getTestObject(): \Com\Tecnick\Barcode\Barcode + { + return new \Com\Tecnick\Barcode\Barcode(); + } + + public function testInvalidInput(): void + { + $this->bcExpectException('\\' . \Com\Tecnick\Barcode\Exception::class); + $barcode = $this->getTestObject(); + $barcode->getBarcodeObj('PDF417', ''); + } + + public function testCapacityException(): void + { + $this->bcExpectException('\\' . \Com\Tecnick\Barcode\Exception::class); + $barcode = $this->getTestObject(); + $code = str_pad('', 1000, 'X1'); + $barcode->getBarcodeObj('PDF417', $code); + } + + #[DataProvider('getGridDataProvider')] + public function testGetGrid(string $options, string $code, mixed $expected): void + { + $barcode = $this->getTestObject(); + $type = $barcode->getBarcodeObj('PDF417' . $options, $code); + $grid = $type->getGrid(); + $this->assertEquals($expected, md5($grid)); + } + + /** + * @return array + */ + public static function getGridDataProvider(): array + { + return [ + [ + '', + str_pad('', 1850, 'ABCDEFGHIJKLMNOPQRSTUVWXYZ'), + '38e205c911b94a62c72b7d20fa4361f8', + ], + // max text + [ + '', + str_pad('', 2710, '123456789'), + '32ba9be56f3e66559b4d4a50f6276da7', + ], + // max digits + [ + '', + 'abc/abc', + '831874fe7d1b3d865c222858eba3507c', + ], + [ + '', + '0123456789', + '4f9cdac81d62f0020beb93fc3ecdd8ad', + ], + [ + ',2,8,1,0,0,0,1,2', + str_pad('', 1750, 'X'), + 'f0874a35e15f11f9aa8bc070a4be24bf', + ], + [ + ',15,8,1,0,0,0,1,2', + str_pad('', 1750, 'X'), + '0288f0a87cc069fc34d6168d7a9f7846', + ], + [ + '', + str_pad('', 350, '0123456789'), + '394d93048831fee232413da29fb709fb', + ], + [ + '', + 'abcdefghijklmnopqrstuvwxyz01234567890123456789', + 'bd4f4215aca0bbc3452a35b81fcf7bdb', + ], + [ + '', + "\x9E\x13\xC0\x08\x47\x71\x6B\xFC\xAB\xA9" + . "\x72\x72\xCC\x97\xB7\x14\xB4\x1A\x49\x4C" + . "\xC1\x10\x45\xD4\xE8\x5A\xF8\x73\x09\x68" + . "\x95\xA7\x7B\x56\xAF\xC1\xC7\x1B\xBE\x73" + . "\xC4\x32\xE4\x92\xC9\x9C\xA5\x7E\xB6\xED" + . "\xC9\x79\xFD\x0F\x4E\xE7\x69\x48\x5C\x72" + . "\xAF\xF0\x1A\x2B\x47\xC8\xEC\x0F\xE3\xAC" + . "\x81\xA9\xDD\x67\x3C\xA7\x05\xE1\x27\xBA" + . "\xD0\xF0\x34\xCE\xFE\x82\xB7\x69\xC9\x14" + . "\xDA\x7A\x05\xF4\xA5\x4C\xBD\x92\x5B\xA2" + . "\x3F\xDC\x4C\x1E\x44\x87\xC4\x49\x6A\xEB" + . "\x05\x3B\xDC\x38\x0B\xDC\xBA\xC2\x46\x84" + . "\xD5\x22\xFE\xDA\x17\xA4\x28\xD4\x38\x82" + . "\x77\x76\x5F\xC2\x94\xA3\x4B\x5A\xEC\xB4" + . "\x46\xF0\xEF\x23\x2A\xFA\xFE\xE3\xBD\x46" + . "\x69\x94\x67\x68\x70\x7E\x0D\x97\x53\x44" + . "\x1B\xC9\xBA\x79\x8D\x50\x1E\xD7\xA9\x0C" + . "\x8D\xEE\xFB\x7E\x12\x27\x79\x12\x0C\x38" + . "\x58\x74\xCB\xBE\xDC\x3C\x3D\xE9\xD3\x90" + . "\x2F\xED\x5A\xE8\x68\xE6\x39\x86\xBF\xE2" + . "\x91\x4D\xD1\x8E\xCA\xE3\xB4\x45\xF5\xBF" + . "\x7C\x4E\x35\x49\x0D\x12\x85\x4A\xFA\x59" + . "\xD9\x2A\x47\x35\x14\xAF\x1D\x4D\x36\xDB" + . "\x30\xC6\x29\x03\x55\xF3\xE5\x0B\x39\xDB" + . "\xC9\xB4\x2B\xFD\xFC\x38\x11\x83\x81\x0C" + . "\xDB\x5C\x36\x24\x91\x4A\xD2\xAD\x97\x09" + . "\x89\xC6\xCF\xB2\xC9\x26\xA6\xAF\x30\xDF" + . "\x8C\xF9\x95\xB6\xF8\x93\xED\x0A\x17\x70" + . "\x16\xF1\xCC\x4C\x17\x5E\x96\xE8\x0D\x2E" + . "\xF1\x95\xF3\xC1\x49\xBE\xE6\xEF\x6E\x18", + '1cae7ca47cde6ca52522ce31771a5c54', + ], + [ + '', + "\x9E\xC6\x2D\x5E\xE7\x53\x3C\x2D\x68\x3E" + . "\x7A\x58\xF5\x08\x15\x4C\xAA\xFA\x57\x06" + . "\xA2\x20\x2B\xD0\x11\x60\x8B\x2B\xC0\x0F" + . "\x39\x5F\xD4\x66\xBD\xBC\xB8\xF9\xE9\x22" + . "\x38\x65\x7A\x2F\x6C\x8E\x7A\x18\x89\xD1" + . "\x1E\x2D\xF0\x48\xFD\x02\xA7\x8A\x2C\x69" + . "\x98\x65\xC8\x6D\xCA\x87\x2B\x84\x81\x15" + . "\xA5\xB9\x79\x20\xE7\xE5\xAE\x63\xFC\x39" + . "\x35\x1B\x65\x26\x63\x64\x27\x0C\xED\x53" + . "\x74\x86\xB7\x3E\xF3\x83\xC4\x1F\x08\x46" + . "\x34\xAC\xFE\xAD\xCC\xE7\x93\x7C\x4B\x91" + . "\xB4\x80\xAC\x1B\xA5\x10\x7E\xCC\x1B\x6D" + . "\x21\x8F\xF2\xD8\xCC\xE7\x5C\x91\x07\x63" + . "\xD6\x3B\x11\xD6\xE7\xDD\xBE\x7C\x5A\x0B" + . "\x0E\x10\x8A\xBA\x2B\x31\xC9\xA8\xFC\xE3" + . "\x16\x1F\x74\x0A\xF6\x41\xF0\x53\xD1\xF7" + . "\xB6\xA9\x34\xC7\x81\x1D\xA5\x41\x98\x01" + . "\x4B\xA6\x11\xD4\x61\x3B\x07\x2C\xE3\x04" + . "\x11\xF9\x23\x84\x05\x1A\xC4\xF4\x6C\x97" + . "\xED\x24\x42\x22\xEA\xC2\x3F\x91\x04\xD6" + . "\x92\x4F\x7E\xA2\x24\xDE\xDC\x2A\x0C\xC1" + . "\x2E\x1C\xBB\x50\x9F\xBF\x6A\x64\xB5\xD5" + . "\xFB\xA4\xF9\x3E\xC6\xE4\x02\x06\x77\x05" + . "\xDC\x0A\x53\x5B\xAB\x77\x3B\x89\xA1\x46" + . "\x4B\xCF\x61\x08\x21\x01\xC6\x8A\x65\x7D" + . "\x61\x61\x22\x5B\x9F\xE7\x41\xA0\xED\xB7" + . "\xA5\xCA\xC0\xF8\x26\x6C\x70\x60\xF5\x13" + . "\xA6\x41\xE1\x08\x48\x04\x09\x10\x8D\x6D" + . "\x8D\xED\xCE\xAE\x49\x6F\x97\x8A\x10\x85" + . "\x42\xB4\x51\x03\xAD\x76\x6F\x1F\xD6\x65" + . "\x31\x7D\xA6\x14\x85\xEE\x17\x8D\xFE\xA3" + . "\xFA\x8C\x92\xCA\x3C\xDB\x3A\xD3\x66\x49" + . "\x5A\xA7\xFD\xAA\xAA\xAC\x22\x1B\xCA\xF7" + . "\x80\xFB\x75\x27\x11\xF9\x17\x27\x88\x16" + . "\xCA\x83\xA2\x5E\x4E\xDE\x3A\x88\xB2\x9F" + . "\xD1\x0E\x48\xCF\xB7\xF2\x7C\xD9\x0E\x48" + . "\xD1\x8D\x45\x48\xB4\x55\x43\xCA\x7C\xCA" + . "\xE0\x48\x4F\x83\xA5\x9D\x63\xDF\x26\x17" + . "\x80\xF6\x24\xC7\xC7\xDB\xBB\x45\xB5\xC8" + . "\x8C\x88\x56\xD0\xCF\x0B\x27\x13\xD5\xA2" + . "\xDD\xB6\xE9\x2E\x3B\x90\xCA\x9D\x70\xF0" + . "\xB3\xF0\xE7\xD7\xB9\xB0\xB4\x75\xF4\x6A" + . "\x3E\x81\xF2\x94\x53\xC2\x9F\x79\xD5\x75" + . "\x1D\xB3\x2C\x08\xE0\x67\x97\xAC\x05\x09" + . "\x9D\xB8\xF8\x86\x91\xB3\x37\x46\x29\x2C" + . "\xB0\x66\xAD\xA3\xFA\x02\x67\x9A\x7B\x3D" + . "\x10\x97\xF0\x3C\x9F\xD2\xA2\x37\x7F\xA7" + . "\x40\x1E\x61\x3A\xA3\xF1\xEC\xDA\x39\x16" + . "\x08\xE9\x7C\xB4\x8D\x77\xB6\xF3\x12\x33" + . "\x32\x22\xC9\x23\x5D\x6A\xF4\x01\xA1\x74" + . "\xA7\xE0\x92\x09\x1C\x36\xFA\x0A\x11\x35" + . "\x20\x18\x1F\x9B\xCC\xAC\x14\x84\xA0\x26" + . "\xB6\xD1\x48\x81\xF3\xA4\xEA\xE9\xA4\x8C" + . "\x5F\x4D\x6E\xF0\x56\x89\x27\x51\x92\x38" + . "\x86\xB1\x50\xA4\x4E\x1E\x51\x62\xA1\xF1" + . "\x87\x58\xC4\xCE\xD8\xB9\x74\xC3\xA3\x1A" + . "\x51\x03\x66\xBE\xF3\xBB\x48\x1C\x0E\xDA" + . "\x53\x93\x8D\xA3\x39\xDA\xC0\x89\x3D\x62" + . "\x7C\xC4\xBA\x41\x94\x93\xF9\x09\x58\x9D" + . "\x22\xA8\xA0\x87\x67\x94\x44\xAF\xB0\x51" + . "\x8A\x04\xE4\x19\xA7\x1E\xF2\x68\xA7\x31" + . "\xCA\x24\xF4\x85\x64\x8A\x1A\x5E\x92\x71" + . "\xFB\xB4\x1B\x9D\x3D\x81\x33\x80\x32\xE2" + . "\xD1\xBC\xE6\xB6\xD4\x8E\xD4\xC8\xF6\x7C" + . "\xF8\xC1\x9F\xEE\x47\x04\x79\x60\x62\x0D" + . "\xD1\x5F\xC1\xEB\xFB\xFD\x6E\x2F\x7F\x9F" + . "\x12\x51\x5D\xF7\x09\x32\x87\xDC\xF9\x7E" + . "\x5A\xF3\x40\xF8\xE3\x87\xFC\x5E\xE7\x60" + . "\x6A\xBA\xBE\x2C\xA6\xBB\x2B\x15\xE9\xA9" + . "\xB4\xFB\xFA\x12\xF4\x05\x44\x7C\xE1\x3F" + . "\xFA\x3C\x34\x3B\x35\x18\xC2\x33\x75\xAB" + . "\x92\xDF\x66\x52\x0C\x0D\x0E\x36\x22\xF6" + . "\xDF\xD6\xF3\xDA\xE8\xE8\xDE\x2D\x66\xC0" + . "\x6C\x61\xFC\x9F\x9C\x32\xB7\x60\x65\x2D" + . "\x0C\xF6\x0D\x71\x49\x19\x7E\x57\x4F\xA0" + . "\x4E\x2F\x77\x43\x0B\x60\x2D\xE9\x8D\x92" + . "\xAB\xF9\xF2\xA8\x99\x8F\xDA\x51\xEE\x40" + . "\x7E\xFA\x37\x8B\x6D\x80\xA3\xEA\xD6\xF2" + . "\x8B\x26\x22\x04\x68\x2D\x64\x94\x17\xF1" + . "\x28\xC2\xEB\x1B\x6B\x85\xAA\x46\xD6\x9A" + . "\x85\x56\x95\xBC\xE0\x03\x3D\x85\xED\x15" + . "\x79\x7A\x3B\x9A\x7D\xA3\xC7\xE1\x38\xDE" + . "\xD3\x60\xA1\xBF\x7A\x0D\x46\x26\x52\x1E" + . "\xBF\xD7\x73\x56\x94\x55\x59\xD1\xDA\x47" + . "\xE6\x54\xC1\x22\xEE\x3F\xC4\xB6\x22\xFC" + . "\x95\xF4\x5D\x37\xB4\xD7\x44\xF9\xFC\x96" + . "\x18\xBD\x6E\x8B\x15\x04\xDF\x6D\xD5\xBA" + . "\xB4\xBC\x10\x76\xDD\xFD\xB5\xA3\xB4\xD6" + . "\xA0\x4B\xCB\xFC\x82\x81\xD5\xC5\x7C\xD2" + . "\x5C\x94\x91\xCA\x20\xA6\xCD\x01\x15\xA4" + . "\xBB\xC8\x61\xCA\x40\x40\xC8\xF5\xE2\x7E" + . "\xCD\x84\xC9\x9A\x82\x4C\x1C\x58\x12\x98" + . "\x2C\x6E\x2D\xBC\x39\x4C\x64\x08\x4C\x78" + . "\xAC\x09\x41\x0E\xD2\x81\x4E\x9C\x78\x32" + . "\x1C\x46\xB5\xE4\xDF\x38\x31\xFB\x8F\x43" + . "\x94\xBB\xB0\xC0\x78\xE9\x0E\xDB\xF1\x5A" + . "\x55\x9E\x62\x96\xAC\x36\x18\xF9\xD1\x8F" + . "\x2D\xEC\xD5\xE1\xD2\xB6\x1B\x04\xB3\xA9" + . "\x46\x48\x65\xF6\x0A\xDD\xE1\x18\xBA\xD4" + . "\x71\x10\x73\xD3\xA5\x21\x0A\xBD\x1C\xDB", + '6c1033648fc11250ad22006398cd1bdc', + ], + ]; + } + + #[DataProvider('getStringDataProvider')] + public function testStrings(string $code): void + { + $barcode = $this->getTestObject(); + $type = $barcode->getBarcodeObj('PDF417', $code); + $this->assertNotNull($type); // @phpstan-ignore method.alreadyNarrowedType + } + + /** + * @return array + */ + public static function getStringDataProvider() + { + return \Test\TestStrings::$data; + } +} diff --git a/vendor/tecnickcom/tc-lib-barcode/test/Square/QrCodeTest.php b/vendor/tecnickcom/tc-lib-barcode/test/Square/QrCodeTest.php new file mode 100644 index 0000000..93af29b --- /dev/null +++ b/vendor/tecnickcom/tc-lib-barcode/test/Square/QrCodeTest.php @@ -0,0 +1,366 @@ + + * @copyright 2015-2024 Nicola Asuni - Tecnick.com LTD + * @license http://www.gnu.org/copyleft/lesser.html GNU-LGPL v3 (see LICENSE.TXT) + * @link https://github.com/tecnickcom/tc-lib-barcode + * + * This file is part of tc-lib-barcode software library. + */ + +namespace Test\Square; + +use Test\TestUtil; +use PHPUnit\Framework\Attributes\DataProvider; + +/** + * QR-Code Barcode class test + * + * @since 2015-02-21 + * @category Library + * @package Barcode + * @author Nicola Asuni + * @copyright 2015-2024 Nicola Asuni - Tecnick.com LTD + * @license http://www.gnu.org/copyleft/lesser.html GNU-LGPL v3 (see LICENSE.TXT) + * @link https://github.com/tecnickcom/tc-lib-barcode + */ +class QrCodeTest extends TestUtil +{ + protected function getTestObject(): \Com\Tecnick\Barcode\Barcode + { + return new \Com\Tecnick\Barcode\Barcode(); + } + + public function testInvalidInput(): void + { + $this->bcExpectException('\\' . \Com\Tecnick\Barcode\Exception::class); + $barcode = $this->getTestObject(); + $barcode->getBarcodeObj('QRCODE', ''); + } + + public function testCapacityException(): void + { + $this->bcExpectException('\\' . \Com\Tecnick\Barcode\Exception::class); + $barcode = $this->getTestObject(); + $code = str_pad('', 4000, 'iVoo{[O17n~>(FXC9{*t1P532}l7E{7/R\' ObO`y?`9G(qjBmu7 GM3ZK!qp|)!P1" sRanqC(:Ky'); + $barcode->getBarcodeObj('QRCODE', $code); + } + + #[DataProvider('getGridDataProvider')] + public function testGetGrid(string $options, string $code, mixed $expected): void + { + $barcode = $this->getTestObject(); + $type = $barcode->getBarcodeObj('QRCODE' . $options, $code); + $grid = $type->getGrid(); + $this->assertEquals($expected, md5($grid)); + } + + /** + * @return array + */ + public static function getGridDataProvider(): array + { + return [ + [ + '', + '0123456789', + '89e599523008751db7eef3b5befc37ed', + ], + [ + ',L', + '0123456789', + '89e599523008751db7eef3b5befc37ed', + ], + [ + ',H,NM', + '0123456789', + '3c4ecb6cc99b7843de8d2d3274a43d9e', + ], + [ + ',L,8B,0,0', + '123aeiouàèìòù', + '1622068066c77d3e6ea0a3ad420d105c', + ], + [ + ',H,KJ,0,0', + 'ぎポ亊', + '1d429dd6a1627f6dc1620b3f56862d52', + ], + [ + ',H,ST,0,0', + 'ABCdef0123', + '3a8260f504bca8de8f55a7b3776080bb', + ], + [ + '', + str_pad('', 350, '0123456789'), + '3cca7eb0f61bc39c5a79d7eb3e23a409', + ], + [ + '', + 'abcdefghijklmnopqrstuvwxyz01234567890123456789', + '9c489cd7ded55a82b2d7e3589afbd7d0', + ], + [ + ',H,AN,40,1,0,1,2', + 'abcdefghijklmnopqrstuvwxyz01234567890123456789', + '5ba221be81b269ab1f105b07bf49b372', + ], + [ + '', + "\x9E\x13\xC0\x08\x47\x71\x6B\xFC\xAB\xA9" + . "\x72\x72\xCC\x97\xB7\x14\xB4\x1A\x49\x4C" + . "\xC1\x10\x45\xD4\xE8\x5A\xF8\x73\x09\x68" + . "\x95\xA7\x7B\x56\xAF\xC1\xC7\x1B\xBE\x73" + . "\xC4\x32\xE4\x92\xC9\x9C\xA5\x7E\xB6\xED" + . "\xC9\x79\xFD\x0F\x4E\xE7\x69\x48\x5C\x72" + . "\xAF\xF0\x1A\x2B\x47\xC8\xEC\x0F\xE3\xAC" + . "\x81\xA9\xDD\x67\x3C\xA7\x05\xE1\x27\xBA" + . "\xD0\xF0\x34\xCE\xFE\x82\xB7\x69\xC9\x14" + . "\xDA\x7A\x05\xF4\xA5\x4C\xBD\x92\x5B\xA2" + . "\x3F\xDC\x4C\x1E\x44\x87\xC4\x49\x6A\xEB" + . "\x05\x3B\xDC\x38\x0B\xDC\xBA\xC2\x46\x84" + . "\xD5\x22\xFE\xDA\x17\xA4\x28\xD4\x38\x82" + . "\x77\x76\x5F\xC2\x94\xA3\x4B\x5A\xEC\xB4" + . "\x46\xF0\xEF\x23\x2A\xFA\xFE\xE3\xBD\x46" + . "\x69\x94\x67\x68\x70\x7E\x0D\x97\x53\x44" + . "\x1B\xC9\xBA\x79\x8D\x50\x1E\xD7\xA9\x0C" + . "\x8D\xEE\xFB\x7E\x12\x27\x79\x12\x0C\x38" + . "\x58\x74\xCB\xBE\xDC\x3C\x3D\xE9\xD3\x90" + . "\x2F\xED\x5A\xE8\x68\xE6\x39\x86\xBF\xE2" + . "\x91\x4D\xD1\x8E\xCA\xE3\xB4\x45\xF5\xBF" + . "\x7C\x4E\x35\x49\x0D\x12\x85\x4A\xFA\x59" + . "\xD9\x2A\x47\x35\x14\xAF\x1D\x4D\x36\xDB" + . "\x30\xC6\x29\x03\x55\xF3\xE5\x0B\x39\xDB" + . "\xC9\xB4\x2B\xFD\xFC\x38\x11\x83\x81\x0C" + . "\xDB\x5C\x36\x24\x91\x4A\xD2\xAD\x97\x09" + . "\x89\xC6\xCF\xB2\xC9\x26\xA6\xAF\x30\xDF" + . "\x8C\xF9\x95\xB6\xF8\x93\xED\x0A\x17\x70" + . "\x16\xF1\xCC\x4C\x17\x5E\x96\xE8\x0D\x2E" + . "\xF1\x95\xF3\xC1\x49\xBE\xE6\xEF\x6E\x18", + 'd1977c58334ea034ef4201fe95ee4d2b', + ], + [ + '', + "\x9E\xC6\x2D\x5E\xE7\x53\x3C\x2D\x68\x3E" + . "\x7A\x58\xF5\x08\x15\x4C\xAA\xFA\x57\x06" + . "\xA2\x20\x2B\xD0\x11\x60\x8B\x2B\xC0\x0F" + . "\x39\x5F\xD4\x66\xBD\xBC\xB8\xF9\xE9\x22" + . "\x38\x65\x7A\x2F\x6C\x8E\x7A\x18\x89\xD1" + . "\x1E\x2D\xF0\x48\xFD\x02\xA7\x8A\x2C\x69" + . "\x98\x65\xC8\x6D\xCA\x87\x2B\x84\x81\x15" + . "\xA5\xB9\x79\x20\xE7\xE5\xAE\x63\xFC\x39" + . "\x35\x1B\x65\x26\x63\x64\x27\x0C\xED\x53" + . "\x74\x86\xB7\x3E\xF3\x83\xC4\x1F\x08\x46" + . "\x34\xAC\xFE\xAD\xCC\xE7\x93\x7C\x4B\x91" + . "\xB4\x80\xAC\x1B\xA5\x10\x7E\xCC\x1B\x6D" + . "\x21\x8F\xF2\xD8\xCC\xE7\x5C\x91\x07\x63" + . "\xD6\x3B\x11\xD6\xE7\xDD\xBE\x7C\x5A\x0B" + . "\x0E\x10\x8A\xBA\x2B\x31\xC9\xA8\xFC\xE3" + . "\x16\x1F\x74\x0A\xF6\x41\xF0\x53\xD1\xF7" + . "\xB6\xA9\x34\xC7\x81\x1D\xA5\x41\x98\x01" + . "\x4B\xA6\x11\xD4\x61\x3B\x07\x2C\xE3\x04" + . "\x11\xF9\x23\x84\x05\x1A\xC4\xF4\x6C\x97" + . "\xED\x24\x42\x22\xEA\xC2\x3F\x91\x04\xD6" + . "\x92\x4F\x7E\xA2\x24\xDE\xDC\x2A\x0C\xC1" + . "\x2E\x1C\xBB\x50\x9F\xBF\x6A\x64\xB5\xD5" + . "\xFB\xA4\xF9\x3E\xC6\xE4\x02\x06\x77\x05" + . "\xDC\x0A\x53\x5B\xAB\x77\x3B\x89\xA1\x46" + . "\x4B\xCF\x61\x08\x21\x01\xC6\x8A\x65\x7D" + . "\x61\x61\x22\x5B\x9F\xE7\x41\xA0\xED\xB7" + . "\xA5\xCA\xC0\xF8\x26\x6C\x70\x60\xF5\x13" + . "\xA6\x41\xE1\x08\x48\x04\x09\x10\x8D\x6D" + . "\x8D\xED\xCE\xAE\x49\x6F\x97\x8A\x10\x85" + . "\x42\xB4\x51\x03\xAD\x76\x6F\x1F\xD6\x65" + . "\x31\x7D\xA6\x14\x85\xEE\x17\x8D\xFE\xA3" + . "\xFA\x8C\x92\xCA\x3C\xDB\x3A\xD3\x66\x49" + . "\x5A\xA7\xFD\xAA\xAA\xAC\x22\x1B\xCA\xF7" + . "\x80\xFB\x75\x27\x11\xF9\x17\x27\x88\x16" + . "\xCA\x83\xA2\x5E\x4E\xDE\x3A\x88\xB2\x9F" + . "\xD1\x0E\x48\xCF\xB7\xF2\x7C\xD9\x0E\x48" + . "\xD1\x8D\x45\x48\xB4\x55\x43\xCA\x7C\xCA" + . "\xE0\x48\x4F\x83\xA5\x9D\x63\xDF\x26\x17" + . "\x80\xF6\x24\xC7\xC7\xDB\xBB\x45\xB5\xC8" + . "\x8C\x88\x56\xD0\xCF\x0B\x27\x13\xD5\xA2" + . "\xDD\xB6\xE9\x2E\x3B\x90\xCA\x9D\x70\xF0" + . "\xB3\xF0\xE7\xD7\xB9\xB0\xB4\x75\xF4\x6A" + . "\x3E\x81\xF2\x94\x53\xC2\x9F\x79\xD5\x75" + . "\x1D\xB3\x2C\x08\xE0\x67\x97\xAC\x05\x09" + . "\x9D\xB8\xF8\x86\x91\xB3\x37\x46\x29\x2C" + . "\xB0\x66\xAD\xA3\xFA\x02\x67\x9A\x7B\x3D" + . "\x10\x97\xF0\x3C\x9F\xD2\xA2\x37\x7F\xA7" + . "\x40\x1E\x61\x3A\xA3\xF1\xEC\xDA\x39\x16" + . "\x08\xE9\x7C\xB4\x8D\x77\xB6\xF3\x12\x33" + . "\x32\x22\xC9\x23\x5D\x6A\xF4\x01\xA1\x74" + . "\xA7\xE0\x92\x09\x1C\x36\xFA\x0A\x11\x35" + . "\x20\x18\x1F\x9B\xCC\xAC\x14\x84\xA0\x26" + . "\xB6\xD1\x48\x81\xF3\xA4\xEA\xE9\xA4\x8C" + . "\x5F\x4D\x6E\xF0\x56\x89\x27\x51\x92\x38" + . "\x86\xB1\x50\xA4\x4E\x1E\x51\x62\xA1\xF1" + . "\x87\x58\xC4\xCE\xD8\xB9\x74\xC3\xA3\x1A" + . "\x51\x03\x66\xBE\xF3\xBB\x48\x1C\x0E\xDA" + . "\x53\x93\x8D\xA3\x39\xDA\xC0\x89\x3D\x62" + . "\x7C\xC4\xBA\x41\x94\x93\xF9\x09\x58\x9D" + . "\x22\xA8\xA0\x87\x67\x94\x44\xAF\xB0\x51" + . "\x8A\x04\xE4\x19\xA7\x1E\xF2\x68\xA7\x31" + . "\xCA\x24\xF4\x85\x64\x8A\x1A\x5E\x92\x71" + . "\xFB\xB4\x1B\x9D\x3D\x81\x33\x80\x32\xE2" + . "\xD1\xBC\xE6\xB6\xD4\x8E\xD4\xC8\xF6\x7C" + . "\xF8\xC1\x9F\xEE\x47\x04\x79\x60\x62\x0D" + . "\xD1\x5F\xC1\xEB\xFB\xFD\x6E\x2F\x7F\x9F" + . "\x12\x51\x5D\xF7\x09\x32\x87\xDC\xF9\x7E" + . "\x5A\xF3\x40\xF8\xE3\x87\xFC\x5E\xE7\x60" + . "\x6A\xBA\xBE\x2C\xA6\xBB\x2B\x15\xE9\xA9" + . "\xB4\xFB\xFA\x12\xF4\x05\x44\x7C\xE1\x3F" + . "\xFA\x3C\x34\x3B\x35\x18\xC2\x33\x75\xAB" + . "\x92\xDF\x66\x52\x0C\x0D\x0E\x36\x22\xF6" + . "\xDF\xD6\xF3\xDA\xE8\xE8\xDE\x2D\x66\xC0" + . "\x6C\x61\xFC\x9F\x9C\x32\xB7\x60\x65\x2D" + . "\x0C\xF6\x0D\x71\x49\x19\x7E\x57\x4F\xA0" + . "\x4E\x2F\x77\x43\x0B\x60\x2D\xE9\x8D\x92" + . "\xAB\xF9\xF2\xA8\x99\x8F\xDA\x51\xEE\x40" + . "\x7E\xFA\x37\x8B\x6D\x80\xA3\xEA\xD6\xF2" + . "\x8B\x26\x22\x04\x68\x2D\x64\x94\x17\xF1" + . "\x28\xC2\xEB\x1B\x6B\x85\xAA\x46\xD6\x9A" + . "\x85\x56\x95\xBC\xE0\x03\x3D\x85\xED\x15" + . "\x79\x7A\x3B\x9A\x7D\xA3\xC7\xE1\x38\xDE" + . "\xD3\x60\xA1\xBF\x7A\x0D\x46\x26\x52\x1E" + . "\xBF\xD7\x73\x56\x94\x55\x59\xD1\xDA\x47" + . "\xE6\x54\xC1\x22\xEE\x3F\xC4\xB6\x22\xFC" + . "\x95\xF4\x5D\x37\xB4\xD7\x44\xF9\xFC\x96" + . "\x18\xBD\x6E\x8B\x15\x04\xDF\x6D\xD5\xBA" + . "\xB4\xBC\x10\x76\xDD\xFD\xB5\xA3\xB4\xD6" + . "\xA0\x4B\xCB\xFC\x82\x81\xD5\xC5\x7C\xD2" + . "\x5C\x94\x91\xCA\x20\xA6\xCD\x01\x15\xA4" + . "\xBB\xC8\x61\xCA\x40\x40\xC8\xF5\xE2\x7E" + . "\xCD\x84\xC9\x9A\x82\x4C\x1C\x58\x12\x98" + . "\x2C\x6E\x2D\xBC\x39\x4C\x64\x08\x4C\x78" + . "\xAC\x09\x41\x0E\xD2\x81\x4E\x9C\x78\x32" + . "\x1C\x46\xB5\xE4\xDF\x38\x31\xFB\x8F\x43" + . "\x94\xBB\xB0\xC0\x78\xE9\x0E\xDB\xF1\x5A" + . "\x55\x9E\x62\x96\xAC\x36\x18\xF9\xD1\x8F" + . "\x2D\xEC\xD5\xE1\xD2\xB6\x1B\x04\xB3\xA9" + . "\x46\x48\x65\xF6\x0A\xDD\xE1\x18\xBA\xD4" + . "\x71\x10\x73\xD3\xA5\x21\x0A\xBD\x1C\xDB", + 'f4bf6b42c6964562a3a91e054fc8ec51'], + [ + ',H,NM', + + "\x1A\x97\xE0\xC1\x47\x20\xA2\xBF\x1E\x62" + . "\x52\x0D\x99\x91\x45\x03\x7B\xE3\x32\xC8" + . "\x18\xEA\x80\x51\xE8\x70\x93\x2D\x19\x08" + . "\x26\x33\x9E\x07\xF3\xE5\x27\x96\xA5\x45" + . "\xF7\xF6\x51\x92\x89\x95\x94\x06\x7A\xC5", + + '4f6fd3799489b48fa07e1a7aef0561fc', + ], + [ + ',H,AN', + + "\xCD\x92\xB0\x4F\xE2\x9A\xBF\x76\xC6\xD7" + . "\x7E\xEC\x0C\x1D\xF3\xFE\x04\x1B\x96\xA8" + . "\x60\x8E\xA0\xB0\x22\x2A\x47\xB6\x30\xC0" + . "\x7D\xFC\x54\x2E\x4D\x37\xC8\x0D\xAD\x90" + . "\xE3\x2C\x7D\xEE\x49\x71\xEE\x4C\x8C\x85", + + '55cd590ed76d12591c6df3b673904530', + ], + [ + ',H,KJ', + "\xF4\xEB\x15\x95\x9D\x36\xBF\xE3\xEB\xEE" + . "\xA5\x69\xEC\xF8\x97\x3A\x31\x61\x46\xDD" + . "\xF0\x2B\x0B\x6F\x1B\x53\xDF\x0A\x9F\x6D" + . "\x8E\x94\x59\xA3\x2A\xF6\xD8\xE9\xDA\xC5" + . "\xD8\x81\x30\xC5\x7A\xC7\x01\xAA\x29\x46", + + '92e82c296965d97d35ab7168ece11dd0', + ], + [ + ',H,8B', + "\x89\x1B\x70\x93\x89\x8A\xE6\x6A\x94\x86" + . "\xD6\x24\x1B\x31\xC6\x45\x28\xA0\x2F\x04" + . "\x67\x09\x85\x96\xCE\xFE\x5F\xCE\xAA\x88" + . "\x16\x35\xA2\x86\xC7\x2D\x12\xAE\x96\xA5" + . "\x36\x6D\xC9\x51\x9E\x90\x96\xC6\x32\xC4", + '68799fdb9685b5e2f258245833006425', + ], + [ + ',H,ST', + "\xC9\x98\xCD\x4F\x2F\x9D\x4F\x8E\x6C\xF9" + . "\x17\x82\x2F\xB9\x09\xF6\xE5\x1A\xA6\x7C" + . "\xBF\xDB\xE9\x89\x2D\x89\x1B\xC2\x50\x4C" + . "\x88\x1B\xE3\x57\x6A\x14\xF3\xB8\xA1\x61" + . "\xB3\xB8\xE2\xE2\x72\xEB\xD9\x58\x06\x81", + '6fb328c418ea40c6c94277f420ba9357', + ], + [ + '', + 'w(fa`nC]e=}OY(K^ 3xN1Vz1gkKnFS;&TN ' + . '$`W~r?;9\\l?]5MF@<~oh>\\4-#hH*=w*AYaAL!]f^J&<`Tc!' + . 'pcpZ"Nn0RWY\\uQf8+HZXJ8?*bFGDz+Eln7Gqe6"8n[te.\\}' + . ':&YrQq3[UY#yU.@B}Xio>!rWoNMV]*Uw0/kb!~>WYAR0PrROK' + . '=?j>3B/boe@z;8,K$nM$-%]OWm KAOv^oa}#%-ets&p/?|[Dk' + . ')Hy.\'IfuI27y*viktmq#Tfv[X\'zUb?Bkh=zofbe1t|+~tuk' + . 'id]l9Edt}kpTO0wSr^PK|T2SZ:[Jb0UX!I8}Grc^>L)jzG>n\'n:%DMX g5KK' + . 'F!$GJ=Er0*QOVZ:R#YA+H\\0m*inr :>G;Cof`5Yq@,Avg\\J' + . 'j6lv_J(MUqv' + . '>?03:!+8ig9`\\-PZW\'D%Qz^wEC,z3JrQj#d&$p>nYXP6f!p' + . '?)5EZ1$RWH_S[+F-vIr|Nc<==tmT\\oF{x\\ASnF\'FnfyKr@' + . 'YijLg91$VOyD%V4KS-(tav;h>+P8VCY0.D]u^nz6?tZDLoo }' + . 'xt_p1I0=zIs?#%MHbD(R?>q4y7ai(ah"WIrir$\'nM{.P![yd' + . ' "7@@*T:A7%IxmKP7?:+CAyp>)B?e<$e><\'_F\\yhs~2ll^>' + . '%~X1Bz+494VYys^`2zhrBEl+9l>&Y}D_|}p@y|T32,m- Ln3H' + . 'W&j|sv6`6=;5bz2alS[i(o{5]*6*xIRPP>NE6d&L#Abe=tG+H' + . '$tQsqgQ{}\\tH0FyNt?eZE2]gtD&jl14p\'fdxO7uMskv$2pS' + . '(19bWLA@BeF-RXBD_*)YY@O\'5;~9NolV!\':YS[yuA@$tyF9' + . 'YPC3*cc2y~13N"!%$(@][{WR>xV4r|MMNp`YUDkPD|cr~ex#m' + . '9`J69}T2Th&R7S")4[_YG0~EtqDZkHI&*tw+T.8r!mk4j"CEn9+S!Qn]\'Ohu%y0`9)lm7' + . '%a9sMN^Oq$?,0r.ablh2U_8PoxixeX1k;K_hy>9lBXxRL\'5/' + . 's~BJ^Z{OSfI:?[&[\'eD!$^mG8gzen1uc08/or+@Fria2FgnM' + . 'N3NRr=z+%uqt\'gY8 h(rtI:g4{zZdi(3}Wfpta|zXoo`WIxX' + . '3"L)Kgp_cl:IVB\\UyCGo&Ej^5[?m&8F::rCfZ4F?"`hX$F/~' + . 'iVoo{[O17n~>(FXC9{*t1P532}l7E{7/R\' ObO`y?`9G(qjB' + . 'mu7 GM3ZK!qp|)!P1" sRanqC(:Ky&mh{&hDS|~ }qqzzrL,u' + . 'L!H/o:RwU}r[l\\XrE|FB{FAm9=i-iv#7wKFgfx`RM8' + . '83KI~dMkt}L9 ]uN[,@:6/[",:jKl8c%L/OKs}7i{c#{BxK}%' + . 'k9(0*S}C7#oGS;TW2x8z]!sK=k]rf', + '83747986cf0df320b915587609232076', + ], + ]; + } + + #[DataProvider('getStringDataProvider')] + public function testStrings(string $code): void + { + $barcode = $this->getTestObject(); + $type = $barcode->getBarcodeObj('QRCODE,H,NL,0,1,3,1', $code); + $this->assertNotNull($type); // @phpstan-ignore method.alreadyNarrowedType + } + + /** + * @return array + */ + public static function getStringDataProvider() + { + return \Test\TestStrings::$data; + } +} diff --git a/vendor/tecnickcom/tc-lib-barcode/test/Square/RawTest.php b/vendor/tecnickcom/tc-lib-barcode/test/Square/RawTest.php new file mode 100644 index 0000000..148eb20 --- /dev/null +++ b/vendor/tecnickcom/tc-lib-barcode/test/Square/RawTest.php @@ -0,0 +1,47 @@ + + * @copyright 2015-2024 Nicola Asuni - Tecnick.com LTD + * @license http://www.gnu.org/copyleft/lesser.html GNU-LGPL v3 (see LICENSE.TXT) + * @link https://github.com/tecnickcom/tc-lib-barcode + * + * This file is part of tc-lib-barcode software library. + */ + +namespace Test\Square; + +use PHPUnit\Framework\TestCase; + +/** + * Raw Barcode class test + * + * @since 2015-02-21 + * @category Library + * @package Barcode + * @author Nicola Asuni + * @copyright 2015-2024 Nicola Asuni - Tecnick.com LTD + * @license http://www.gnu.org/copyleft/lesser.html GNU-LGPL v3 (see LICENSE.TXT) + * @link https://github.com/tecnickcom/tc-lib-barcode + */ +class RawTest extends TestCase +{ + protected function getTestObject(): \Com\Tecnick\Barcode\Barcode + { + return new \Com\Tecnick\Barcode\Barcode(); + } + + public function testGetGrid(): void + { + $barcode = $this->getTestObject(); + $type = $barcode->getBarcodeObj('SRAW', '0101,1010,1100,0011'); + $grid = $type->getGrid(); + $expected = "0101\n1010\n1100\n0011\n"; + $this->assertEquals($expected, $grid); + } +} diff --git a/vendor/tecnickcom/tc-lib-barcode/test/TestStrings.php b/vendor/tecnickcom/tc-lib-barcode/test/TestStrings.php new file mode 100644 index 0000000..9783c58 --- /dev/null +++ b/vendor/tecnickcom/tc-lib-barcode/test/TestStrings.php @@ -0,0 +1,78 @@ + + * @copyright 2015-2024 Nicola Asuni - Tecnick.com LTD + * @license http://www.gnu.org/copyleft/lesser.html GNU-LGPL v3 (see LICENSE.TXT) + * @link https://github.com/tecnickcom/tc-lib-barcode + * + * This file is part of tc-lib-barcode software library. + */ + +namespace Test; + +/** + * Barcode class test + * + * @since 2016-08-31 + * @category Library + * @package Barcode + * @author Nicola Asuni + * @copyright 2015-2024 Nicola Asuni - Tecnick.com LTD + * @license http://www.gnu.org/copyleft/lesser.html GNU-LGPL v3 (see LICENSE.TXT) + * @link https://github.com/tecnickcom/tc-lib-barcode + */ +class TestStrings +{ + /** + * Array containing testing strings. + * + * @var array + */ + public static $data = [ + // Reserved keywords + ['__halt_compiler abstract and array as break callable case catch class clone const continue declare default die do echo else elseif empty enddeclare endfor endforeach endif endswitch endwhile eval exit extends final for foreach function global goto if implements include include_once instanceof insteadof interface isset list namespace new or print private protected public require require_once return static switch throw trait try unset use var while xor'], + ['__CLASS__ __DIR__ __FILE__ __FUNCTION__ __LINE__ __METHOD__ __NAMESPACE__ __TRAIT__ boolean bool integer float double string array object resource undefined undef null NULL (null) nil NIL true false True False TRUE FALSE None hasOwnProperty'], + // Numeric Strings + ['0 1 2 3 5 7 97 397 997 7919 99991 104729 01 012 0123 01234 012345 0123456 01234567 012345678 0123456789 1234567890 12 123 1234 12345 123456 1234567 12345678 123456789 1234567890 012345678900112233445566778899 012345678900112233445566778899000111222333444555666777888999 123456789012345678901234567890123456789 999999999999999999999999999999999999999999999999999999999999999999999999999999999999999999999999'], + ['1.00 $1.00 1/2 1E2 1E02 1E+02 -1 -1.00 -$1.00 -1/2 -1E2 -1E02 -1E+02 1/0 0/0 -2147483648/-1 -9223372036854775808/-1 0.00 0..0 . 0.0.0 0,00 0,,0 , 0,0,0 0.0/0 1.0/0.0 0.0/0.0 1,0/0,0 0,0/0,0 --1 - -. -, NaN Infinity -Infinity INF 1#INF -1#IND 1#QNAN 1#SNAN 1#IND 0x0 0xffffffff 0xffffffffffffffff 0xabad1dea 1,000.00 1 000.00 1\'000.00 1,000,000.00 1 000 000.00 1\'000\'000.00 1.000,00 1 000,00 1\'000,00 1.000.000,00 1 000 000,00 1\'000\'000,00 01000 08 09 2.2250738585072011e-308 012-345-678-901-234-567-890-123-456-789'], + // Special Characters + [' !"#$%&\'()*+,-./0123456789:;<=>?@ABCDEFGHIJKLMNOPQRSTUVWXYZ[\]^_`abcdefghijklmnopqrstuvwxyz{|}~'], + ['Roses are red, violets are blue. Hope you enjoy terminal hue But now...for my greatest trick... The quick brown fox...'], + ['<<< ((( [[[ {{{ """ \'\'\' ``` ### ~~~ @@@ £££ $$$ %%% ^^^ &&& *** --- +++ === ___ ::: ;;; ,,, ... ??? ¬¬¬ ||| /// \\\\\\ !!! }}} ]]] ))) >>> ./;\'[]\-= <>?:"{}|_+ !@#$%^&*()`~ "\'"\'"\'\'\'\'"'], + // Unicode Symbols + ['Ω≈ç√∫˜µ≤≥÷ åß∂ƒ©˙∆˚¬…æ œ∑´®†¥¨ˆøπ“‘ ¡™£¢∞§¶•ªº–≠ ¸˛Ç◊ı˜Â¯˘¿ ÅÍÎÏ˝ÓÔÒÚÆ☃ Œ„´‰ˇÁ¨ˆØ∏”’ `⁄€‹›fifl‡°·‚—± ⅛⅜⅝⅞ ЁЂЃЄЅІЇЈЉЊЋЌЍЎЏАБВГДЕЖЗИЙКЛМНОПРСТУФХЦЧШЩЪЫЬЭЮЯабвгдежзийклмнопрстуфхцчшщъыьэюя ٠١٢٣٤٥٦٧٨٩   ᠎    ␣ ␢ ␡ ⁰⁴⁵ ₀₁₂ ⁰⁴⁵₀₁₂'], + // Two-Byte Characters + ['田中さんにあげて下さい パーティーへ行かないか 和製漢語 部落格 사회과학원 어학연구소 찦차를 타고 온 펲시맨과 쑛다리 똠방각하 社會科學院語學研究所 울란바토르 𠜎𠜱𠝹𠱓𠱸𠲖𠳏'], + // Japanese Emoticons + ['ヽ༼ຈل͜ຈ༽ノ ヽ༼ຈل͜ຈ༽ノ (。◕ ∀ ◕。) `ィ(´∀`∩ __ロ(,_,*) ・( ̄∀ ̄)・:*: ゚・✿ヾ╲(。◕‿◕。)╱✿・゚ ,。・:*:・゜’( ☻ ω ☻ )。・:*:・゜’ (╯°□°)╯︵ ┻━┻) (ノಥ益ಥ)ノ ┻━┻ ( ͡° ͜ʖ ͡°)'], + // Emoji + ['😍 👩🏽 👾 🙇 💁 🙅 🙆 🙋 🙎 🙍 🐵 🙈 🙉 🙊 ❤️ 💔 💌 💕 💞 💓 💗 💖 💘 💝 💟 💜 💛 💚 💙 ✋🏿 💪🏿 👐🏿 🙌🏿 👏🏿 🙏🏿 🚾 🆒 🆓 🆕 🆖 🆗 🆙 🏧 0️⃣ 1️⃣ 2️⃣ 3️⃣ 4️⃣ 5️⃣ 6️⃣ 7️⃣ 8️⃣ 9️⃣ 🔟'], + // Regional Indicator Symbols + ['🇺🇸🇷🇺🇸 🇦🇫🇦🇲🇸 🇺🇸🇷🇺🇸🇦🇫🇦🇲 🇺🇸🇷🇺🇸🇦'], + // Unicode Numbers + ['123 ١٢٣'], + // Right-To-Left Strings + ['ثم نفس سقطت وبالتحديد،, جزيرتي باستخدام أن دنو. إذ هنا؟ الستار وتنصيب كان. أهّل ايطاليا، بريطانيا-فرنسا قد أخذ. سليمان، إتفاقية بين ما, يذكر الحدود أي بعد, معاملة بولندا، الإطلاق عل إيو. בְּרֵאשִׁית, בָּרָא אֱלֹהִים, אֵת הַשָּׁמַיִם, וְאֵת הָאָרֶץ הָיְתָהtestالصفحات التّحول ﷽ ﷺ مُنَاقَشَةُ سُبُلِ اِسْتِخْدَامِ اللُّغَةِ فِي النُّظُمِ الْقَائِمَةِ وَفِيم يَخُصَّ التَّطْبِيقَاتُ الْحاسُوبِيَّةُ، '], + // Trick Unicode + ['‪‪test‪ ‫test‫ 
test
 test⁠test‫ ⁦test⁧'], + // Strings which contain "corrupted" text + ['Ṱ̺̺̕o͞ ̷i̲̬͇̪͙n̝̗͕v̟̜̘̦͟o̶̙̰̠kè͚̮̺̪̹̱̤ ̖t̝͕̳̣̻̪͞h̼͓̲̦̳̘̲e͇̣̰̦̬͎ ̢̼̻̱̘h͚͎͙̜̣̲ͅi̦̲̣̰̤v̻͍e̺̭̳̪̰-m̢iͅn̖̺̞̲̯̰d̵̼̟͙̩̼̘̳ ̞̥̱̳̭r̛̗̘e͙p͠r̼̞̻̭̗e̺̠̣͟s̘͇̳͍̝͉e͉̥̯̞̲͚̬͜ǹ̬͎͎̟̖͇̤t͍̬̤͓̼̭͘ͅi̪̱n͠g̴͉ ͏͉ͅc̬̟h͡a̫̻̯͘o̫̟̖͍̙̝͉s̗̦̲.̨̹͈̣ ̡͓̞ͅI̗̘̦͝n͇͇͙v̮̫ok̲̫̙͈i̖͙̭̹̠̞n̡̻̮̣̺g̲͈͙̭͙̬͎ ̰t͔̦h̞̲e̢̤ ͍̬̲͖f̴̘͕̣è͖ẹ̥̩l͖͔͚i͓͚̦͠n͖͍̗͓̳̮g͍ ̨o͚̪͡f̘̣̬ ̖̘͖̟͙̮c҉͔̫͖͓͇͖ͅh̵̤̣͚͔á̗̼͕ͅo̼̣̥s̱͈̺̖̦̻͢.̛̖̞̠̫̰ ̗̺͖̹̯͓'], + ['Ṯ̤͍̥͇͈h̲́e͏͓̼̗̙̼̣͔ ͇̜̱̠͓͍ͅN͕͠e̗̱z̘̝̜̺͙p̤̺̹͍̯͚e̠̻̠͜r̨̤͍̺̖͔̖̖d̠̟̭̬̝͟i̦͖̩͓͔̤a̠̗̬͉̙n͚͜ ̻̞̰͚ͅh̵͉i̳̞v̢͇ḙ͎͟-҉̭̩̼͔m̤̭̫i͕͇̝̦n̗͙ḍ̟ ̯̲͕͞ǫ̟̯̰̲͙̻̝f ̪̰̰̗̖̭̘͘c̦͍̲̞͍̩̙ḥ͚a̮͎̟̙͜ơ̩̹͎s̤.̝̝ ҉Z̡̖̜͖̰̣͉̜a͖̰͙̬͡l̲̫̳͍̩g̡̟̼̱͚̞̬ͅo̗͜.̟ ̦H̬̤̗̤͝e͜ ̜̥̝̻͍̟́w̕h̖̯͓o̝͙̖͎̱̮ ҉̺̙̞̟͈W̷̼̭a̺̪͍į͈͕̭͙̯̜t̶̼̮s̘͙͖̕ ̠̫̠B̻͍͙͉̳ͅe̵h̵̬͇̫͙i̹͓̳̳̮͎̫̕n͟d̴̪̜̖ ̰͉̩͇͙̲͞ͅT͖̼͓̪͢h͏͓̮̻e̬̝̟ͅ ̤̹̝W͙̞̝͔͇͝ͅa͏͓͔̹̼̣l̴͔̰̤̟͔ḽ̫.͕'], + // Unicode Upsidedown + ['˙ɐnbᴉlɐ ɐuƃɐɯ ǝɹolop ʇǝ ǝɹoqɐl ʇn ʇunpᴉpᴉɔuᴉ ɹodɯǝʇ poɯsnᴉǝ op pǝs \'ʇᴉlǝ ƃuᴉɔsᴉdᴉpɐ ɹnʇǝʇɔǝsuoɔ \'ʇǝɯɐ ʇᴉs ɹolop ɯnsdᴉ ɯǝɹo˥ 00˙Ɩ$-'], + // Unicode font + ['The quick brown fox jumps over the lazy dog 𝐓𝐡𝐞 𝐪𝐮𝐢𝐜𝐤 𝐛𝐫𝐨𝐰𝐧 𝐟𝐨𝐱 𝐣𝐮𝐦𝐩𝐬 𝐨𝐯𝐞𝐫 𝐭𝐡𝐞 𝐥𝐚𝐳𝐲 𝐝𝐨𝐠 𝕿𝖍𝖊 𝖖𝖚𝖎𝖈𝖐 𝖇𝖗𝖔𝖜𝖓 𝖋𝖔𝖝 𝖏𝖚𝖒𝖕𝖘 𝖔𝖛𝖊𝖗 𝖙𝖍𝖊 𝖑𝖆𝖟𝖞 𝖉𝖔𝖌 𝑻𝒉𝒆 𝒒𝒖𝒊𝒄𝒌 𝒃𝒓𝒐𝒘𝒏 𝒇𝒐𝒙 𝒋𝒖𝒎𝒑𝒔 𝒐𝒗𝒆𝒓 𝒕𝒉𝒆 𝒍𝒂𝒛𝒚 𝒅𝒐𝒈 𝓣𝓱𝓮 𝓺𝓾𝓲𝓬𝓴 𝓫𝓻𝓸𝔀𝓷 𝓯𝓸𝔁 𝓳𝓾𝓶𝓹𝓼 𝓸𝓿𝓮𝓻 𝓽𝓱𝓮 𝓵𝓪𝔃𝔂 𝓭𝓸𝓰 '], + ['𝕋𝕙𝕖 𝕢𝕦𝕚𝕔𝕜 𝕓𝕣𝕠𝕨𝕟 𝕗𝕠𝕩 𝕛𝕦𝕞𝕡𝕤 𝕠𝕧𝕖𝕣 𝕥𝕙𝕖 𝕝𝕒𝕫𝕪 𝕕𝕠𝕘 𝚃𝚑𝚎 𝚚𝚞𝚒𝚌𝚔 𝚋𝚛𝚘𝚠𝚗 𝚏𝚘𝚡 𝚓𝚞𝚖𝚙𝚜 𝚘𝚟𝚎𝚛 𝚝𝚑𝚎 𝚕𝚊𝚣𝚢 𝚍𝚘𝚐 ⒯⒣⒠ ⒬⒰⒤⒞⒦ ⒝⒭⒪⒲⒩ ⒡⒪⒳ ⒥⒰⒨⒫⒮ ⒪⒱⒠⒭ ⒯⒣⒠ ⒧⒜⒵⒴ ⒟⒪⒢'], + // Unwanted Interpolation + ['$HOME $ENV{\'HOME\'} %d %s {0} %*.*s'], + // PHP code + ['echo \'hello world\'; exit(); for($i=32;$i<120;++$i){echo chr($i);}'], + ]; +} diff --git a/vendor/tecnickcom/tc-lib-barcode/test/TestUtil.php b/vendor/tecnickcom/tc-lib-barcode/test/TestUtil.php new file mode 100644 index 0000000..b97c685 --- /dev/null +++ b/vendor/tecnickcom/tc-lib-barcode/test/TestUtil.php @@ -0,0 +1,52 @@ + + * @copyright 2015-2024 Nicola Asuni - Tecnick.com LTD + * @license http://www.gnu.org/copyleft/lesser.html GNU-LGPL v3 (see LICENSE.TXT) + * @link https://github.com/tecnickcom/tc-lib-barcode + * + * This file is part of tc-lib-color software library. + */ + +namespace Test; + +use PHPUnit\Framework\TestCase; + +/** + * Web Color class test + * + * @since 2020-12-19 + * @category Library + * @package Barcode + * @author Nicola Asuni + * @copyright 2015-2024 Nicola Asuni - Tecnick.com LTD + * @license http://www.gnu.org/copyleft/lesser.html GNU-LGPL v3 (see LICENSE.TXT) + * @link https://github.com/tecnickcom/tc-lib-barcode + * + * @SuppressWarnings("PHPMD.NumberOfChildren") + */ +class TestUtil extends TestCase +{ + public function bcAssertEqualsWithDelta( + mixed $expected, + mixed $actual, + float $delta = 0.01, + string $message = '' + ): void { + parent::assertEqualsWithDelta($expected, $actual, $delta, $message); + } + + /** + * @param class-string<\Throwable> $exception + */ + public function bcExpectException($exception): void + { + parent::expectException($exception); + } +} diff --git a/vendor/tecnickcom/tc-lib-color/.editorconfig b/vendor/tecnickcom/tc-lib-color/.editorconfig new file mode 100644 index 0000000..f8d1e73 --- /dev/null +++ b/vendor/tecnickcom/tc-lib-color/.editorconfig @@ -0,0 +1,20 @@ +# Ref: https://EditorConfig.org + +# top-most EditorConfig file +root = true + +# Unix-style end of lines and a blank line at the end of the file +[*] +indent_style = tab +end_of_line = lf +charset = utf-8 +trim_trailing_whitespace = true +insert_final_newline = true + +[*.php] +indent_style = space +indent_size = 4 + +[*.{js,json,scss,css,yml,vue}] +indent_style = space +indent_size = 2 diff --git a/vendor/tecnickcom/tc-lib-color/.github/FUNDING.yml b/vendor/tecnickcom/tc-lib-color/.github/FUNDING.yml new file mode 100644 index 0000000..c47c69e --- /dev/null +++ b/vendor/tecnickcom/tc-lib-color/.github/FUNDING.yml @@ -0,0 +1 @@ +custom: ['https://www.paypal.com/donate/?hosted_button_id=NZUEC5XS8MFBJ'] diff --git a/vendor/tecnickcom/tc-lib-color/.github/ISSUE_TEMPLATE/bug_report.md b/vendor/tecnickcom/tc-lib-color/.github/ISSUE_TEMPLATE/bug_report.md new file mode 100644 index 0000000..2c954f9 --- /dev/null +++ b/vendor/tecnickcom/tc-lib-color/.github/ISSUE_TEMPLATE/bug_report.md @@ -0,0 +1,29 @@ +--- +name: Bug report +about: Create a report to help us improve +title: '' +labels: '' +assignees: '' + +--- + +**Describe the bug** +A clear and concise description of what the bug is. + +**To Reproduce** +Steps to reproduce the behavior: +1. ... + +**Expected behavior** +A clear and concise description of what you expected to happen. + +**Logs** +If applicable, copy the relevant logs to help explain your problem. + +**Environment:** + - OS: + - PHP version: + - Version: + +**Additional context** +Add any other context about the problem here. diff --git a/vendor/tecnickcom/tc-lib-color/.github/ISSUE_TEMPLATE/feature_request.md b/vendor/tecnickcom/tc-lib-color/.github/ISSUE_TEMPLATE/feature_request.md new file mode 100644 index 0000000..bbcbbe7 --- /dev/null +++ b/vendor/tecnickcom/tc-lib-color/.github/ISSUE_TEMPLATE/feature_request.md @@ -0,0 +1,20 @@ +--- +name: Feature request +about: Suggest an idea for this project +title: '' +labels: '' +assignees: '' + +--- + +**Is your feature request related to a problem? Please describe.** +A clear and concise description of what the problem is. Ex. I'm always frustrated when [...] + +**Describe the solution you'd like** +A clear and concise description of what you want to happen. + +**Describe alternatives you've considered** +A clear and concise description of any alternative solutions or features you've considered. + +**Additional context** +Add any other context or screenshots about the feature request here. diff --git a/vendor/tecnickcom/tc-lib-color/.github/pull_request_template.md b/vendor/tecnickcom/tc-lib-color/.github/pull_request_template.md new file mode 100644 index 0000000..776ebc0 --- /dev/null +++ b/vendor/tecnickcom/tc-lib-color/.github/pull_request_template.md @@ -0,0 +1,25 @@ +# Description + +Please include a summary of the change and include relevant motivation and context. + +... + + +## Checklist: + +- [ ] The `make buildall` command has been run successfully without any error or warning. +- [ ] Any new code line is covered by unit tests and the coverage has not dropped. +- [ ] Any new code follows the style guidelines of this project. +- [ ] The code changes have been self-reviewed. +- [ ] Corresponding changes to the documentation have been made. +- [ ] The version has been updated in the VERSION file. + +## Type of change: + +- [ ] Bug fix (non-breaking change which fixes an issue) → The patch number in the VERSION file has been increased. +- [ ] New feature (non-breaking change which adds functionality) → The minor number in the VERSION file has been increased. +- [ ] Breaking change (fix or feature that would cause existing functionality to not work as expected) → The major number in the VERSION file has been increased. +- [ ] Automation. +- [ ] Documentation. +- [ ] Example. +- [ ] Testing. diff --git a/vendor/tecnickcom/tc-lib-color/.github/workflows/check.yml b/vendor/tecnickcom/tc-lib-color/.github/workflows/check.yml new file mode 100644 index 0000000..bf9c5e3 --- /dev/null +++ b/vendor/tecnickcom/tc-lib-color/.github/workflows/check.yml @@ -0,0 +1,56 @@ +name: check + +env: + XDEBUG_MODE: coverage + +permissions: + contents: read + +on: + push: + branches: + - 'main' + pull_request: + types: [opened, synchronize, reopened] + branches: + - main + +jobs: + test-php: + name: Test on php ${{ matrix.php-version }} and ${{ matrix.os }} + runs-on: ${{ matrix.os }} + continue-on-error: ${{ matrix.experimental }} + strategy: + fail-fast: false + matrix: + php-version: ["8.1", "8.2", "8.3", "8.4"] + experimental: [false] + os: [ubuntu-latest] + coverage-extension: [pcov] + steps: + - uses: actions/checkout@v4 + - name: Use php ${{ matrix.php-version }} + uses: shivammathur/setup-php@v2 + with: + php-version: ${{ matrix.php-version }} + coverage: ${{ matrix.coverage-extension }} + extensions: bcmath, curl, date, gd, hash, imagick, json, mbstring, openssl, pcre, zlib + ini-values: display_errors=on, error_reporting=-1, zend.assertions=1 + - name: List php modules + run: php -m + - name: List php modules using "no php ini" mode + run: php -m -n + - name: Cache module + uses: actions/cache@v4 + with: + path: ~/.composer/cache/ + key: composer-cache + - name: Install dependencies + run: make deps + - name: Run all tests + run: make qa + - name: Send coverage + uses: codecov/codecov-action@v5 + with: + flags: php-${{ matrix.php-version }}-${{ matrix.os }} + name: php-${{ matrix.php-version }}-${{ matrix.os }} diff --git a/vendor/tecnickcom/tc-lib-color/.gitignore b/vendor/tecnickcom/tc-lib-color/.gitignore new file mode 100644 index 0000000..4dd7d5e --- /dev/null +++ b/vendor/tecnickcom/tc-lib-color/.gitignore @@ -0,0 +1,20 @@ +**/*.bak +**/*.tmp +**/.#* +**/.DS_Store +**/._* +**/.idea +**/.vagrant +**/auth.json +**/nbproject +**/temp.php +**/test.php +.phpdoc +.phpunit.cache +.phpunit.result.cache +composer.lock +ecs.php +phpunit.xml +rector.php +target +vendor diff --git a/vendor/tecnickcom/tc-lib-color/CODEOWNERS b/vendor/tecnickcom/tc-lib-color/CODEOWNERS new file mode 100644 index 0000000..302fbf3 --- /dev/null +++ b/vendor/tecnickcom/tc-lib-color/CODEOWNERS @@ -0,0 +1 @@ +* @nicolaasuni diff --git a/vendor/tecnickcom/tc-lib-color/CODE_OF_CONDUCT.md b/vendor/tecnickcom/tc-lib-color/CODE_OF_CONDUCT.md new file mode 100644 index 0000000..18c9147 --- /dev/null +++ b/vendor/tecnickcom/tc-lib-color/CODE_OF_CONDUCT.md @@ -0,0 +1,128 @@ +# Contributor Covenant Code of Conduct + +## Our Pledge + +We as members, contributors, and leaders pledge to make participation in our +community a harassment-free experience for everyone, regardless of age, body +size, visible or invisible disability, ethnicity, sex characteristics, gender +identity and expression, level of experience, education, socio-economic status, +nationality, personal appearance, race, religion, or sexual identity +and orientation. + +We pledge to act and interact in ways that contribute to an open, welcoming, +diverse, inclusive, and healthy community. + +## Our Standards + +Examples of behavior that contributes to a positive environment for our +community include: + +* Demonstrating empathy and kindness toward other people +* Being respectful of differing opinions, viewpoints, and experiences +* Giving and gracefully accepting constructive feedback +* Accepting responsibility and apologizing to those affected by our mistakes, + and learning from the experience +* Focusing on what is best not just for us as individuals, but for the + overall community + +Examples of unacceptable behavior include: + +* The use of sexualized language or imagery, and sexual attention or + advances of any kind +* Trolling, insulting or derogatory comments, and personal or political attacks +* Public or private harassment +* Publishing others' private information, such as a physical or email + address, without their explicit permission +* Other conduct which could reasonably be considered inappropriate in a + professional setting + +## Enforcement Responsibilities + +Community leaders are responsible for clarifying and enforcing our standards of +acceptable behavior and will take appropriate and fair corrective action in +response to any behavior that they deem inappropriate, threatening, offensive, +or harmful. + +Community leaders have the right and responsibility to remove, edit, or reject +comments, commits, code, wiki edits, issues, and other contributions that are +not aligned to this Code of Conduct, and will communicate reasons for moderation +decisions when appropriate. + +## Scope + +This Code of Conduct applies within all community spaces, and also applies when +an individual is officially representing the community in public spaces. +Examples of representing our community include using an official e-mail address, +posting via an official social media account, or acting as an appointed +representative at an online or offline event. + +## Enforcement + +Instances of abusive, harassing, or otherwise unacceptable behavior may be +reported to the community leaders responsible for enforcement at +. +All complaints will be reviewed and investigated promptly and fairly. + +All community leaders are obligated to respect the privacy and security of the +reporter of any incident. + +## Enforcement Guidelines + +Community leaders will follow these Community Impact Guidelines in determining +the consequences for any action they deem in violation of this Code of Conduct: + +### 1. Correction + +**Community Impact**: Use of inappropriate language or other behavior deemed +unprofessional or unwelcome in the community. + +**Consequence**: A private, written warning from community leaders, providing +clarity around the nature of the violation and an explanation of why the +behavior was inappropriate. A public apology may be requested. + +### 2. Warning + +**Community Impact**: A violation through a single incident or series +of actions. + +**Consequence**: A warning with consequences for continued behavior. No +interaction with the people involved, including unsolicited interaction with +those enforcing the Code of Conduct, for a specified period of time. This +includes avoiding interactions in community spaces as well as external channels +like social media. Violating these terms may lead to a temporary or +permanent ban. + +### 3. Temporary Ban + +**Community Impact**: A serious violation of community standards, including +sustained inappropriate behavior. + +**Consequence**: A temporary ban from any sort of interaction or public +communication with the community for a specified period of time. No public or +private interaction with the people involved, including unsolicited interaction +with those enforcing the Code of Conduct, is allowed during this period. +Violating these terms may lead to a permanent ban. + +### 4. Permanent Ban + +**Community Impact**: Demonstrating a pattern of violation of community +standards, including sustained inappropriate behavior, harassment of an +individual, or aggression toward or disparagement of classes of individuals. + +**Consequence**: A permanent ban from any sort of public interaction within +the community. + +## Attribution + +This Code of Conduct is adapted from the [Contributor Covenant][homepage], +version 2.0, available at +https://www.contributor-covenant.org/version/2/0/code_of_conduct.html. + +Community Impact Guidelines were inspired by [Mozilla's code of conduct +enforcement ladder](https://github.com/mozilla/diversity). + +[homepage]: https://www.contributor-covenant.org + +For answers to common questions about this code of conduct, see the FAQ at +https://www.contributor-covenant.org/faq. Translations are available at +https://www.contributor-covenant.org/translations. diff --git a/vendor/tecnickcom/tc-lib-color/CONTRIBUTING.md b/vendor/tecnickcom/tc-lib-color/CONTRIBUTING.md new file mode 100644 index 0000000..db2739c --- /dev/null +++ b/vendor/tecnickcom/tc-lib-color/CONTRIBUTING.md @@ -0,0 +1,26 @@ +# How to Contribute + + +## Reporting a bug + +* **Do not open up a GitHub issue if the bug is a security vulnerability**, and instead to refer to our [Security policy](SECURITY.md). + +* Ensure the bug was not already reported by searching on GitHub Issues. + +* If you're unable to find an open issue addressing the problem, open a new one. Be sure to include a **title and clear description**, as much relevant information as possible, and a **code sample** or an **executable test case** demonstrating the expected behavior that is not occurring. + + +## Submitting a bug fix + +* Open a new GitHub pull request with the patch. + +* Ensure the PR description clearly describes the problem and solution. Include the relevant issue number if applicable. + +* Ensure the new code is following the existing conventions and the unit test coverage is 100%. + +* Before submitting, please run the following command locally to ensure the code is passing the automatic checks: `make buildall`. + + +## Add a new feature or change an existing one + +* Before writing any code please suggest the change by opening a new Feature Request on Issues. diff --git a/vendor/tecnickcom/tc-lib-color/LICENSE b/vendor/tecnickcom/tc-lib-color/LICENSE new file mode 100644 index 0000000..b7946a0 --- /dev/null +++ b/vendor/tecnickcom/tc-lib-color/LICENSE @@ -0,0 +1,862 @@ +********************************************************************** +* LICENSE +* +* SOFTWARE : tc-lib-color +* AUTHOR : Nicola Asuni +* COPYRIGHT : 2015-2025 Nicola Asuni - Tecnick.com LTD +********************************************************************** + + This is free software: you can redistribute it and/or modify it + under the terms of the GNU Lesser General Public License as + published by the Free Software Foundation, either version 3 of the + License, or (at your option) any later version. + +********************************************************************** +********************************************************************** + + GNU LESSER GENERAL PUBLIC LICENSE + Version 3, 29 June 2007 + + Copyright (C) 2007 Free Software Foundation, Inc. + Everyone is permitted to copy and distribute verbatim copies + of this license document, but changing it is not allowed. + + + This version of the GNU Lesser General Public License incorporates +the terms and conditions of version 3 of the GNU General Public +License, supplemented by the additional permissions listed below. + + 0. Additional Definitions. + + As used herein, "this License" refers to version 3 of the GNU Lesser +General Public License, and the "GNU GPL" refers to version 3 of the GNU +General Public License. + + "The Library" refers to a covered work governed by this License, +other than an Application or a Combined Work as defined below. + + An "Application" is any work that makes use of an interface provided +by the Library, but which is not otherwise based on the Library. +Defining a subclass of a class defined by the Library is deemed a mode +of using an interface provided by the Library. + + A "Combined Work" is a work produced by combining or linking an +Application with the Library. The particular version of the Library +with which the Combined Work was made is also called the "Linked +Version". + + The "Minimal Corresponding Source" for a Combined Work means the +Corresponding Source for the Combined Work, excluding any source code +for portions of the Combined Work that, considered in isolation, are +based on the Application, and not on the Linked Version. + + The "Corresponding Application Code" for a Combined Work means the +object code and/or source code for the Application, including any data +and utility programs needed for reproducing the Combined Work from the +Application, but excluding the System Libraries of the Combined Work. + + 1. Exception to Section 3 of the GNU GPL. + + You may convey a covered work under sections 3 and 4 of this License +without being bound by section 3 of the GNU GPL. + + 2. Conveying Modified Versions. + + If you modify a copy of the Library, and, in your modifications, a +facility refers to a function or data to be supplied by an Application +that uses the facility (other than as an argument passed when the +facility is invoked), then you may convey a copy of the modified +version: + + a) under this License, provided that you make a good faith effort to + ensure that, in the event an Application does not supply the + function or data, the facility still operates, and performs + whatever part of its purpose remains meaningful, or + + b) under the GNU GPL, with none of the additional permissions of + this License applicable to that copy. + + 3. Object Code Incorporating Material from Library Header Files. + + The object code form of an Application may incorporate material from +a header file that is part of the Library. You may convey such object +code under terms of your choice, provided that, if the incorporated +material is not limited to numerical parameters, data structure +layouts and accessors, or small macros, inline functions and templates +(ten or fewer lines in length), you do both of the following: + + a) Give prominent notice with each copy of the object code that the + Library is used in it and that the Library and its use are + covered by this License. + + b) Accompany the object code with a copy of the GNU GPL and this license + document. + + 4. Combined Works. + + You may convey a Combined Work under terms of your choice that, +taken together, effectively do not restrict modification of the +portions of the Library contained in the Combined Work and reverse +engineering for debugging such modifications, if you also do each of +the following: + + a) Give prominent notice with each copy of the Combined Work that + the Library is used in it and that the Library and its use are + covered by this License. + + b) Accompany the Combined Work with a copy of the GNU GPL and this license + document. + + c) For a Combined Work that displays copyright notices during + execution, include the copyright notice for the Library among + these notices, as well as a reference directing the user to the + copies of the GNU GPL and this license document. + + d) Do one of the following: + + 0) Convey the Minimal Corresponding Source under the terms of this + License, and the Corresponding Application Code in a form + suitable for, and under terms that permit, the user to + recombine or relink the Application with a modified version of + the Linked Version to produce a modified Combined Work, in the + manner specified by section 6 of the GNU GPL for conveying + Corresponding Source. + + 1) Use a suitable shared library mechanism for linking with the + Library. A suitable mechanism is one that (a) uses at run time + a copy of the Library already present on the user's computer + system, and (b) will operate properly with a modified version + of the Library that is interface-compatible with the Linked + Version. + + e) Provide Installation Information, but only if you would otherwise + be required to provide such information under section 6 of the + GNU GPL, and only to the extent that such information is + necessary to install and execute a modified version of the + Combined Work produced by recombining or relinking the + Application with a modified version of the Linked Version. (If + you use option 4d0, the Installation Information must accompany + the Minimal Corresponding Source and Corresponding Application + Code. If you use option 4d1, you must provide the Installation + Information in the manner specified by section 6 of the GNU GPL + for conveying Corresponding Source.) + + 5. Combined Libraries. + + You may place library facilities that are a work based on the +Library side by side in a single library together with other library +facilities that are not Applications and are not covered by this +License, and convey such a combined library under terms of your +choice, if you do both of the following: + + a) Accompany the combined library with a copy of the same work based + on the Library, uncombined with any other library facilities, + conveyed under the terms of this License. + + b) Give prominent notice with the combined library that part of it + is a work based on the Library, and explaining where to find the + accompanying uncombined form of the same work. + + 6. Revised Versions of the GNU Lesser General Public License. + + The Free Software Foundation may publish revised and/or new versions +of the GNU Lesser General Public License from time to time. Such new +versions will be similar in spirit to the present version, but may +differ in detail to address new problems or concerns. + + Each version is given a distinguishing version number. If the +Library as you received it specifies that a certain numbered version +of the GNU Lesser General Public License "or any later version" +applies to it, you have the option of following the terms and +conditions either of that published version or of any later version +published by the Free Software Foundation. If the Library as you +received it does not specify a version number of the GNU Lesser +General Public License, you may choose any version of the GNU Lesser +General Public License ever published by the Free Software Foundation. + + If the Library as you received it specifies that a proxy can decide +whether future versions of the GNU Lesser General Public License shall +apply, that proxy's public statement of acceptance of any version is +permanent authorization for you to choose that version for the +Library. + +********************************************************************** +********************************************************************** + + GNU GENERAL PUBLIC LICENSE + Version 3, 29 June 2007 + + Copyright (C) 2007 Free Software Foundation, Inc. + Everyone is permitted to copy and distribute verbatim copies + of this license document, but changing it is not allowed. + + Preamble + + The GNU General Public License is a free, copyleft license for +software and other kinds of works. + + The licenses for most software and other practical works are designed +to take away your freedom to share and change the works. By contrast, +the GNU General Public License is intended to guarantee your freedom to +share and change all versions of a program--to make sure it remains free +software for all its users. We, the Free Software Foundation, use the +GNU General Public License for most of our software; it applies also to +any other work released this way by its authors. You can apply it to +your programs, too. + + When we speak of free software, we are referring to freedom, not +price. Our General Public Licenses are designed to make sure that you +have the freedom to distribute copies of free software (and charge for +them if you wish), that you receive source code or can get it if you +want it, that you can change the software or use pieces of it in new +free programs, and that you know you can do these things. + + To protect your rights, we need to prevent others from denying you +these rights or asking you to surrender the rights. Therefore, you have +certain responsibilities if you distribute copies of the software, or if +you modify it: responsibilities to respect the freedom of others. + + For example, if you distribute copies of such a program, whether +gratis or for a fee, you must pass on to the recipients the same +freedoms that you received. You must make sure that they, too, receive +or can get the source code. And you must show them these terms so they +know their rights. + + Developers that use the GNU GPL protect your rights with two steps: +(1) assert copyright on the software, and (2) offer you this License +giving you legal permission to copy, distribute and/or modify it. + + For the developers' and authors' protection, the GPL clearly explains +that there is no warranty for this free software. For both users' and +authors' sake, the GPL requires that modified versions be marked as +changed, so that their problems will not be attributed erroneously to +authors of previous versions. + + Some devices are designed to deny users access to install or run +modified versions of the software inside them, although the manufacturer +can do so. This is fundamentally incompatible with the aim of +protecting users' freedom to change the software. The systematic +pattern of such abuse occurs in the area of products for individuals to +use, which is precisely where it is most unacceptable. Therefore, we +have designed this version of the GPL to prohibit the practice for those +products. If such problems arise substantially in other domains, we +stand ready to extend this provision to those domains in future versions +of the GPL, as needed to protect the freedom of users. + + Finally, every program is threatened constantly by software patents. +States should not allow patents to restrict development and use of +software on general-purpose computers, but in those that do, we wish to +avoid the special danger that patents applied to a free program could +make it effectively proprietary. To prevent this, the GPL assures that +patents cannot be used to render the program non-free. + + The precise terms and conditions for copying, distribution and +modification follow. + + TERMS AND CONDITIONS + + 0. Definitions. + + "This License" refers to version 3 of the GNU General Public License. + + "Copyright" also means copyright-like laws that apply to other kinds of +works, such as semiconductor masks. + + "The Program" refers to any copyrightable work licensed under this +License. Each licensee is addressed as "you". "Licensees" and +"recipients" may be individuals or organizations. + + To "modify" a work means to copy from or adapt all or part of the work +in a fashion requiring copyright permission, other than the making of an +exact copy. The resulting work is called a "modified version" of the +earlier work or a work "based on" the earlier work. + + A "covered work" means either the unmodified Program or a work based +on the Program. + + To "propagate" a work means to do anything with it that, without +permission, would make you directly or secondarily liable for +infringement under applicable copyright law, except executing it on a +computer or modifying a private copy. Propagation includes copying, +distribution (with or without modification), making available to the +public, and in some countries other activities as well. + + To "convey" a work means any kind of propagation that enables other +parties to make or receive copies. Mere interaction with a user through +a computer network, with no transfer of a copy, is not conveying. + + An interactive user interface displays "Appropriate Legal Notices" +to the extent that it includes a convenient and prominently visible +feature that (1) displays an appropriate copyright notice, and (2) +tells the user that there is no warranty for the work (except to the +extent that warranties are provided), that licensees may convey the +work under this License, and how to view a copy of this License. If +the interface presents a list of user commands or options, such as a +menu, a prominent item in the list meets this criterion. + + 1. Source Code. + + The "source code" for a work means the preferred form of the work +for making modifications to it. "Object code" means any non-source +form of a work. + + A "Standard Interface" means an interface that either is an official +standard defined by a recognized standards body, or, in the case of +interfaces specified for a particular programming language, one that +is widely used among developers working in that language. + + The "System Libraries" of an executable work include anything, other +than the work as a whole, that (a) is included in the normal form of +packaging a Major Component, but which is not part of that Major +Component, and (b) serves only to enable use of the work with that +Major Component, or to implement a Standard Interface for which an +implementation is available to the public in source code form. A +"Major Component", in this context, means a major essential component +(kernel, window system, and so on) of the specific operating system +(if any) on which the executable work runs, or a compiler used to +produce the work, or an object code interpreter used to run it. + + The "Corresponding Source" for a work in object code form means all +the source code needed to generate, install, and (for an executable +work) run the object code and to modify the work, including scripts to +control those activities. However, it does not include the work's +System Libraries, or general-purpose tools or generally available free +programs which are used unmodified in performing those activities but +which are not part of the work. For example, Corresponding Source +includes interface definition files associated with source files for +the work, and the source code for shared libraries and dynamically +linked subprograms that the work is specifically designed to require, +such as by intimate data communication or control flow between those +subprograms and other parts of the work. + + The Corresponding Source need not include anything that users +can regenerate automatically from other parts of the Corresponding +Source. + + The Corresponding Source for a work in source code form is that +same work. + + 2. Basic Permissions. + + All rights granted under this License are granted for the term of +copyright on the Program, and are irrevocable provided the stated +conditions are met. This License explicitly affirms your unlimited +permission to run the unmodified Program. The output from running a +covered work is covered by this License only if the output, given its +content, constitutes a covered work. This License acknowledges your +rights of fair use or other equivalent, as provided by copyright law. + + You may make, run and propagate covered works that you do not +convey, without conditions so long as your license otherwise remains +in force. You may convey covered works to others for the sole purpose +of having them make modifications exclusively for you, or provide you +with facilities for running those works, provided that you comply with +the terms of this License in conveying all material for which you do +not control copyright. Those thus making or running the covered works +for you must do so exclusively on your behalf, under your direction +and control, on terms that prohibit them from making any copies of +your copyrighted material outside their relationship with you. + + Conveying under any other circumstances is permitted solely under +the conditions stated below. Sublicensing is not allowed; section 10 +makes it unnecessary. + + 3. Protecting Users' Legal Rights From Anti-Circumvention Law. + + No covered work shall be deemed part of an effective technological +measure under any applicable law fulfilling obligations under article +11 of the WIPO copyright treaty adopted on 20 December 1996, or +similar laws prohibiting or restricting circumvention of such +measures. + + When you convey a covered work, you waive any legal power to forbid +circumvention of technological measures to the extent such circumvention +is effected by exercising rights under this License with respect to +the covered work, and you disclaim any intention to limit operation or +modification of the work as a means of enforcing, against the work's +users, your or third parties' legal rights to forbid circumvention of +technological measures. + + 4. Conveying Verbatim Copies. + + You may convey verbatim copies of the Program's source code as you +receive it, in any medium, provided that you conspicuously and +appropriately publish on each copy an appropriate copyright notice; +keep intact all notices stating that this License and any +non-permissive terms added in accord with section 7 apply to the code; +keep intact all notices of the absence of any warranty; and give all +recipients a copy of this License along with the Program. + + You may charge any price or no price for each copy that you convey, +and you may offer support or warranty protection for a fee. + + 5. Conveying Modified Source Versions. + + You may convey a work based on the Program, or the modifications to +produce it from the Program, in the form of source code under the +terms of section 4, provided that you also meet all of these conditions: + + a) The work must carry prominent notices stating that you modified + it, and giving a relevant date. + + b) The work must carry prominent notices stating that it is + released under this License and any conditions added under section + 7. This requirement modifies the requirement in section 4 to + "keep intact all notices". + + c) You must license the entire work, as a whole, under this + License to anyone who comes into possession of a copy. This + License will therefore apply, along with any applicable section 7 + additional terms, to the whole of the work, and all its parts, + regardless of how they are packaged. This License gives no + permission to license the work in any other way, but it does not + invalidate such permission if you have separately received it. + + d) If the work has interactive user interfaces, each must display + Appropriate Legal Notices; however, if the Program has interactive + interfaces that do not display Appropriate Legal Notices, your + work need not make them do so. + + A compilation of a covered work with other separate and independent +works, which are not by their nature extensions of the covered work, +and which are not combined with it such as to form a larger program, +in or on a volume of a storage or distribution medium, is called an +"aggregate" if the compilation and its resulting copyright are not +used to limit the access or legal rights of the compilation's users +beyond what the individual works permit. Inclusion of a covered work +in an aggregate does not cause this License to apply to the other +parts of the aggregate. + + 6. Conveying Non-Source Forms. + + You may convey a covered work in object code form under the terms +of sections 4 and 5, provided that you also convey the +machine-readable Corresponding Source under the terms of this License, +in one of these ways: + + a) Convey the object code in, or embodied in, a physical product + (including a physical distribution medium), accompanied by the + Corresponding Source fixed on a durable physical medium + customarily used for software interchange. + + b) Convey the object code in, or embodied in, a physical product + (including a physical distribution medium), accompanied by a + written offer, valid for at least three years and valid for as + long as you offer spare parts or customer support for that product + model, to give anyone who possesses the object code either (1) a + copy of the Corresponding Source for all the software in the + product that is covered by this License, on a durable physical + medium customarily used for software interchange, for a price no + more than your reasonable cost of physically performing this + conveying of source, or (2) access to copy the + Corresponding Source from a network server at no charge. + + c) Convey individual copies of the object code with a copy of the + written offer to provide the Corresponding Source. This + alternative is allowed only occasionally and noncommercially, and + only if you received the object code with such an offer, in accord + with subsection 6b. + + d) Convey the object code by offering access from a designated + place (gratis or for a charge), and offer equivalent access to the + Corresponding Source in the same way through the same place at no + further charge. You need not require recipients to copy the + Corresponding Source along with the object code. If the place to + copy the object code is a network server, the Corresponding Source + may be on a different server (operated by you or a third party) + that supports equivalent copying facilities, provided you maintain + clear directions next to the object code saying where to find the + Corresponding Source. Regardless of what server hosts the + Corresponding Source, you remain obligated to ensure that it is + available for as long as needed to satisfy these requirements. + + e) Convey the object code using peer-to-peer transmission, provided + you inform other peers where the object code and Corresponding + Source of the work are being offered to the general public at no + charge under subsection 6d. + + A separable portion of the object code, whose source code is excluded +from the Corresponding Source as a System Library, need not be +included in conveying the object code work. + + A "User Product" is either (1) a "consumer product", which means any +tangible personal property which is normally used for personal, family, +or household purposes, or (2) anything designed or sold for incorporation +into a dwelling. In determining whether a product is a consumer product, +doubtful cases shall be resolved in favor of coverage. For a particular +product received by a particular user, "normally used" refers to a +typical or common use of that class of product, regardless of the status +of the particular user or of the way in which the particular user +actually uses, or expects or is expected to use, the product. A product +is a consumer product regardless of whether the product has substantial +commercial, industrial or non-consumer uses, unless such uses represent +the only significant mode of use of the product. + + "Installation Information" for a User Product means any methods, +procedures, authorization keys, or other information required to install +and execute modified versions of a covered work in that User Product from +a modified version of its Corresponding Source. The information must +suffice to ensure that the continued functioning of the modified object +code is in no case prevented or interfered with solely because +modification has been made. + + If you convey an object code work under this section in, or with, or +specifically for use in, a User Product, and the conveying occurs as +part of a transaction in which the right of possession and use of the +User Product is transferred to the recipient in perpetuity or for a +fixed term (regardless of how the transaction is characterized), the +Corresponding Source conveyed under this section must be accompanied +by the Installation Information. But this requirement does not apply +if neither you nor any third party retains the ability to install +modified object code on the User Product (for example, the work has +been installed in ROM). + + The requirement to provide Installation Information does not include a +requirement to continue to provide support service, warranty, or updates +for a work that has been modified or installed by the recipient, or for +the User Product in which it has been modified or installed. Access to a +network may be denied when the modification itself materially and +adversely affects the operation of the network or violates the rules and +protocols for communication across the network. + + Corresponding Source conveyed, and Installation Information provided, +in accord with this section must be in a format that is publicly +documented (and with an implementation available to the public in +source code form), and must require no special password or key for +unpacking, reading or copying. + + 7. Additional Terms. + + "Additional permissions" are terms that supplement the terms of this +License by making exceptions from one or more of its conditions. +Additional permissions that are applicable to the entire Program shall +be treated as though they were included in this License, to the extent +that they are valid under applicable law. If additional permissions +apply only to part of the Program, that part may be used separately +under those permissions, but the entire Program remains governed by +this License without regard to the additional permissions. + + When you convey a copy of a covered work, you may at your option +remove any additional permissions from that copy, or from any part of +it. (Additional permissions may be written to require their own +removal in certain cases when you modify the work.) You may place +additional permissions on material, added by you to a covered work, +for which you have or can give appropriate copyright permission. + + Notwithstanding any other provision of this License, for material you +add to a covered work, you may (if authorized by the copyright holders of +that material) supplement the terms of this License with terms: + + a) Disclaiming warranty or limiting liability differently from the + terms of sections 15 and 16 of this License; or + + b) Requiring preservation of specified reasonable legal notices or + author attributions in that material or in the Appropriate Legal + Notices displayed by works containing it; or + + c) Prohibiting misrepresentation of the origin of that material, or + requiring that modified versions of such material be marked in + reasonable ways as different from the original version; or + + d) Limiting the use for publicity purposes of names of licensors or + authors of the material; or + + e) Declining to grant rights under trademark law for use of some + trade names, trademarks, or service marks; or + + f) Requiring indemnification of licensors and authors of that + material by anyone who conveys the material (or modified versions of + it) with contractual assumptions of liability to the recipient, for + any liability that these contractual assumptions directly impose on + those licensors and authors. + + All other non-permissive additional terms are considered "further +restrictions" within the meaning of section 10. If the Program as you +received it, or any part of it, contains a notice stating that it is +governed by this License along with a term that is a further +restriction, you may remove that term. If a license document contains +a further restriction but permits relicensing or conveying under this +License, you may add to a covered work material governed by the terms +of that license document, provided that the further restriction does +not survive such relicensing or conveying. + + If you add terms to a covered work in accord with this section, you +must place, in the relevant source files, a statement of the +additional terms that apply to those files, or a notice indicating +where to find the applicable terms. + + Additional terms, permissive or non-permissive, may be stated in the +form of a separately written license, or stated as exceptions; +the above requirements apply either way. + + 8. Termination. + + You may not propagate or modify a covered work except as expressly +provided under this License. Any attempt otherwise to propagate or +modify it is void, and will automatically terminate your rights under +this License (including any patent licenses granted under the third +paragraph of section 11). + + However, if you cease all violation of this License, then your +license from a particular copyright holder is reinstated (a) +provisionally, unless and until the copyright holder explicitly and +finally terminates your license, and (b) permanently, if the copyright +holder fails to notify you of the violation by some reasonable means +prior to 60 days after the cessation. + + Moreover, your license from a particular copyright holder is +reinstated permanently if the copyright holder notifies you of the +violation by some reasonable means, this is the first time you have +received notice of violation of this License (for any work) from that +copyright holder, and you cure the violation prior to 30 days after +your receipt of the notice. + + Termination of your rights under this section does not terminate the +licenses of parties who have received copies or rights from you under +this License. If your rights have been terminated and not permanently +reinstated, you do not qualify to receive new licenses for the same +material under section 10. + + 9. Acceptance Not Required for Having Copies. + + You are not required to accept this License in order to receive or +run a copy of the Program. Ancillary propagation of a covered work +occurring solely as a consequence of using peer-to-peer transmission +to receive a copy likewise does not require acceptance. However, +nothing other than this License grants you permission to propagate or +modify any covered work. These actions infringe copyright if you do +not accept this License. Therefore, by modifying or propagating a +covered work, you indicate your acceptance of this License to do so. + + 10. Automatic Licensing of Downstream Recipients. + + Each time you convey a covered work, the recipient automatically +receives a license from the original licensors, to run, modify and +propagate that work, subject to this License. You are not responsible +for enforcing compliance by third parties with this License. + + An "entity transaction" is a transaction transferring control of an +organization, or substantially all assets of one, or subdividing an +organization, or merging organizations. If propagation of a covered +work results from an entity transaction, each party to that +transaction who receives a copy of the work also receives whatever +licenses to the work the party's predecessor in interest had or could +give under the previous paragraph, plus a right to possession of the +Corresponding Source of the work from the predecessor in interest, if +the predecessor has it or can get it with reasonable efforts. + + You may not impose any further restrictions on the exercise of the +rights granted or affirmed under this License. For example, you may +not impose a license fee, royalty, or other charge for exercise of +rights granted under this License, and you may not initiate litigation +(including a cross-claim or counterclaim in a lawsuit) alleging that +any patent claim is infringed by making, using, selling, offering for +sale, or importing the Program or any portion of it. + + 11. Patents. + + A "contributor" is a copyright holder who authorizes use under this +License of the Program or a work on which the Program is based. The +work thus licensed is called the contributor's "contributor version". + + A contributor's "essential patent claims" are all patent claims +owned or controlled by the contributor, whether already acquired or +hereafter acquired, that would be infringed by some manner, permitted +by this License, of making, using, or selling its contributor version, +but do not include claims that would be infringed only as a +consequence of further modification of the contributor version. For +purposes of this definition, "control" includes the right to grant +patent sublicenses in a manner consistent with the requirements of +this License. + + Each contributor grants you a non-exclusive, worldwide, royalty-free +patent license under the contributor's essential patent claims, to +make, use, sell, offer for sale, import and otherwise run, modify and +propagate the contents of its contributor version. + + In the following three paragraphs, a "patent license" is any express +agreement or commitment, however denominated, not to enforce a patent +(such as an express permission to practice a patent or covenant not to +sue for patent infringement). To "grant" such a patent license to a +party means to make such an agreement or commitment not to enforce a +patent against the party. + + If you convey a covered work, knowingly relying on a patent license, +and the Corresponding Source of the work is not available for anyone +to copy, free of charge and under the terms of this License, through a +publicly available network server or other readily accessible means, +then you must either (1) cause the Corresponding Source to be so +available, or (2) arrange to deprive yourself of the benefit of the +patent license for this particular work, or (3) arrange, in a manner +consistent with the requirements of this License, to extend the patent +license to downstream recipients. "Knowingly relying" means you have +actual knowledge that, but for the patent license, your conveying the +covered work in a country, or your recipient's use of the covered work +in a country, would infringe one or more identifiable patents in that +country that you have reason to believe are valid. + + If, pursuant to or in connection with a single transaction or +arrangement, you convey, or propagate by procuring conveyance of, a +covered work, and grant a patent license to some of the parties +receiving the covered work authorizing them to use, propagate, modify +or convey a specific copy of the covered work, then the patent license +you grant is automatically extended to all recipients of the covered +work and works based on it. + + A patent license is "discriminatory" if it does not include within +the scope of its coverage, prohibits the exercise of, or is +conditioned on the non-exercise of one or more of the rights that are +specifically granted under this License. You may not convey a covered +work if you are a party to an arrangement with a third party that is +in the business of distributing software, under which you make payment +to the third party based on the extent of your activity of conveying +the work, and under which the third party grants, to any of the +parties who would receive the covered work from you, a discriminatory +patent license (a) in connection with copies of the covered work +conveyed by you (or copies made from those copies), or (b) primarily +for and in connection with specific products or compilations that +contain the covered work, unless you entered into that arrangement, +or that patent license was granted, prior to 28 March 2007. + + Nothing in this License shall be construed as excluding or limiting +any implied license or other defenses to infringement that may +otherwise be available to you under applicable patent law. + + 12. No Surrender of Others' Freedom. + + If conditions are imposed on you (whether by court order, agreement or +otherwise) that contradict the conditions of this License, they do not +excuse you from the conditions of this License. If you cannot convey a +covered work so as to satisfy simultaneously your obligations under this +License and any other pertinent obligations, then as a consequence you may +not convey it at all. For example, if you agree to terms that obligate you +to collect a royalty for further conveying from those to whom you convey +the Program, the only way you could satisfy both those terms and this +License would be to refrain entirely from conveying the Program. + + 13. Use with the GNU Affero General Public License. + + Notwithstanding any other provision of this License, you have +permission to link or combine any covered work with a work licensed +under version 3 of the GNU Affero General Public License into a single +combined work, and to convey the resulting work. The terms of this +License will continue to apply to the part which is the covered work, +but the special requirements of the GNU Affero General Public License, +section 13, concerning interaction through a network will apply to the +combination as such. + + 14. Revised Versions of this License. + + The Free Software Foundation may publish revised and/or new versions of +the GNU General Public License from time to time. Such new versions will +be similar in spirit to the present version, but may differ in detail to +address new problems or concerns. + + Each version is given a distinguishing version number. If the +Program specifies that a certain numbered version of the GNU General +Public License "or any later version" applies to it, you have the +option of following the terms and conditions either of that numbered +version or of any later version published by the Free Software +Foundation. If the Program does not specify a version number of the +GNU General Public License, you may choose any version ever published +by the Free Software Foundation. + + If the Program specifies that a proxy can decide which future +versions of the GNU General Public License can be used, that proxy's +public statement of acceptance of a version permanently authorizes you +to choose that version for the Program. + + Later license versions may give you additional or different +permissions. However, no additional obligations are imposed on any +author or copyright holder as a result of your choosing to follow a +later version. + + 15. Disclaimer of Warranty. + + THERE IS NO WARRANTY FOR THE PROGRAM, TO THE EXTENT PERMITTED BY +APPLICABLE LAW. EXCEPT WHEN OTHERWISE STATED IN WRITING THE COPYRIGHT +HOLDERS AND/OR OTHER PARTIES PROVIDE THE PROGRAM "AS IS" WITHOUT WARRANTY +OF ANY KIND, EITHER EXPRESSED OR IMPLIED, INCLUDING, BUT NOT LIMITED TO, +THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR +PURPOSE. THE ENTIRE RISK AS TO THE QUALITY AND PERFORMANCE OF THE PROGRAM +IS WITH YOU. SHOULD THE PROGRAM PROVE DEFECTIVE, YOU ASSUME THE COST OF +ALL NECESSARY SERVICING, REPAIR OR CORRECTION. + + 16. Limitation of Liability. + + IN NO EVENT UNLESS REQUIRED BY APPLICABLE LAW OR AGREED TO IN WRITING +WILL ANY COPYRIGHT HOLDER, OR ANY OTHER PARTY WHO MODIFIES AND/OR CONVEYS +THE PROGRAM AS PERMITTED ABOVE, BE LIABLE TO YOU FOR DAMAGES, INCLUDING ANY +GENERAL, SPECIAL, INCIDENTAL OR CONSEQUENTIAL DAMAGES ARISING OUT OF THE +USE OR INABILITY TO USE THE PROGRAM (INCLUDING BUT NOT LIMITED TO LOSS OF +DATA OR DATA BEING RENDERED INACCURATE OR LOSSES SUSTAINED BY YOU OR THIRD +PARTIES OR A FAILURE OF THE PROGRAM TO OPERATE WITH ANY OTHER PROGRAMS), +EVEN IF SUCH HOLDER OR OTHER PARTY HAS BEEN ADVISED OF THE POSSIBILITY OF +SUCH DAMAGES. + + 17. Interpretation of Sections 15 and 16. + + If the disclaimer of warranty and limitation of liability provided +above cannot be given local legal effect according to their terms, +reviewing courts shall apply local law that most closely approximates +an absolute waiver of all civil liability in connection with the +Program, unless a warranty or assumption of liability accompanies a +copy of the Program in return for a fee. + + END OF TERMS AND CONDITIONS + + How to Apply These Terms to Your New Programs + + If you develop a new program, and you want it to be of the greatest +possible use to the public, the best way to achieve this is to make it +free software which everyone can redistribute and change under these terms. + + To do so, attach the following notices to the program. It is safest +to attach them to the start of each source file to most effectively +state the exclusion of warranty; and each file should have at least +the "copyright" line and a pointer to where the full notice is found. + + + Copyright (C) + + This program is free software: you can redistribute it and/or modify + it under the terms of the GNU General Public License as published by + the Free Software Foundation, either version 3 of the License, or + (at your option) any later version. + + This program is distributed in the hope that it will be useful, + but WITHOUT ANY WARRANTY; without even the implied warranty of + MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the + GNU General Public License for more details. + + You should have received a copy of the GNU General Public License + along with this program. If not, see . + +Also add information on how to contact you by electronic and paper mail. + + If the program does terminal interaction, make it output a short +notice like this when it starts in an interactive mode: + + Copyright (C) + This program comes with ABSOLUTELY NO WARRANTY; for details type `show w'. + This is free software, and you are welcome to redistribute it + under certain conditions; type `show c' for details. + +The hypothetical commands `show w' and `show c' should show the appropriate +parts of the General Public License. Of course, your program's commands +might be different; for a GUI interface, you would use an "about box". + + You should also get your employer (if you work as a programmer) or school, +if any, to sign a "copyright disclaimer" for the program, if necessary. +For more information on this, and how to apply and follow the GNU GPL, see +. + + The GNU General Public License does not permit incorporating your program +into proprietary programs. If your program is a subroutine library, you +may consider it more useful to permit linking proprietary applications with +the library. If this is what you want to do, use the GNU Lesser General +Public License instead of this License. But first, please read +. + +********************************************************************** +********************************************************************** diff --git a/vendor/tecnickcom/tc-lib-color/Makefile b/vendor/tecnickcom/tc-lib-color/Makefile new file mode 100644 index 0000000..bb35590 --- /dev/null +++ b/vendor/tecnickcom/tc-lib-color/Makefile @@ -0,0 +1,277 @@ +# Makefile +# +# @since 2015-02-21 +# @category Library +# @package Color +# @author Nicola Asuni +# @copyright 2015-2024 Nicola Asuni - Tecnick.com LTD +# @license http://www.gnu.org/copyleft/lesser.html GNU-LGPL v3 (see LICENSE) +# @link https://github.com/tecnickcom/tc-lib-color +# +# This file is part of tc-lib-color software library. +# ---------------------------------------------------------------------------------------------------------------------- + +SHELL=/bin/bash +.SHELLFLAGS=-o pipefail -c + +# Project owner +OWNER=tecnickcom + +# Project vendor +VENDOR=${OWNER} + +# Project name +PROJECT=tc-lib-color + +# Project version +VERSION=$(shell cat VERSION) + +# Project release number (packaging build number) +RELEASE=$(shell cat RELEASE) + +# Name of RPM or DEB package +PKGNAME=php-${OWNER}-${PROJECT} + +# Data dir +DATADIR=usr/share + +# PHP home folder +PHPHOME=${DATADIR}/php/Com/Tecnick + +# Default installation path for code +LIBPATH=${PHPHOME}/Color/ + +# Path for configuration files (etc/$(PKGNAME)/) +CONFIGPATH= + +# Default installation path for documentation +DOCPATH=${DATADIR}/doc/$(PKGNAME)/ + +# Installation path for the code +PATHINSTBIN=$(DESTDIR)/$(LIBPATH) + +# Installation path for the configuration files +PATHINSTCFG=$(DESTDIR)/$(CONFIGPATH) + +# Installation path for documentation +PATHINSTDOC=$(DESTDIR)/$(DOCPATH) + +# Current directory +CURRENTDIR=$(dir $(realpath $(firstword $(MAKEFILE_LIST)))) + +# Target directory +TARGETDIR=$(CURRENTDIR)target + +# RPM Packaging path (where RPMs will be stored) +PATHRPMPKG=$(TARGETDIR)/RPM + +# DEB Packaging path (where DEBs will be stored) +PATHDEBPKG=$(TARGETDIR)/DEB + +# BZ2 Packaging path (where BZ2s will be stored) +PATHBZ2PKG=$(TARGETDIR)/BZ2 + +# Default port number for the example server +PORT?=8000 + +# PHP binary +PHP=$(shell which php) + +# Composer executable (disable APC to as a work-around of a bug) +COMPOSER=$(PHP) -d "apc.enable_cli=0" $(shell which composer) + +# phpDocumentor executable file +PHPDOC=$(shell which phpDocumentor) + +# --- MAKE TARGETS --- + +# Display general help about this command +.PHONY: help +help: + @echo "" + @echo "$(PROJECT) Makefile." + @echo "The following commands are available:" + @echo "" + @echo " make buildall : Build and test everything from scratch" + @echo " make bz2 : Package the library in a compressed bz2 archive" + @echo " make clean : Delete the vendor and target directories" + @echo " make codefix : Fix code style violations" + @echo " make deb : Build a DEB package for Debian-like Linux distributions" + @echo " make deps : Download all dependencies" + @echo " make doc : Generate source code documentation" + @echo " make lint : Test source code for coding standard violations" + @echo " make qa : Run all tests and reports" + @echo " make report : Generate various reports" + @echo " make rpm : Build an RPM package for RedHat-like Linux distributions" + @echo " make server : Start the development server" + @echo " make test : Run unit tests" + @echo " make versionup: Increase the version patch number" + @echo "" + @echo "To test and build everything from scratch:" + @echo "make buildall" + @echo "" + +# alias for help target +.PHONY: all +all: help + +# Full build and test sequence +.PHONY: x +x: buildall + +# Full build and test sequence +.PHONY: buildall +buildall: deps codefix qa bz2 rpm deb + +# Package the library in a compressed bz2 archive +.PHONY: bz2 +bz2: + rm -rf $(PATHBZ2PKG) + make install DESTDIR=$(PATHBZ2PKG) + tar -jcvf $(PATHBZ2PKG)/$(PKGNAME)-$(VERSION)-$(RELEASE).tbz2 -C $(PATHBZ2PKG) $(DATADIR) + +# Delete the vendor and target directories +.PHONY: clean +clean: + rm -rf ./vendor $(TARGETDIR) + +# Fix code style violations +.PHONY: codefix +codefix: + ./vendor/bin/phpcbf --ignore="./vendor/" --standard=psr12 src test + +# Build a DEB package for Debian-like Linux distributions +.PHONY: deb +deb: + rm -rf $(PATHDEBPKG) + make install DESTDIR=$(PATHDEBPKG)/$(PKGNAME)-$(VERSION) + rm -f $(PATHDEBPKG)/$(PKGNAME)-$(VERSION)/$(DOCPATH)LICENSE + tar -zcvf $(PATHDEBPKG)/$(PKGNAME)_$(VERSION).orig.tar.gz -C $(PATHDEBPKG)/ $(PKGNAME)-$(VERSION) + cp -rf ./resources/debian $(PATHDEBPKG)/$(PKGNAME)-$(VERSION)/debian + find $(PATHDEBPKG)/$(PKGNAME)-$(VERSION)/debian/ -type f -exec sed -i "s/~#DATE#~/`date -R`/" {} \; + find $(PATHDEBPKG)/$(PKGNAME)-$(VERSION)/debian/ -type f -exec sed -i "s/~#VENDOR#~/$(VENDOR)/" {} \; + find $(PATHDEBPKG)/$(PKGNAME)-$(VERSION)/debian/ -type f -exec sed -i "s/~#PROJECT#~/$(PROJECT)/" {} \; + find $(PATHDEBPKG)/$(PKGNAME)-$(VERSION)/debian/ -type f -exec sed -i "s/~#PKGNAME#~/$(PKGNAME)/" {} \; + find $(PATHDEBPKG)/$(PKGNAME)-$(VERSION)/debian/ -type f -exec sed -i "s/~#VERSION#~/$(VERSION)/" {} \; + find $(PATHDEBPKG)/$(PKGNAME)-$(VERSION)/debian/ -type f -exec sed -i "s/~#RELEASE#~/$(RELEASE)/" {} \; + echo $(LIBPATH) > $(PATHDEBPKG)/$(PKGNAME)-$(VERSION)/debian/$(PKGNAME).dirs + echo "$(LIBPATH)* $(LIBPATH)" > $(PATHDEBPKG)/$(PKGNAME)-$(VERSION)/debian/install + echo $(DOCPATH) >> $(PATHDEBPKG)/$(PKGNAME)-$(VERSION)/debian/$(PKGNAME).dirs + echo "$(DOCPATH)* $(DOCPATH)" >> $(PATHDEBPKG)/$(PKGNAME)-$(VERSION)/debian/install +ifneq ($(strip $(CONFIGPATH)),) + echo $(CONFIGPATH) >> $(PATHDEBPKG)/$(PKGNAME)-$(VERSION)/debian/$(PKGNAME).dirs + echo "$(CONFIGPATH)* $(CONFIGPATH)" >> $(PATHDEBPKG)/$(PKGNAME)-$(VERSION)/debian/install +endif + echo "new-package-should-close-itp-bug" > $(PATHDEBPKG)/$(PKGNAME)-$(VERSION)/debian/$(PKGNAME).lintian-overrides + cd $(PATHDEBPKG)/$(PKGNAME)-$(VERSION) && debuild -us -uc + +# Clean all artifacts and download all dependencies +.PHONY: deps +deps: ensuretarget + rm -rf ./vendor/* + ($(COMPOSER) install -vvv --no-interaction) + curl --silent --show-error --fail --location --output ./vendor/phpstan.phar https://github.com/phpstan/phpstan/releases/download/2.1.2/phpstan.phar \ + && chmod +x ./vendor/phpstan.phar + +# Generate source code documentation +.PHONY: doc +doc: ensuretarget + rm -rf $(TARGETDIR)/doc + $(PHPDOC) -d ./src -t $(TARGETDIR)/doc/ + +# Create missing target directories for test and build artifacts +.PHONY: ensuretarget +ensuretarget: + mkdir -p $(TARGETDIR)/test + mkdir -p $(TARGETDIR)/report + mkdir -p $(TARGETDIR)/doc + +# Install this application +.PHONY: install +install: uninstall + mkdir -p $(PATHINSTBIN) + cp -rf ./src/* $(PATHINSTBIN) + cp -f ./resources/autoload.php $(PATHINSTBIN) + find $(PATHINSTBIN) -type d -exec chmod 755 {} \; + find $(PATHINSTBIN) -type f -exec chmod 644 {} \; + mkdir -p $(PATHINSTDOC) + cp -f ./LICENSE $(PATHINSTDOC) + cp -f ./README.md $(PATHINSTDOC) + cp -f ./VERSION $(PATHINSTDOC) + cp -f ./RELEASE $(PATHINSTDOC) + chmod -R 644 $(PATHINSTDOC)* +ifneq ($(strip $(CONFIGPATH)),) + mkdir -p $(PATHINSTCFG) + touch -c $(PATHINSTCFG)* + cp -ru ./resources/${CONFIGPATH}* $(PATHINSTCFG) + find $(PATHINSTCFG) -type d -exec chmod 755 {} \; + find $(PATHINSTCFG) -type f -exec chmod 644 {} \; +endif + +# Test source code for coding standard violations +.PHONY: lint +lint: + ./vendor/bin/phpcs --ignore="./vendor/" --standard=phpcs.xml src test + ./vendor/bin/phpmd src text codesize,unusedcode,naming,design --exclude */vendor/* + ./vendor/bin/phpmd test text unusedcode,naming,design --exclude */vendor/* + php -r 'exit((int)version_compare(PHP_MAJOR_VERSION, "7", ">"));' || ./vendor/phpstan.phar analyse + +# Run all tests and reports +.PHONY: qa +qa: ensuretarget lint test report + +# Generate various reports +.PHONY: report +report: ensuretarget + ./vendor/bin/pdepend --jdepend-xml=$(TARGETDIR)/report/dependencies.xml --summary-xml=$(TARGETDIR)/report/metrics.xml --jdepend-chart=$(TARGETDIR)/report/dependecies.svg --overview-pyramid=$(TARGETDIR)/report/overview-pyramid.svg --ignore=vendor ./src + #./vendor/bartlett/php-compatinfo/bin/phpcompatinfo --no-ansi analyser:run src/ > $(TARGETDIR)/report/phpcompatinfo.txt + +# Build the RPM package for RedHat-like Linux distributions +.PHONY: rpm +rpm: + rm -rf $(PATHRPMPKG) + rpmbuild \ + --define "_topdir $(PATHRPMPKG)" \ + --define "_vendor $(VENDOR)" \ + --define "_owner $(OWNER)" \ + --define "_project $(PROJECT)" \ + --define "_package $(PKGNAME)" \ + --define "_version $(VERSION)" \ + --define "_release $(RELEASE)" \ + --define "_current_directory $(CURRENTDIR)" \ + --define "_libpath /$(LIBPATH)" \ + --define "_docpath /$(DOCPATH)" \ + --define "_configpath /$(CONFIGPATH)" \ + -bb resources/rpm/rpm.spec + +# Start the development server +.PHONY: server +server: + $(PHP) -t example -S localhost:$(PORT) + +# Tag this GIT version +.PHONY: tag +tag: + git checkout main && \ + git tag -a ${VERSION} -m "Release ${VERSION}" && \ + git push origin --tags && \ + git pull + +# Run unit tests +.PHONY: test +test: + cp phpunit.xml.dist phpunit.xml + #./vendor/bin/phpunit --migrate-configuration || true + XDEBUG_MODE=coverage ./vendor/bin/phpunit --stderr test + +# Remove all installed files +.PHONY: uninstall +uninstall: + rm -rf $(PATHINSTBIN) + rm -rf $(PATHINSTDOC) + +# Increase the version patch number +.PHONY: versionup +versionup: + echo ${VERSION} | gawk -F. '{printf("%d.%d.%d\n",$$1,$$2,(($$3+1)));}' > VERSION + diff --git a/vendor/tecnickcom/tc-lib-color/README.md b/vendor/tecnickcom/tc-lib-color/README.md new file mode 100644 index 0000000..2edd393 --- /dev/null +++ b/vendor/tecnickcom/tc-lib-color/README.md @@ -0,0 +1,109 @@ +# tc-lib-color +*PHP Color Library* + +[![Latest Stable Version](https://poser.pugx.org/tecnickcom/tc-lib-color/version)](https://packagist.org/packages/tecnickcom/tc-lib-color) +![Build](https://github.com/tecnickcom/tc-lib-color/actions/workflows/check.yml/badge.svg) +[![Coverage](https://codecov.io/gh/tecnickcom/tc-lib-color/graph/badge.svg?token=l3UCVbShmc)](https://codecov.io/gh/tecnickcom/tc-lib-color) +[![License](https://poser.pugx.org/tecnickcom/tc-lib-color/license)](https://packagist.org/packages/tecnickcom/tc-lib-color) +[![Downloads](https://poser.pugx.org/tecnickcom/tc-lib-color/downloads)](https://packagist.org/packages/tecnickcom/tc-lib-color) + +[![Donate via PayPal](https://img.shields.io/badge/donate-paypal-87ceeb.svg)](https://www.paypal.com/donate/?hosted_button_id=NZUEC5XS8MFBJ) +*Please consider supporting this project by making a donation via [PayPal](https://www.paypal.com/donate/?hosted_button_id=NZUEC5XS8MFBJ)* + +* **category** Library +* **package** \Com\Tecnick\Color +* **author** Nicola Asuni +* **copyright** 2001-2025 Nicola Asuni - Tecnick.com LTD +* **license** http://www.gnu.org/copyleft/lesser.html GNU-LGPL v3 (see LICENSE.TXT) +* **link** https://github.com/tecnickcom/tc-lib-color +* **SRC DOC** https://tcpdf.org/docs/srcdoc/tc-lib-color + +## Description + +This library includes utility classes to get colors in various representation formats. + +The initial source code has been derived from [TCPDF](). + + +## Getting started + +First, you need to install all development dependencies using [Composer](https://getcomposer.org/): + +```bash +$ curl -sS https://getcomposer.org/installer | php +$ mv composer.phar /usr/local/bin/composer +``` + +This project include a Makefile that allows you to test and build the project with simple commands. +To see all available options: + +```bash +make help +``` + +To install all the development dependencies: + +```bash +make deps +``` + +## Running all tests + +Before committing the code, please check if it passes all tests using + +```bash +make qa +``` + +All artifacts are generated in the target directory. + + +## Example + +Examples are located in the `example` directory. + +Start a development server (requires PHP 8.0) using the command: + +``` +make server +``` + +and point your browser to + + +## Installation + +Create a composer.json in your projects root-directory: + +```json +{ + "require": { + "tecnickcom/tc-lib-color": "^2.0" + } +} +``` + +Or add to an existing project with: + +```bash +composer require tecnickcom/tc-lib-color ^2.0 +``` + + +## Packaging + +This library is mainly intended to be used and included in other PHP projects using Composer. +However, since some production environments dictates the installation of any application as RPM or DEB packages, +this library includes make targets for building these packages (`make rpm` and `make deb`). +The packages are generated under the `target` directory. + +When this library is installed using an RPM or DEB package, you can use it your code by including the autoloader: +``` +require_once ('/usr/share/php/Com/Tecnick/Color/autoload.php'); +``` + + + +## Developer(s) Contact + +* Nicola Asuni diff --git a/vendor/tecnickcom/tc-lib-color/RELEASE b/vendor/tecnickcom/tc-lib-color/RELEASE new file mode 100644 index 0000000..573541a --- /dev/null +++ b/vendor/tecnickcom/tc-lib-color/RELEASE @@ -0,0 +1 @@ +0 diff --git a/vendor/tecnickcom/tc-lib-color/SECURITY.md b/vendor/tecnickcom/tc-lib-color/SECURITY.md new file mode 100644 index 0000000..6150279 --- /dev/null +++ b/vendor/tecnickcom/tc-lib-color/SECURITY.md @@ -0,0 +1,5 @@ +# Security Policy + +## Reporting a Vulnerability + +Please report (suspected) security vulnerabilities to info@tecnick.com. diff --git a/vendor/tecnickcom/tc-lib-color/VERSION b/vendor/tecnickcom/tc-lib-color/VERSION new file mode 100644 index 0000000..f2b42fc --- /dev/null +++ b/vendor/tecnickcom/tc-lib-color/VERSION @@ -0,0 +1 @@ +2.2.13 diff --git a/vendor/tecnickcom/tc-lib-color/composer.json b/vendor/tecnickcom/tc-lib-color/composer.json new file mode 100644 index 0000000..e585965 --- /dev/null +++ b/vendor/tecnickcom/tc-lib-color/composer.json @@ -0,0 +1,46 @@ +{ + "name": "tecnickcom/tc-lib-color", + "description": "PHP library to manipulate various color representations", + "type": "library", + "homepage": "http://www.tecnick.com", + "license": "LGPL-3.0-or-later", + "keywords": [ + "tc-lib-color", + "color", + "colors", + "colour", + "colours", + "javascript", + "web", + "rgb", + "rgba", + "cmyk", + "hsl", + "hsla" + ], + "authors": [ + { + "name": "Nicola Asuni", + "email": "info@tecnick.com", + "role": "lead" + } + ], + "require": { + "php": ">=8.1", + "ext-pcre": "*" + }, + "require-dev": { + "pdepend/pdepend": "2.16.2", + "phpmd/phpmd": "2.15.0", + "phpunit/phpunit": "12.2.0 || 11.5.7 || 10.5.40", + "squizlabs/php_codesniffer": "3.13.0" + }, + "autoload": { + "psr-4": { + "Com\\Tecnick\\Color\\": "src" + } + }, + "autoload-dev": { + "psr-4": { "Test\\": "test" } + } +} diff --git a/vendor/tecnickcom/tc-lib-color/example/index.php b/vendor/tecnickcom/tc-lib-color/example/index.php new file mode 100644 index 0000000..e230d87 --- /dev/null +++ b/vendor/tecnickcom/tc-lib-color/example/index.php @@ -0,0 +1,111 @@ + + * @copyright 2015-2024 Nicola Asuni - Tecnick.com LTD + * @license http://www.gnu.org/copyleft/lesser.html GNU-LGPL v3 (see LICENSE.TXT) + * @link https://github.com/tecnickcom/tc-lib-color + * + * This file is part of tc-lib-color software library. + */ + +// autoloader when using Composer +require __DIR__ . '/../vendor/autoload.php'; + +// autoloader when using RPM or DEB package installation +//require ('/usr/share/php/Com/Tecnick/Color/autoload.php'); + +$colobj = new \Com\Tecnick\Color\Web(); + +$colmap = $colobj::WEBHEX; + +$tablerows = ''; +$invtablerows = ''; +foreach ($colmap as $name => $hex) { + $rgbcolor = $colobj->getRgbObjFromHex($hex); + $hslcolor = new \Com\Tecnick\Color\Model\Hsl($rgbcolor->toHslArray()); + $comp = $rgbcolor->getNormalizedArray(255); + // web colors + $tablerows .= ' ' + . '' . $name . '' + . '' . $rgbcolor->getRgbHexColor() . '' + . '' . $comp['R'] . '' + . '' . $comp['G'] . '' + . '' . $comp['B'] . '' + . '' . $rgbcolor->getCssColor() . '' + . '' . $hslcolor->getCssColor() . '' + . '' . $rgbcolor->getJsPdfColor() . '' + . '' . "\n"; + // normalised inverted web colors + $invcolor = clone $rgbcolor; + $invcolor->invertColor(); + $invcolname = $colobj->getClosestWebColor($invcolor->toRgbArray()); + $invrgbcolor = $colobj->getRgbObjFromName($invcolname); + $invtablerows .= '' . $name . '' + . ' ' + . ' ' + . '' . $invcolname . '' + . '' . "\n"; +} + +echo " + + + + Usage example of tc-lib-color library + + + + + +

Usage example of tc-lib-color library

+

This is an usage example of tc-lib-color library.

+

Web Colors Table

+ + + + + + + + + + + + + + + +" . $tablerows . " + +
COLORNAMEHEXREDGREENBLUECSS-RGBACSS-HSLAPDF-JS
+

Normalized Inverted Web Colors Table

+ + + + + + + + + + + + + + +" . $invtablerows . " + +
AB
NAMECOLORCOLORNAME
+ + +"; diff --git a/vendor/tecnickcom/tc-lib-color/phpcompatinfo.json b/vendor/tecnickcom/tc-lib-color/phpcompatinfo.json new file mode 100644 index 0000000..dc01759 --- /dev/null +++ b/vendor/tecnickcom/tc-lib-color/phpcompatinfo.json @@ -0,0 +1,15 @@ +{ + "source-providers": [ + { + "in": "src as source", + "exclude": "vendor", + "name": "/\\.(php)$/" + } + ], + "plugins": [ + ], + "analysers": [ + ], + "services": [ + ] +} diff --git a/vendor/tecnickcom/tc-lib-color/phpcs.xml b/vendor/tecnickcom/tc-lib-color/phpcs.xml new file mode 100644 index 0000000..7c9da08 --- /dev/null +++ b/vendor/tecnickcom/tc-lib-color/phpcs.xml @@ -0,0 +1,7 @@ + + + PSR-12 for PHP less than 7.1 + + + + diff --git a/vendor/tecnickcom/tc-lib-color/phpstan.neon b/vendor/tecnickcom/tc-lib-color/phpstan.neon new file mode 100644 index 0000000..86bd47d --- /dev/null +++ b/vendor/tecnickcom/tc-lib-color/phpstan.neon @@ -0,0 +1,10 @@ +parameters: + level: max + paths: + - src + - test + excludePaths: + - vendor + ignoreErrors: + reportUnmatchedIgnoredErrors: false + treatPhpDocTypesAsCertain: false diff --git a/vendor/tecnickcom/tc-lib-color/phpunit.xml.dist b/vendor/tecnickcom/tc-lib-color/phpunit.xml.dist new file mode 100644 index 0000000..702ff12 --- /dev/null +++ b/vendor/tecnickcom/tc-lib-color/phpunit.xml.dist @@ -0,0 +1,31 @@ + + + + + ./test + + + + + src + + + + + + + + + + + + diff --git a/vendor/tecnickcom/tc-lib-color/resources/autoload.php b/vendor/tecnickcom/tc-lib-color/resources/autoload.php new file mode 100644 index 0000000..7c6ec88 --- /dev/null +++ b/vendor/tecnickcom/tc-lib-color/resources/autoload.php @@ -0,0 +1,30 @@ + + * @copyright 2015-2024 Nicola Asuni - Tecnick.com LTD + * @license http://www.gnu.org/copyleft/lesser.html GNU-LGPL v3 (see LICENSE.TXT) + * @link https://github.com/tecnickcom/tc-lib-color + * + * This file is part of tc-lib-color software library. + */ +spl_autoload_register( + function ($class) { + $prefix = 'Com\\Tecnick\\'; + $len = strlen($prefix); + if (strncmp($prefix, $class, $len) !== 0) { + return; + } + $relative_class = substr($class, $len); + $file = dirname(__DIR__).'/'.str_replace('\\', '/', $relative_class).'.php'; + if (file_exists($file)) { + require $file; + } + } +); diff --git a/vendor/tecnickcom/tc-lib-color/resources/debian/changelog b/vendor/tecnickcom/tc-lib-color/resources/debian/changelog new file mode 100644 index 0000000..7767c79 --- /dev/null +++ b/vendor/tecnickcom/tc-lib-color/resources/debian/changelog @@ -0,0 +1,7 @@ +~#PKGNAME#~ (~#VERSION#~-~#RELEASE#~) UNRELEASED; urgency=low + + * Please check the + https://github.com/~#VENDOR#~/~#PROJECT#~ + commit history + + -- Nicola Asuni ~#DATE#~ diff --git a/vendor/tecnickcom/tc-lib-color/resources/debian/compat b/vendor/tecnickcom/tc-lib-color/resources/debian/compat new file mode 100644 index 0000000..f599e28 --- /dev/null +++ b/vendor/tecnickcom/tc-lib-color/resources/debian/compat @@ -0,0 +1 @@ +10 diff --git a/vendor/tecnickcom/tc-lib-color/resources/debian/control b/vendor/tecnickcom/tc-lib-color/resources/debian/control new file mode 100644 index 0000000..402779c --- /dev/null +++ b/vendor/tecnickcom/tc-lib-color/resources/debian/control @@ -0,0 +1,16 @@ +Source: ~#PKGNAME#~ +Maintainer: Nicola Asuni +Section: php +Priority: optional +Build-Depends: debhelper (>= 9) +Standards-Version: 3.9.7 +Homepage: https://github.com/~#VENDOR#~/~#PROJECT#~ +Vcs-Git: https://github.com/~#VENDOR#~/~#PROJECT#~.git + +Package: ~#PKGNAME#~ +Provides: php-~#PROJECT#~ +Architecture: all +Depends: php (>= 8.1.0), ${misc:Depends} +Description: PHP Color library + This library includes PHP classes to parse and manipulate + various colors representations GRAY, RGB, HSL, CMYK. diff --git a/vendor/tecnickcom/tc-lib-color/resources/debian/copyright b/vendor/tecnickcom/tc-lib-color/resources/debian/copyright new file mode 100644 index 0000000..68603ae --- /dev/null +++ b/vendor/tecnickcom/tc-lib-color/resources/debian/copyright @@ -0,0 +1,20 @@ +Format: http://www.debian.org/doc/packaging-manuals/copyright-format/1.0/ +Upstream-Name: ~#PROJECT#~ +Source: https://github.com/~#VENDOR#~/~#PROJECT#~ + +Files: * +Copyright: Copyright 2001-2024 Nicola Asuni +License: LGPL-3 + +License: LGPL-3 + This program is free software: you can redistribute it and/or modify + it under the terms of the GNU Lesser General Public License as + published by the Free Software Foundation, either version 3 of the + License, or (at your option) any later version. + This program is distributed in the hope that it will be useful, + but WITHOUT ANY WARRANTY; without even the implied warranty of + MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the + GNU General Public License for more details. + You should have received a copy of the GNU General Public License + along with this program. If not, see or + /usr/share/common-licenses/LGPL-3 diff --git a/vendor/tecnickcom/tc-lib-color/resources/debian/rules b/vendor/tecnickcom/tc-lib-color/resources/debian/rules new file mode 100644 index 0000000..cbe925d --- /dev/null +++ b/vendor/tecnickcom/tc-lib-color/resources/debian/rules @@ -0,0 +1,3 @@ +#!/usr/bin/make -f +%: + dh $@ diff --git a/vendor/tecnickcom/tc-lib-color/resources/debian/source/format b/vendor/tecnickcom/tc-lib-color/resources/debian/source/format new file mode 100644 index 0000000..163aaf8 --- /dev/null +++ b/vendor/tecnickcom/tc-lib-color/resources/debian/source/format @@ -0,0 +1 @@ +3.0 (quilt) diff --git a/vendor/tecnickcom/tc-lib-color/resources/rpm/rpm.spec b/vendor/tecnickcom/tc-lib-color/resources/rpm/rpm.spec new file mode 100644 index 0000000..f4e2ef5 --- /dev/null +++ b/vendor/tecnickcom/tc-lib-color/resources/rpm/rpm.spec @@ -0,0 +1,49 @@ +# SPEC file + +%global c_vendor %{_vendor} +%global gh_owner %{_owner} +%global gh_project %{_project} + +Name: %{_package} +Version: %{_version} +Release: %{_release}%{?dist} +Summary: PHP library to manipulate various color representations + +Group: Development/Libraries +License: LGPLv3+ +URL: https://github.com/%{gh_owner}/%{gh_project} + +BuildRoot: %{_tmppath}/%{name}-%{version}-%{release}-%(%{__id_u} -n) +BuildArch: noarch + +Requires: php(language) >= 8.1.0 +Requires: php-pcre + +Provides: php-composer(%{c_vendor}/%{gh_project}) = %{version} +Provides: php-%{gh_project} = %{version} + +%description +PHP library to manipulate various color representations (GRAY, RGB, HSL, CMYK) and parse Web colors. + +%build +#(cd %{_current_directory} && make build) + +%install +rm -rf $RPM_BUILD_ROOT +(cd %{_current_directory} && make install DESTDIR=$RPM_BUILD_ROOT) + +%clean +rm -rf $RPM_BUILD_ROOT +#(cd %{_current_directory} && make clean) + +%files +%attr(-,root,root) %{_libpath} +%attr(-,root,root) %{_docpath} +%docdir %{_docpath} +#%config(noreplace) %{_configpath}* + +%changelog +* Thu Jul 02 2024 Nicola Asuni 1.5.0-1 +- Changed package name, add provides section +* Tue Feb 24 2024 Nicola Asuni 1.0.0-1 +- Initial Commit diff --git a/vendor/tecnickcom/tc-lib-color/src/Css.php b/vendor/tecnickcom/tc-lib-color/src/Css.php new file mode 100644 index 0000000..5b3444f --- /dev/null +++ b/vendor/tecnickcom/tc-lib-color/src/Css.php @@ -0,0 +1,219 @@ + + * @copyright 2015-2024 Nicola Asuni - Tecnick.com LTD + * @license http://www.gnu.org/copyleft/lesser.html GNU-LGPL v3 (see LICENSE.TXT) + * @link https://github.com/tecnickcom/tc-lib-color + * + * This file is part of tc-lib-color software library. + */ + +namespace Com\Tecnick\Color; + +use Com\Tecnick\Color\Exception as ColorException; + +/** + * Com\Tecnick\Color\Css + * + * Css Color class + * + * @since 2015-02-21 + * @category Library + * @package Color + * @author Nicola Asuni + * @copyright 2015-2024 Nicola Asuni - Tecnick.com LTD + * @license http://www.gnu.org/copyleft/lesser.html GNU-LGPL v3 (see LICENSE.TXT) + * @link https://github.com/tecnickcom/tc-lib-color + */ +abstract class Css +{ + abstract public function normalizeValue(mixed $value, int $max): float; + + /** + * Get the color object from acrobat Javascript syntax + * + * @param string $color color specification (e.g.: ["RGB",0.1,0.3,1]) + * + * @throws ColorException if the color is not found + */ + protected function getColorObjFromJs(string $color): ?\Com\Tecnick\Color\Model + { + if (! isset($color[2]) || (strpos('tgrc', $color[2]) === false)) { + throw new ColorException('invalid javascript color: ' . $color); + } + + switch ($color[2]) { + case 'g': + $rex = '/[\[][\"\']g[\"\'][\,]([0-9\.]+)[\]]/'; + if (preg_match($rex, $color, $col) !== 1) { + throw new ColorException('invalid javascript color: ' . $color); + } + + return new \Com\Tecnick\Color\Model\Gray([ + 'gray' => $col[1], + 'alpha' => 1, + ]); + case 'r': + $rex = '/[\[][\"\']rgb[\"\'][\,]([0-9\.]+)[\,]([0-9\.]+)[\,]([0-9\.]+)[\]]/'; + if (preg_match($rex, $color, $col) !== 1) { + throw new ColorException('invalid javascript color: ' . $color); + } + + return new \Com\Tecnick\Color\Model\Rgb( + [ + 'red' => $col[1], + 'green' => $col[2], + 'blue' => $col[3], + 'alpha' => 1, + ] + ); + case 'c': + $rex = '/[\[][\"\']cmyk[\"\'][\,]([0-9\.]+)[\,]([0-9\.]+)[\,]([0-9\.]+)[\,]([0-9\.]+)[\]]/'; + if (preg_match($rex, $color, $col) !== 1) { + throw new ColorException('invalid javascript color: ' . $color); + } + + return new \Com\Tecnick\Color\Model\Cmyk( + [ + 'cyan' => $col[1], + 'magenta' => $col[2], + 'yellow' => $col[3], + 'key' => $col[4], + 'alpha' => 1, + ] + ); + } + + // case 't' + return null; + } + + /** + * Get the color object from a CSS color string + * + * @param string $type color type: t, g, rgb, rgba, hsl, hsla, cmyk + * @param string $color color specification (e.g.: rgb(255,128,64)) + * + * @throws ColorException if the color is not found + */ + protected function getColorObjFromCss(string $type, string $color): ?\Com\Tecnick\Color\Model + { + switch ($type) { + case 'g': + return $this->getColorObjFromCssGray($color); + case 'rgb': + case 'rgba': + return $this->getColorObjFromCssRgb($color); + case 'hsl': + case 'hsla': + return $this->getColorObjFromCssHsl($color); + case 'cmyk': + case 'cmyka': + return $this->getColorObjFromCssCmyk($color); + } + + // case 't' + return null; + } + + /** + * Get the color object from a CSS CMYK color string + * + * @param string $color color specification (e.g.: rgb(255,128,64)) + * + * @throws ColorException if the color is not found + */ + private function getColorObjFromCssGray(string $color): \Com\Tecnick\Color\Model\Gray + { + $rex = '/[\(]([0-9\%]+)[\)]/'; + if (preg_match($rex, $color, $col) !== 1) { + throw new ColorException('invalid css color: ' . $color); + } + + return new \Com\Tecnick\Color\Model\Gray( + [ + 'gray' => $this->normalizeValue($col[1], 255), + 'alpha' => 1, + ] + ); + } + + /** + * Get the color object from a CSS CMYK color string + * + * @param string $color color specification (e.g.: rgb(255,128,64)) + * + * @throws ColorException if the color is not found + */ + private function getColorObjFromCssRgb(string $color): \Com\Tecnick\Color\Model\Rgb + { + $rex = '/[\(]([0-9\%]+)[\,]([0-9\%]+)[\,]([0-9\%]+)[\,]?([0-9\.]*)[\)]/'; + if (preg_match($rex, $color, $col) !== 1) { + throw new ColorException('invalid css color: ' . $color); + } + + return new \Com\Tecnick\Color\Model\Rgb( + [ + 'red' => $this->normalizeValue($col[1], 255), + 'green' => $this->normalizeValue($col[2], 255), + 'blue' => $this->normalizeValue($col[3], 255), + 'alpha' => (isset($col[4][0]) ? $col[4] : 1), + ] + ); + } + + /** + * Get the color object from a CSS CMYK color string + * + * @param string $color color specification (e.g.: rgb(255,128,64)) + * + * @throws ColorException if the color is not found + */ + private function getColorObjFromCssHsl(string $color): \Com\Tecnick\Color\Model\Hsl + { + $rex = '/[\(]([0-9\%]+)[\,]([0-9\%]+)[\,]([0-9\%]+)[\,]?([0-9\.]*)[\)]/'; + if (preg_match($rex, $color, $col) !== 1) { + throw new ColorException('invalid css color: ' . $color); + } + + return new \Com\Tecnick\Color\Model\Hsl( + [ + 'hue' => $this->normalizeValue($col[1], 360), + 'saturation' => $this->normalizeValue($col[2], 1), + 'lightness' => $this->normalizeValue($col[3], 1), + 'alpha' => (isset($col[4][0]) ? $col[4] : 1), + ] + ); + } + + /** + * Get the color object from a CSS CMYK color string + * + * @param string $color color specification (e.g.: rgb(255,128,64)) + * + * @throws ColorException if the color is not found + */ + private function getColorObjFromCssCmyk(string $color): \Com\Tecnick\Color\Model\Cmyk + { + $rex = '/[\(]([0-9\%]+)[\,]([0-9\%]+)[\,]([0-9\%]+)[\,]([0-9\%]+)[\,]?([0-9\.]*)[\)]/'; + if (preg_match($rex, $color, $col) !== 1) { + throw new ColorException('invalid css color: ' . $color); + } + + return new \Com\Tecnick\Color\Model\Cmyk( + [ + 'cyan' => $this->normalizeValue($col[1], 100), + 'magenta' => $this->normalizeValue($col[2], 100), + 'yellow' => $this->normalizeValue($col[3], 100), + 'key' => $this->normalizeValue($col[4], 100), + 'alpha' => (isset($col[5][0]) ? $col[5] : 1), + ] + ); + } +} diff --git a/vendor/tecnickcom/tc-lib-color/src/Exception.php b/vendor/tecnickcom/tc-lib-color/src/Exception.php new file mode 100644 index 0000000..609e85c --- /dev/null +++ b/vendor/tecnickcom/tc-lib-color/src/Exception.php @@ -0,0 +1,34 @@ + + * @copyright 2015-2024 Nicola Asuni - Tecnick.com LTD + * @license http://www.gnu.org/copyleft/lesser.html GNU-LGPL v3 (see LICENSE.TXT) + * @link https://github.com/tecnickcom/tc-lib-color + * + * This file is part of tc-lib-color software library. + */ + +namespace Com\Tecnick\Color; + +/** + * Com\Tecnick\Color\Exception + * + * Custom Exception class + * + * @since 2015-02-21 + * @category Library + * @package Color + * @author Nicola Asuni + * @copyright 2015-2024 Nicola Asuni - Tecnick.com LTD + * @license http://www.gnu.org/copyleft/lesser.html GNU-LGPL v3 (see LICENSE.TXT) + * @link https://github.com/tecnickcom/tc-lib-color + */ +class Exception extends \Exception +{ +} diff --git a/vendor/tecnickcom/tc-lib-color/src/Model.php b/vendor/tecnickcom/tc-lib-color/src/Model.php new file mode 100644 index 0000000..8ef5459 --- /dev/null +++ b/vendor/tecnickcom/tc-lib-color/src/Model.php @@ -0,0 +1,122 @@ + + * @copyright 2015-2024 Nicola Asuni - Tecnick.com LTD + * @license http://www.gnu.org/copyleft/lesser.html GNU-LGPL v3 (see LICENSE.TXT) + * @link https://github.com/tecnickcom/tc-lib-color + * + * This file is part of tc-lib-color software library. + */ + +namespace Com\Tecnick\Color; + +/** + * Com\Tecnick\Color\Model + * + * Color Model class + * + * @since 2015-02-21 + * @category Library + * @package Color + * @author Nicola Asuni + * @copyright 2015-2024 Nicola Asuni - Tecnick.com LTD + * @license http://www.gnu.org/copyleft/lesser.html GNU-LGPL v3 (see LICENSE.TXT) + * @link https://github.com/tecnickcom/tc-lib-color + */ +abstract class Model implements \Com\Tecnick\Color\Model\Template +{ + /** + * Color Model type (GRAY, RGB, HSL, CMYK) + * + * @var string + */ + protected $type; + + /** + * Value of the Alpha channel component. + * Values range between 0.0 (fully transparent) and 1.0 (fully opaque) + * + * @var float + */ + protected $cmp_alpha = 1.0; + + /** + * Initialize a new color object. + * + * @param array $components color components. + */ + public function __construct(array $components) + { + foreach ($components as $color => $value) { + $property = 'cmp_' . $color; + if (property_exists($this, $property)) { + $this->$property = (max(0, min(1, (float) $value))); + } + } + } + + /** + * Get the color model type (GRAY, RGB, HSL, CMYK) + */ + public function getType(): string + { + return $this->type; + } + + /** + * Get the normalized integer value of the specified float fraction + * + * @param float $value Fraction value to convert [0..1] + * @param int $max Maximum value to return (reference value) + * + * @return float value [0..$max] + */ + public function getNormalizedValue(float $value, int $max): float + { + // NOTE: The last round has been added for backward compatibility because of: + // https://github.com/php/php-src/issues/14332 + return round(max(0, min($max, ($max * round($value, 14))))); + } + + /** + * Get the normalized hexadecimal value of the specified float fraction + * + * @param float $value Fraction value to convert [0..1] + * @param int $max Maximum value to return (reference value) + */ + public function getHexValue(float $value, int $max): string + { + return sprintf('%02x', $this->getNormalizedValue($value, $max)); + } + + /** + * Get the Hexadecimal representation of the color with alpha channel: #RRGGBBAA + */ + public function getRgbaHexColor(): string + { + $rgba = $this->toRgbArray(); + return '#' + . $this->getHexValue($rgba['red'], 255) + . $this->getHexValue($rgba['green'], 255) + . $this->getHexValue($rgba['blue'], 255) + . $this->getHexValue($rgba['alpha'], 255); + } + + /** + * Get the Hexadecimal representation of the color: #RRGGBB + */ + public function getRgbHexColor(): string + { + $rgba = $this->toRgbArray(); + return '#' + . $this->getHexValue($rgba['red'], 255) + . $this->getHexValue($rgba['green'], 255) + . $this->getHexValue($rgba['blue'], 255); + } +} diff --git a/vendor/tecnickcom/tc-lib-color/src/Model/Cmyk.php b/vendor/tecnickcom/tc-lib-color/src/Model/Cmyk.php new file mode 100644 index 0000000..2b9d75c --- /dev/null +++ b/vendor/tecnickcom/tc-lib-color/src/Model/Cmyk.php @@ -0,0 +1,223 @@ + + * @copyright 2015-2024 Nicola Asuni - Tecnick.com LTD + * @license http://www.gnu.org/copyleft/lesser.html GNU-LGPL v3 (see LICENSE.TXT) + * @link https://github.com/tecnickcom/tc-lib-color + * + * This file is part of tc-lib-color software library. + */ + +namespace Com\Tecnick\Color\Model; + +/** + * Com\Tecnick\Color\Model\Cmyk + * + * CMYK Color Model class + * + * @since 2015-02-21 + * @category Library + * @package Color + * @author Nicola Asuni + * @copyright 2015-2024 Nicola Asuni - Tecnick.com LTD + * @license http://www.gnu.org/copyleft/lesser.html GNU-LGPL v3 (see LICENSE.TXT) + * @link https://github.com/tecnickcom/tc-lib-color + */ +class Cmyk extends \Com\Tecnick\Color\Model +{ + /** + * Color Model type + * + * @var string + */ + protected $type = 'CMYK'; + + /** + * Value of the Cyan color component [0..1] + * + * @var float + */ + protected $cmp_cyan = 0.0; + + /** + * Value of the Magenta color component [0..1] + * + * @var float + */ + protected $cmp_magenta = 0.0; + + /** + * Value of the Yellow color component [0..1] + * + * @var float + */ + protected $cmp_yellow = 0.0; + + /** + * Value of the Key (Black) color component [0..1] + * + * @var float + */ + protected $cmp_key = 0.0; + + /** + * Get an array with all color components + * + * @return array with keys ('C', 'M', 'Y', 'K', 'A') + */ + public function getArray(): array + { + return [ + 'C' => $this->cmp_cyan, + 'M' => $this->cmp_magenta, + 'Y' => $this->cmp_yellow, + 'K' => $this->cmp_key, + 'A' => $this->cmp_alpha, + ]; + } + + /** + * Get an array with color components values normalized between 0 and $max. + * NOTE: the alpha and other fraction component values are kept in the [0..1] range. + * + * @param int $max Maximum value to return (reference value - it should be 100) + * + * @return array with keys ('C', 'M', 'Y', 'K', 'A') + */ + public function getNormalizedArray(int $max): array + { + return [ + 'C' => $this->getNormalizedValue($this->cmp_cyan, $max), + 'M' => $this->getNormalizedValue($this->cmp_magenta, $max), + 'Y' => $this->getNormalizedValue($this->cmp_yellow, $max), + 'K' => $this->getNormalizedValue($this->cmp_key, $max), + 'A' => $this->cmp_alpha, + ]; + } + + /** + * Get the CSS representation of the color: rgba(R, G, B, A) + * NOTE: Supported since CSS3 and above. + * Use getHexadecimalColor() for CSS1 and CSS2 + */ + public function getCssColor(): string + { + $rgb = $this->toRgbArray(); + return 'rgba(' + . $this->getNormalizedValue($rgb['red'], 100) . '%,' + . $this->getNormalizedValue($rgb['green'], 100) . '%,' + . $this->getNormalizedValue($rgb['blue'], 100) . '%,' + . $rgb['alpha'] + . ')'; + } + + /** + * Get the color format used in Acrobat JavaScript + * NOTE: the alpha channel is omitted from this representation unless is 0 = transparent + */ + public function getJsPdfColor(): string + { + if ($this->cmp_alpha == 0) { + return '["T"]'; // transparent color + } + + return sprintf('["CMYK",%F,%F,%F,%F]', $this->cmp_cyan, $this->cmp_magenta, $this->cmp_yellow, $this->cmp_key); + } + + /** + * Get a space separated string with color component values. + */ + public function getComponentsString(): string + { + return sprintf('%F %F %F %F', $this->cmp_cyan, $this->cmp_magenta, $this->cmp_yellow, $this->cmp_key); + } + + /** + * Get the color components format used in PDF documents (CMYK) + * NOTE: the alpha channel is omitted + * + * @param bool $stroke True for stroking (lines, drawing) and false for non-stroking (text and area filling). + */ + public function getPdfColor($stroke = false): string + { + $mode = 'k'; + if ($stroke) { + $mode = strtoupper($mode); + } + + return $this->getComponentsString() . ' ' . $mode . "\n"; + } + + /** + * Get an array with Gray color components + * + * @return array with keys ('gray') + */ + public function toGrayArray(): array + { + return [ + 'gray' => $this->cmp_key, + 'alpha' => $this->cmp_alpha, + ]; + } + + /** + * Get an array with RGB color components + * + * @return array with keys ('red', 'green', 'blue', 'alpha') + */ + public function toRgbArray(): array + { + return [ + 'red' => max(0, min(1, (1 - (($this->cmp_cyan * (1 - $this->cmp_key)) + $this->cmp_key)))), + 'green' => max(0, min(1, (1 - (($this->cmp_magenta * (1 - $this->cmp_key)) + $this->cmp_key)))), + 'blue' => max(0, min(1, (1 - (($this->cmp_yellow * (1 - $this->cmp_key)) + $this->cmp_key)))), + 'alpha' => $this->cmp_alpha, + ]; + } + + /** + * Get an array with HSL color components + * + * @return array with keys ('hue', 'saturation', 'lightness', 'alpha') + */ + public function toHslArray(): array + { + $rgb = new \Com\Tecnick\Color\Model\Rgb($this->toRgbArray()); + return $rgb->toHslArray(); + } + + /** + * Get an array with CMYK color components + * + * @return array with keys ('cyan', 'magenta', 'yellow', 'key', 'alpha') + */ + public function toCmykArray(): array + { + return [ + 'cyan' => $this->cmp_cyan, + 'magenta' => $this->cmp_magenta, + 'yellow' => $this->cmp_yellow, + 'key' => $this->cmp_key, + 'alpha' => $this->cmp_alpha, + ]; + } + + /** + * Invert the color + */ + public function invertColor(): self + { + $this->cmp_cyan = (1 - $this->cmp_cyan); + $this->cmp_magenta = (1 - $this->cmp_magenta); + $this->cmp_yellow = (1 - $this->cmp_yellow); + $this->cmp_key = (1 - $this->cmp_key); + return $this; + } +} diff --git a/vendor/tecnickcom/tc-lib-color/src/Model/Gray.php b/vendor/tecnickcom/tc-lib-color/src/Model/Gray.php new file mode 100644 index 0000000..ffc1ee2 --- /dev/null +++ b/vendor/tecnickcom/tc-lib-color/src/Model/Gray.php @@ -0,0 +1,196 @@ + + * @copyright 2015-2024 Nicola Asuni - Tecnick.com LTD + * @license http://www.gnu.org/copyleft/lesser.html GNU-LGPL v3 (see LICENSE.TXT) + * @link https://github.com/tecnickcom/tc-lib-color + * + * This file is part of tc-lib-color software library. + */ + +namespace Com\Tecnick\Color\Model; + +/** + * Com\Tecnick\Color\Model\Gray + * + * Gray Color Model class + * + * @since 2015-02-21 + * @category Library + * @package Color + * @author Nicola Asuni + * @copyright 2015-2024 Nicola Asuni - Tecnick.com LTD + * @license http://www.gnu.org/copyleft/lesser.html GNU-LGPL v3 (see LICENSE.TXT) + * @link https://github.com/tecnickcom/tc-lib-color + */ +class Gray extends \Com\Tecnick\Color\Model +{ + /** + * Color Model type + * + * @var string + */ + protected $type = 'GRAY'; + + /** + * Value of the Gray color component [0..1] + * + * @var float + */ + protected $cmp_gray = 0.0; + + /** + * Get an array with all color components + * + * @return array with keys ('G', 'A') + */ + public function getArray(): array + { + return [ + 'G' => $this->cmp_gray, + 'A' => $this->cmp_alpha, + ]; + } + + /** + * Get an array with color components values normalized between 0 and $max. + * NOTE: the alpha and other fraction component values are kept in the [0..1] range. + * + * @param int $max Maximum value to return (reference value) + * + * @return array with keys ('G', 'A') + */ + public function getNormalizedArray(int $max): array + { + return [ + 'G' => $this->getNormalizedValue($this->cmp_gray, $max), + 'A' => $this->cmp_alpha, + ]; + } + + /** + * Get the CSS representation of the color: rgba(R, G, B, A) + * NOTE: Supported since CSS3 and above. + * Use getHexadecimalColor() for CSS1 and CSS2 + */ + public function getCssColor(): string + { + return 'rgba(' + . $this->getNormalizedValue($this->cmp_gray, 100) . '%,' + . $this->getNormalizedValue($this->cmp_gray, 100) . '%,' + . $this->getNormalizedValue($this->cmp_gray, 100) . '%,' + . $this->cmp_alpha + . ')'; + } + + /** + * Get the color format used in Acrobat JavaScript + * NOTE: the alpha channel is omitted from this representation unless is 0 = transparent + */ + public function getJsPdfColor(): string + { + if ($this->cmp_alpha == 0) { + return '["T"]'; // transparent color + } + + return sprintf('["G",%F]', $this->cmp_gray); + } + + /** + * Get a space separated string with color component values. + */ + public function getComponentsString(): string + { + return sprintf('%F', $this->cmp_gray); + } + + /** + * Get the color components format used in PDF documents (G) + * NOTE: the alpha channel is omitted + * + * @param bool $stroke True for stroking (lines, drawing) and false for non-stroking (text and area filling). + */ + public function getPdfColor(bool $stroke = false): string + { + $mode = 'g'; + if ($stroke) { + $mode = strtoupper($mode); + } + + return $this->getComponentsString() . ' ' . $mode . "\n"; + } + + /** + * Get an array with Gray color components + * + * @return array with keys ('gray') + */ + public function toGrayArray(): array + { + return [ + 'gray' => $this->cmp_gray, + 'alpha' => $this->cmp_alpha, + ]; + } + + /** + * Get an array with RGB color components + * + * @return array with keys ('red', 'green', 'blue', 'alpha') + */ + public function toRgbArray(): array + { + return [ + 'red' => $this->cmp_gray, + 'green' => $this->cmp_gray, + 'blue' => $this->cmp_gray, + 'alpha' => $this->cmp_alpha, + ]; + } + + /** + * Get an array with HSL color components + * + * @return array with keys ('hue', 'saturation', 'lightness', 'alpha') + */ + public function toHslArray(): array + { + return [ + 'hue' => 0, + 'saturation' => 0, + 'lightness' => $this->cmp_gray, + 'alpha' => $this->cmp_alpha, + ]; + } + + /** + * Get an array with CMYK color components + * + * @return array with keys ('cyan', 'magenta', 'yellow', 'key', 'alpha') + */ + public function toCmykArray(): array + { + return [ + 'cyan' => 0, + 'magenta' => 0, + 'yellow' => 0, + 'key' => $this->cmp_gray, + 'alpha' => $this->cmp_alpha, + ]; + } + + /** + * Invert the color + */ + public function invertColor(): self + { + $this->cmp_gray = (1 - $this->cmp_gray); + return $this; + } +} diff --git a/vendor/tecnickcom/tc-lib-color/src/Model/Hsl.php b/vendor/tecnickcom/tc-lib-color/src/Model/Hsl.php new file mode 100644 index 0000000..dda2bcb --- /dev/null +++ b/vendor/tecnickcom/tc-lib-color/src/Model/Hsl.php @@ -0,0 +1,260 @@ + + * @copyright 2015-2024 Nicola Asuni - Tecnick.com LTD + * @license http://www.gnu.org/copyleft/lesser.html GNU-LGPL v3 (see LICENSE.TXT) + * @link https://github.com/tecnickcom/tc-lib-color + * + * This file is part of tc-lib-color software library. + */ + +namespace Com\Tecnick\Color\Model; + +/** + * Com\Tecnick\Color\Model\Hsl + * + * HSL Color Model class + * + * @since 2015-02-21 + * @category Library + * @package Color + * @author Nicola Asuni + * @copyright 2015-2024 Nicola Asuni - Tecnick.com LTD + * @license http://www.gnu.org/copyleft/lesser.html GNU-LGPL v3 (see LICENSE.TXT) + * @link https://github.com/tecnickcom/tc-lib-color + */ +class Hsl extends \Com\Tecnick\Color\Model +{ + /** + * Color Model type + * + * @var string + */ + protected $type = 'HSL'; + + /** + * Value of the Hue color component [0..1] + * + * @var float + */ + protected $cmp_hue = 0.0; + + /** + * Value of the Saturation color component [0..1] + * + * @var float + */ + protected $cmp_saturation = 0.0; + + /** + * Value of the Lightness color component [0..1] + * + * @var float + */ + protected $cmp_lightness = 0.0; + + /** + * Get an array with all color components + * + * @return array with keys ('H', 'S', 'L', 'A') + */ + public function getArray(): array + { + return [ + 'H' => $this->cmp_hue, + 'S' => $this->cmp_saturation, + 'L' => $this->cmp_lightness, + 'A' => $this->cmp_alpha, + ]; + } + + /** + * Get an array with color components values normalized between 0 and $max. + * NOTE: the alpha and other fraction component values are kept in the [0..1] range. + * + * @param int $max Maximum value to return (it is always set to 360) + * + * @return array with keys ('H', 'S', 'L', 'A') + */ + public function getNormalizedArray(int $max): array + { + $max = 360; + return [ + 'H' => $this->getNormalizedValue($this->cmp_hue, $max), + 'S' => $this->cmp_saturation, + 'L' => $this->cmp_lightness, + 'A' => $this->cmp_alpha, + ]; + } + + /** + * Get the CSS representation of the color: hsla(H, S, L, A) + * NOTE: Supported since CSS3 and above. + * Use getHexadecimalColor() for CSS1 and CSS2 + */ + public function getCssColor(): string + { + return 'hsla(' + . $this->getNormalizedValue($this->cmp_hue, 360) . ',' + . $this->getNormalizedValue($this->cmp_saturation, 100) . '%,' + . $this->getNormalizedValue($this->cmp_lightness, 100) . '%,' + . $this->cmp_alpha + . ')'; + } + + /** + * Get the color format used in Acrobat JavaScript + * NOTE: the alpha channel is omitted from this representation unless is 0 = transparent + */ + public function getJsPdfColor(): string + { + $rgb = $this->toRgbArray(); + if ($this->cmp_alpha == 0) { + return '["T"]'; // transparent color + } + + return sprintf('["RGB",%F,%F,%F]', $rgb['red'], $rgb['green'], $rgb['blue']); + } + + /** + * Get a space separated string with color component values. + */ + public function getComponentsString(): string + { + $rgb = $this->toRgbArray(); + return sprintf('%F %F %F', $rgb['red'], $rgb['green'], $rgb['blue']); + } + + /** + * Get the color components format used in PDF documents (RGB) + * NOTE: the alpha channel is omitted + * + * @param bool $stroke True for stroking (lines, drawing) and false for non-stroking (text and area filling). + */ + public function getPdfColor(bool $stroke = false): string + { + $mode = 'rg'; + if ($stroke) { + $mode = strtoupper($mode); + } + + return $this->getComponentsString() . ' ' . $mode . "\n"; + } + + /** + * Get an array with Gray color components + * + * @return array with keys ('gray') + */ + public function toGrayArray(): array + { + return [ + 'gray' => $this->cmp_lightness, + 'alpha' => $this->cmp_alpha, + ]; + } + + /** + * Get an array with RGB color components + * + * @return array with keys ('red', 'green', 'blue', 'alpha') + */ + public function toRgbArray(): array + { + if ($this->cmp_saturation == 0) { + return [ + 'red' => $this->cmp_lightness, + 'green' => $this->cmp_lightness, + 'blue' => $this->cmp_lightness, + 'alpha' => $this->cmp_alpha, + ]; + } + + if ($this->cmp_lightness < 0.5) { + $valb = ($this->cmp_lightness * (1 + $this->cmp_saturation)); + } else { + $valb = (($this->cmp_lightness + $this->cmp_saturation) - ($this->cmp_lightness * $this->cmp_saturation)); + } + + $vala = ((2 * $this->cmp_lightness) - $valb); + return [ + 'red' => $this->convertHuetoRgb($vala, $valb, ($this->cmp_hue + (1 / 3))), + 'green' => $this->convertHuetoRgb($vala, $valb, $this->cmp_hue), + 'blue' => $this->convertHuetoRgb($vala, $valb, ($this->cmp_hue - (1 / 3))), + 'alpha' => $this->cmp_alpha, + ]; + } + + /** + * Convet Hue to RGB + * + * @param float $vala Temporary value A + * @param float $valb Temporary value B + * @param float $hue Hue value + */ + private function convertHuetoRgb(float $vala, float $valb, float $hue): float + { + if ($hue < 0) { + ++$hue; + } + + if ($hue > 1) { + --$hue; + } + + if ((6 * $hue) < 1) { + return max(0, min(1, ($vala + (($valb - $vala) * 6 * $hue)))); + } + + if ((2 * $hue) < 1) { + return max(0, min(1, $valb)); + } + + if ((3 * $hue) < 2) { + return max(0, min(1, ($vala + (($valb - $vala) * ((2 / 3) - $hue) * 6)))); + } + + return max(0, min(1, $vala)); + } + + /** + * Get an array with HSL color components + * + * @return array with keys ('hue', 'saturation', 'lightness', 'alpha') + */ + public function toHslArray(): array + { + return [ + 'hue' => $this->cmp_hue, + 'saturation' => $this->cmp_saturation, + 'lightness' => $this->cmp_lightness, + 'alpha' => $this->cmp_alpha, + ]; + } + + /** + * Get an array with CMYK color components + * + * @return array with keys ('cyan', 'magenta', 'yellow', 'key', 'alpha') + */ + public function toCmykArray(): array + { + $rgb = new \Com\Tecnick\Color\Model\Rgb($this->toRgbArray()); + return $rgb->toCmykArray(); + } + + /** + * Invert the color + */ + public function invertColor(): self + { + $this->cmp_hue = ($this->cmp_hue >= 0.5) ? ($this->cmp_hue - 0.5) : ($this->cmp_hue + 0.5); + return $this; + } +} diff --git a/vendor/tecnickcom/tc-lib-color/src/Model/Rgb.php b/vendor/tecnickcom/tc-lib-color/src/Model/Rgb.php new file mode 100644 index 0000000..eb35196 --- /dev/null +++ b/vendor/tecnickcom/tc-lib-color/src/Model/Rgb.php @@ -0,0 +1,275 @@ + + * @copyright 2015-2024 Nicola Asuni - Tecnick.com LTD + * @license http://www.gnu.org/copyleft/lesser.html GNU-LGPL v3 (see LICENSE.TXT) + * @link https://github.com/tecnickcom/tc-lib-color + * + * This file is part of tc-lib-color software library. + */ + +namespace Com\Tecnick\Color\Model; + +/** + * Com\Tecnick\Color\Model\Rgb + * + * RGB Color Model class + * + * @since 2015-02-21 + * @category Library + * @package Color + * @author Nicola Asuni + * @copyright 2015-2024 Nicola Asuni - Tecnick.com LTD + * @license http://www.gnu.org/copyleft/lesser.html GNU-LGPL v3 (see LICENSE.TXT) + * @link https://github.com/tecnickcom/tc-lib-color + */ +class Rgb extends \Com\Tecnick\Color\Model +{ + /** + * Color Model type + * + * @var string + */ + protected $type = 'RGB'; + + /** + * Value of the Red color component [0..1] + * + * @var float + */ + protected $cmp_red = 0.0; + + /** + * Value of the Green color component [0..1] + * + * @var float + */ + protected $cmp_green = 0.0; + + /** + * Value of the Blue color component [0..1] + * + * @var float + */ + protected $cmp_blue = 0.0; + + /** + * Get an array with all color components + * + * @return array with keys ('R', 'G', 'B', 'A') + */ + public function getArray(): array + { + return [ + 'R' => $this->cmp_red, + 'G' => $this->cmp_green, + 'B' => $this->cmp_blue, + 'A' => $this->cmp_alpha, + ]; + } + + /** + * Get an array with color components values normalized between 0 and $max. + * NOTE: the alpha and other fraction component values are kept in the [0..1] range. + * + * @param int $max Maximum value to return (reference value) + * + * @return array with keys ('R', 'G', 'B', 'A') + */ + public function getNormalizedArray(int $max): array + { + return [ + 'R' => $this->getNormalizedValue($this->cmp_red, $max), + 'G' => $this->getNormalizedValue($this->cmp_green, $max), + 'B' => $this->getNormalizedValue($this->cmp_blue, $max), + 'A' => $this->cmp_alpha, + ]; + } + + /** + * Get the CSS representation of the color: rgba(R, G, B, A) + * NOTE: Supported since CSS3 and above. + * Use getHexadecimalColor() for CSS1 and CSS2 + */ + public function getCssColor(): string + { + return 'rgba(' + . $this->getNormalizedValue($this->cmp_red, 100) . '%,' + . $this->getNormalizedValue($this->cmp_green, 100) . '%,' + . $this->getNormalizedValue($this->cmp_blue, 100) . '%,' + . $this->cmp_alpha + . ')'; + } + + /** + * Get the color format used in Acrobat JavaScript + * NOTE: the alpha channel is omitted from this representation unless is 0 = transparent + */ + public function getJsPdfColor(): string + { + if ($this->cmp_alpha == 0) { + return '["T"]'; // transparent color + } + + return sprintf('["RGB",%F,%F,%F]', $this->cmp_red, $this->cmp_green, $this->cmp_blue); + } + + /** + * Get a space separated string with color component values. + */ + public function getComponentsString(): string + { + return sprintf('%F %F %F', $this->cmp_red, $this->cmp_green, $this->cmp_blue); + } + + /** + * Get the color components format used in PDF documents (RGB) + * NOTE: the alpha channel is omitted + * + * @param bool $stroke True for stroking (lines, drawing) and false for non-stroking (text and area filling). + */ + public function getPdfColor(bool $stroke = false): string + { + $mode = 'rg'; + if ($stroke) { + $mode = strtoupper($mode); + } + + return $this->getComponentsString() . ' ' . $mode . "\n"; + } + + /** + * Get an array with Gray color components + * + * @return array with keys ('gray') + */ + public function toGrayArray(): array + { + // convert using the SMPTE 295M-1997 standard conversion constants + return [ + 'gray' => (max( + 0, + min( + 1, + ((0.2126 * $this->cmp_red) + (0.7152 * $this->cmp_green) + (0.0722 * $this->cmp_blue)) + ) + )), + 'alpha' => $this->cmp_alpha, + ]; + } + + /** + * Get an array with RGB color components + * + * @return array with keys ('red', 'green', 'blue', 'alpha') + */ + public function toRgbArray(): array + { + return [ + 'red' => $this->cmp_red, + 'green' => $this->cmp_green, + 'blue' => $this->cmp_blue, + 'alpha' => $this->cmp_alpha, + ]; + } + + /** + * Get an array with HSL color components + * + * @return array with keys ('hue', 'saturation', 'lightness', 'alpha') + */ + public function toHslArray(): array + { + $min = min($this->cmp_red, $this->cmp_green, $this->cmp_blue); + $max = max($this->cmp_red, $this->cmp_green, $this->cmp_blue); + $lightness = (($min + $max) / 2); + $saturation = 0; + $hue = 0; + if ($min != $max) { + $diff = ($max - $min); + $saturation = $lightness < 0.5 ? $diff / ($max + $min) : $diff / (2.0 - $max - $min); + + switch ($max) { + case $this->cmp_red: + $dgb = ($this->cmp_green - $this->cmp_blue); + $hue = ($dgb / $diff) + (($dgb < 0) ? 6 : 0); + break; + case $this->cmp_green: + $hue = (2.0 + (($this->cmp_blue - $this->cmp_red) / $diff)); + break; + case $this->cmp_blue: + $hue = (4.0 + (($this->cmp_red - $this->cmp_green) / $diff)); + break; + } + + $hue /= 6; // 6 = 360 / 60 + } + + return [ + 'hue' => max(0, min(1, $hue)), + 'saturation' => max(0, min(1, $saturation)), + 'lightness' => max(0, min(1, $lightness)), + 'alpha' => $this->cmp_alpha, + ]; + } + + /** + * Get an array with CMYK color components + * + * @return array with keys ('cyan', 'magenta', 'yellow', 'key', 'alpha') + */ + public function toCmykArray(): array + { + $cyan = (1 - $this->cmp_red); + $magenta = (1 - $this->cmp_green); + $yellow = (1 - $this->cmp_blue); + $key = 1; + if ($cyan < $key) { + $key = $cyan; + } + + if ($magenta < $key) { + $key = $magenta; + } + + if ($yellow < $key) { + $key = $yellow; + } + + if ($key == 1) { + // black + $cyan = 0; + $magenta = 0; + $yellow = 0; + } else { + $cyan = (($cyan - $key) / (1 - $key)); + $magenta = (($magenta - $key) / (1 - $key)); + $yellow = (($yellow - $key) / (1 - $key)); + } + + return [ + 'cyan' => max(0, min(1, $cyan)), + 'magenta' => max(0, min(1, $magenta)), + 'yellow' => max(0, min(1, $yellow)), + 'key' => max(0, min(1, $key)), + 'alpha' => $this->cmp_alpha, + ]; + } + + /** + * Invert the color + */ + public function invertColor(): self + { + $this->cmp_red = (1 - $this->cmp_red); + $this->cmp_green = (1 - $this->cmp_green); + $this->cmp_blue = (1 - $this->cmp_blue); + return $this; + } +} diff --git a/vendor/tecnickcom/tc-lib-color/src/Model/Template.php b/vendor/tecnickcom/tc-lib-color/src/Model/Template.php new file mode 100644 index 0000000..7ef92f3 --- /dev/null +++ b/vendor/tecnickcom/tc-lib-color/src/Model/Template.php @@ -0,0 +1,107 @@ + + * @copyright 2015-2024 Nicola Asuni - Tecnick.com LTD + * @license http://www.gnu.org/copyleft/lesser.html GNU-LGPL v3 (see LICENSE.TXT) + * @link https://github.com/tecnickcom/tc-lib-color + * + * This file is part of tc-lib-color software library. + */ + +namespace Com\Tecnick\Color\Model; + +/** + * Com\Tecnick\Color\Model\Template + * + * Color Model Interface + * + * @since 2015-02-21 + * @category Library + * @package Color + * @author Nicola Asuni + * @copyright 2015-2024 Nicola Asuni - Tecnick.com LTD + * @license http://www.gnu.org/copyleft/lesser.html GNU-LGPL v3 (see LICENSE.TXT) + * @link https://github.com/tecnickcom/tc-lib-color + */ +interface Template +{ + /** + * Get an array with all color components + * + * @return array + */ + public function getArray(); + + /** + * Get an array with color components values normalized between 0 and $max. + * NOTE: the alpha and other fraction component values are kept in the [0..1] range. + * + * @param int $max Maximum value to return (reference value) + * + * @return array + */ + public function getNormalizedArray(int $max): array; + + /** + * Get the CSS representation of the color + */ + public function getCssColor(): string; + + /** + * Get the color format used in Acrobat JavaScript + * NOTE: the alpha channel is omitted from this representation unless is 0 = transparent + */ + public function getJsPdfColor(): string; + + /** + * Get a space separated string with color component values. + */ + public function getComponentsString(): string; + + /** + * Get the color components format used in PDF documents (RGB) + * NOTE: the alpha channel is omitted + * + * @param bool $stroke True for stroking (lines, drawing) and false for non-stroking (text and area filling). + */ + public function getPdfColor(bool $stroke = false): string; + + /** + * Get an array with Gray color components + * + * @return array with keys ('gray') + */ + public function toGrayArray(): array; + + /** + * Get an array with RGB color components + * + * @return array with keys ('red', 'green', 'blue', 'alpha') + */ + public function toRgbArray(): array; + + /** + * Get an array with HSL color components + * + * @return array with keys ('hue', 'saturation', 'lightness', 'alpha') + */ + public function toHslArray(): array; + + /** + * Get an array with CMYK color components + * + * @return array with keys ('cyan', 'magenta', 'yellow', 'key', 'alpha') + */ + public function toCmykArray(): array; + + /** + * Invert the color + */ + public function invertColor(): self; +} diff --git a/vendor/tecnickcom/tc-lib-color/src/Pdf.php b/vendor/tecnickcom/tc-lib-color/src/Pdf.php new file mode 100644 index 0000000..6a9305c --- /dev/null +++ b/vendor/tecnickcom/tc-lib-color/src/Pdf.php @@ -0,0 +1,148 @@ + + * @copyright 2015-2024 Nicola Asuni - Tecnick.com LTD + * @license http://www.gnu.org/copyleft/lesser.html GNU-LGPL v3 (see LICENSE.TXT) + * @link https://github.com/tecnickcom/tc-lib-color + * + * This file is part of tc-lib-color software library. + */ + +namespace Com\Tecnick\Color; + +use Com\Tecnick\Color\Exception as ColorException; + +/** + * Com\Tecnick\Color\Pdf + * + * PDF Color class + * + * @since 2015-02-21 + * @category Library + * @package Color + * @author Nicola Asuni + * @copyright 2015-2024 Nicola Asuni - Tecnick.com LTD + * @license http://www.gnu.org/copyleft/lesser.html GNU-LGPL v3 (see LICENSE.TXT) + * @link https://github.com/tecnickcom/tc-lib-color + */ +class Pdf extends \Com\Tecnick\Color\Spot +{ + /** + * Array of valid JavaScript color names to be used in PDF documents + */ + public const JSCOLOR = [ + 'transparent', + 'black', + 'white', + 'red', + 'green', + 'blue', + 'cyan', + 'magenta', + 'yellow', + 'dkGray', + 'gray', + 'ltGray', + ]; + + /** + * Convert color to javascript string + * + * @param string $color color name or color object + */ + public function getJsColorString(string $color): string + { + if (in_array($color, self::JSCOLOR)) { + return 'color.' . $color; + } + + try { + if (($colobj = $this->getColorObj($color)) instanceof \Com\Tecnick\Color\Model) { + return $colobj->getJsPdfColor(); + } + } catch (ColorException $colorException) { + // assert(true); // noop + } + + // default transparent color + return 'color.' . self::JSCOLOR[0]; + } + + /** + * Returns a color object from an HTML, CSS or Spot color representation. + * + * @param string $color HTML, CSS or Spot color to parse + */ + public function getColorObject(string $color): ?\Com\Tecnick\Color\Model + { + try { + return $this->getSpotColorObj($color); + } catch (ColorException $colorException) { + // assert(true); // noop + } + + try { + return $this->getColorObj($color); + } catch (ColorException $colorException) { + // assert(true); // noop + } + + return null; + } + + /** + * Get the color components format used in PDF documents + * NOTE: the alpha channel is omitted + * + * @param string $color HTML, CSS or Spot color to parse + * @param bool $stroke True for stroking (lines, drawing) and false for non-stroking (text and area filling). + * @param float $tint Intensity of the color (from 0 to 1; 1 = full intensity). + */ + public function getPdfColor(string $color, bool $stroke = false, float $tint = 1): string + { + try { + $col = $this->getSpotColor($color); + $tint = sprintf('cs %F scn', (max(0, min(1, $tint)))); + if ($stroke) { + $tint = strtoupper($tint); + } + + return sprintf('/CS%d %s' . "\n", $col['i'], $tint); + } catch (ColorException $colorException) { + // assert(true); // noop + } + + try { + $col = $this->getColorObj($color); + if ($col instanceof \Com\Tecnick\Color\Model) { + return $col->getPdfColor($stroke); + } + } catch (ColorException $colorException) { + // assert(true); // noop + } + + return ''; + } + + /** + * Get the RGB color components format used in PDF documents + * + * @param string $color HTML, CSS or Spot color to parse + */ + public function getPdfRgbComponents(string $color): string + { + $model = $this->getColorObject($color); + if (! $model instanceof \Com\Tecnick\Color\Model) { + return ''; + } + + $cmp = $model->toRgbArray(); + return sprintf('%F %F %F', $cmp['red'], $cmp['green'], $cmp['blue']); + } +} diff --git a/vendor/tecnickcom/tc-lib-color/src/Spot.php b/vendor/tecnickcom/tc-lib-color/src/Spot.php new file mode 100644 index 0000000..c65bd46 --- /dev/null +++ b/vendor/tecnickcom/tc-lib-color/src/Spot.php @@ -0,0 +1,343 @@ + + * @copyright 2015-2024 Nicola Asuni - Tecnick.com LTD + * @license http://www.gnu.org/copyleft/lesser.html GNU-LGPL v3 (see LICENSE.TXT) + * @link https://github.com/tecnickcom/tc-lib-color + * + * This file is part of tc-lib-color software library. + */ + +namespace Com\Tecnick\Color; + +use Com\Tecnick\Color\Exception as ColorException; +use Com\Tecnick\Color\Model\Cmyk; + +/** + * Com\Tecnick\Color\Spot + * + * Spot Color class + * + * @since 2015-02-21 + * @category Library + * @package Color + * @author Nicola Asuni + * @copyright 2015-2024 Nicola Asuni - Tecnick.com LTD + * @license http://www.gnu.org/copyleft/lesser.html GNU-LGPL v3 (see LICENSE.TXT) + * @link https://github.com/tecnickcom/tc-lib-color + * + * @phpstan-type TSpotColor array{ + * 'i': int, + * 'n': int, + * 'name': string, + * 'color': Cmyk, + * } + */ +class Spot extends \Com\Tecnick\Color\Web +{ + /** + * Array of default Spot colors + * Color keys must be in lowercase and without spaces. + * + * @var array + */ + public const DEFAULT_SPOT_COLORS = [ + 'none' => [ + 'name' => 'None', + 'color' => [ + 'cyan' => 0, + 'magenta' => 0, + 'yellow' => 0, + 'key' => 0, + 'alpha' => 1, + ], + ], + 'all' => [ + 'name' => 'All', + 'color' => [ + 'cyan' => 1, + 'magenta' => 1, + 'yellow' => 1, + 'key' => 1, + 'alpha' => 1, + ], + ], + 'cyan' => [ + 'name' => 'Cyan', + 'color' => [ + 'cyan' => 1, + 'magenta' => 0, + 'yellow' => 0, + 'key' => 0, + 'alpha' => 1, + ], + ], + 'magenta' => [ + 'name' => 'Magenta', + 'color' => [ + 'cyan' => 0, + 'magenta' => 1, + 'yellow' => 0, + 'key' => 0, + 'alpha' => 1, + ], + ], + 'yellow' => [ + 'name' => 'Yellow', + 'color' => [ + 'cyan' => 0, + 'magenta' => 0, + 'yellow' => 1, + 'key' => 0, + 'alpha' => 1, + ], + ], + 'key' => [ + 'name' => 'Key', + 'color' => [ + 'cyan' => 0, + 'magenta' => 0, + 'yellow' => 0, + 'key' => 1, + 'alpha' => 1, + ], + ], + 'white' => [ + 'name' => 'White', + 'color' => [ + 'cyan' => 0, + 'magenta' => 0, + 'yellow' => 0, + 'key' => 0, + 'alpha' => 1, + ], + ], + 'black' => [ + 'name' => 'Black', + 'color' => [ + 'cyan' => 0, + 'magenta' => 0, + 'yellow' => 0, + 'key' => 1, + 'alpha' => 1, + ], + ], + 'red' => [ + 'name' => 'Red', + 'color' => [ + 'cyan' => 0, + 'magenta' => 1, + 'yellow' => 1, + 'key' => 0, + 'alpha' => 1, + ], + ], + 'green' => [ + 'name' => 'Green', + 'color' => [ + 'cyan' => 1, + 'magenta' => 0, + 'yellow' => 1, + 'key' => 0, + 'alpha' => 1, + ], + ], + 'blue' => [ + 'name' => 'Blue', + 'color' => [ + 'cyan' => 1, + 'magenta' => 1, + 'yellow' => 0, + 'key' => 0, + 'alpha' => 1, + ], + ], + ]; + + /** + * Array of Spot colors + * + * @var array + */ + protected $spot_colors = []; + + /** + * Returns the array of spot colors. + * + * @return array + */ + public function getSpotColors(): array + { + return $this->spot_colors; + } + + /** + * Return the normalized version of the spot color name + * + * @param string $name Full name of the spot color. + */ + public function normalizeSpotColorName(string $name): string + { + $ret = preg_replace('/[^a-z0-9]*+/', '', strtolower($name)); + return $ret ?? ''; + } + + /** + * Return the requested spot color data array + * + * @param string $name Full name of the spot color. + * + * @return TSpotColor + * + * @throws ColorException if the color is not found + */ + public function getSpotColor(string $name): array + { + $key = $this->normalizeSpotColorName($name); + if (empty($this->spot_colors[$key])) { + // search on default spot colors + if (empty(self::DEFAULT_SPOT_COLORS[$key])) { + throw new ColorException('unable to find the spot color: ' . $key); + } + + $this->addSpotColor($key, new Cmyk(self::DEFAULT_SPOT_COLORS[$key]['color'])); + } + + return $this->spot_colors[$key]; + } + + /** + * Return the requested spot color CMYK object + * + * @param string $name Full name of the spot color. + * + * @throws ColorException if the color is not found + */ + public function getSpotColorObj(string $name): Cmyk + { + $spot = $this->getSpotColor($name); + return $spot['color']; + } + + /** + * Add a new spot color or overwrite an existing one with the same name. + * + * @param string $name Full name of the spot color. + * @param Cmyk $cmyk CMYK color object + * + * @return string Spot color key. + */ + public function addSpotColor(string $name, Cmyk $cmyk): string + { + $key = $this->normalizeSpotColorName($name); + $num = isset($this->spot_colors[$key]) ? $this->spot_colors[$key]['i'] : (count($this->spot_colors) + 1); + + $this->spot_colors[$key] = [ + 'i' => $num, // color index + 'n' => 0, // PDF object number + 'name' => $name, // color name (key) + 'color' => $cmyk, // CMYK color object + ]; + + return $key; + } + + /** + * Returns the PDF command to output Spot color objects. + * + * @param int $pon Current PDF object number + * + * @return string PDF command + */ + public function getPdfSpotObjects(int &$pon): string + { + $out = ''; + foreach ($this->spot_colors as $name => $color) { + $out .= (++$pon) . ' 0 obj' . "\n"; + $this->spot_colors[$name]['n'] = $pon; + $out .= '[/Separation /' . str_replace(' ', '#20', $name) + . ' /DeviceCMYK <<' + . '/Range [0 1 0 1 0 1 0 1]' + . ' /C0 [0 0 0 0]' + . ' /C1 [' . $color['color']->getComponentsString() . ']' + . ' /FunctionType 2' + . ' /Domain [0 1]' + . ' /N 1' + . '>>]' . "\n" + . 'endobj' . "\n"; + } + + return $out; + } + + /** + * Returns the PDF command to output the provided Spot color resources. + * + * @param array $data Spot color array. + * + * @return string PDF command + */ + private function getOutPdfSpotResources(array $data): string + { + if (empty($data)) { + return ''; + } + + $out = '/ColorSpace <<'; + + foreach ($data as $spot_color) { + $out .= ' /CS' . $spot_color['i'] . ' ' . $spot_color['n'] . ' 0 R'; + } + + return $out . ' >>' . "\n"; + } + + /** + * Returns the PDF command to output Spot color resources. + * + * @return string PDF command + */ + public function getPdfSpotResources(): string + { + return $this->getOutPdfSpotResources($this->spot_colors); + } + + /** + * Returns the PDF command to output Spot color resources. + * + * @param array $keys Array of font keys. + * + * @return string PDF command + */ + public function getPdfSpotResourcesByKeys(array $keys): string + { + if (empty($keys)) { + return ''; + } + + $data = []; + foreach ($keys as $key) { + $data[$key] = [ + 'i' => $this->spot_colors[$key]['i'], + 'n' => $this->spot_colors[$key]['n'], + ]; + } + + return $this->getOutPdfSpotResources($data); + } +} diff --git a/vendor/tecnickcom/tc-lib-color/src/Web.php b/vendor/tecnickcom/tc-lib-color/src/Web.php new file mode 100644 index 0000000..b2f37a5 --- /dev/null +++ b/vendor/tecnickcom/tc-lib-color/src/Web.php @@ -0,0 +1,392 @@ + + * @copyright 2015-2024 Nicola Asuni - Tecnick.com LTD + * @license http://www.gnu.org/copyleft/lesser.html GNU-LGPL v3 (see LICENSE.TXT) + * @link https://github.com/tecnickcom/tc-lib-color + * + * This file is part of tc-lib-color software library. + */ + +namespace Com\Tecnick\Color; + +use Com\Tecnick\Color\Exception as ColorException; + +/** + * Com\Tecnick\Color\Web + * + * Web Color class + * + * @since 2015-02-21 + * @category Library + * @package Color + * @author Nicola Asuni + * @copyright 2015-2024 Nicola Asuni - Tecnick.com LTD + * @license http://www.gnu.org/copyleft/lesser.html GNU-LGPL v3 (see LICENSE.TXT) + * @link https://github.com/tecnickcom/tc-lib-color + */ +class Web extends \Com\Tecnick\Color\Css +{ + /** + * Maps WEB safe color names with theur hexadecimal representation (#RRGGBBAA). + */ + public const WEBHEX = [ + 'aliceblue' => 'f0f8ffff', + 'antiquewhite' => 'faebd7ff', + 'aqua' => '00ffffff', + 'aquamarine' => '7fffd4ff', + 'azure' => 'f0ffffff', + 'beige' => 'f5f5dcff', + 'bisque' => 'ffe4c4ff', + 'black' => '000000ff', + 'blanchedalmond' => 'ffebcdff', + 'blue' => '0000ffff', + 'blueviolet' => '8a2be2ff', + 'brown' => 'a52a2aff', + 'burlywood' => 'deb887ff', + 'cadetblue' => '5f9ea0ff', + 'chartreuse' => '7fff00ff', + 'chocolate' => 'd2691eff', + 'coral' => 'ff7f50ff', + 'cornflowerblue' => '6495edff', + 'cornsilk' => 'fff8dcff', + 'crimson' => 'dc143cff', + 'cyan' => '00ffffff', + 'darkblue' => '00008bff', + 'darkcyan' => '008b8bff', + 'darkgoldenrod' => 'b8860bff', + 'dkgray' => 'a9a9a9ff', + 'darkgray' => 'a9a9a9ff', + 'darkgrey' => 'a9a9a9ff', + 'darkgreen' => '006400ff', + 'darkkhaki' => 'bdb76bff', + 'darkmagenta' => '8b008bff', + 'darkolivegreen' => '556b2fff', + 'darkorange' => 'ff8c00ff', + 'darkorchid' => '9932ccff', + 'darkred' => '8b0000ff', + 'darksalmon' => 'e9967aff', + 'darkseagreen' => '8fbc8fff', + 'darkslateblue' => '483d8bff', + 'darkslategray' => '2f4f4fff', + 'darkslategrey' => '2f4f4fff', + 'darkturquoise' => '00ced1ff', + 'darkviolet' => '9400d3ff', + 'deeppink' => 'ff1493ff', + 'deepskyblue' => '00bfffff', + 'dimgray' => '696969ff', + 'dimgrey' => '696969ff', + 'dodgerblue' => '1e90ffff', + 'firebrick' => 'b22222ff', + 'floralwhite' => 'fffaf0ff', + 'forestgreen' => '228b22ff', + 'fuchsia' => 'ff00ffff', + 'gainsboro' => 'dcdcdcff', + 'ghostwhite' => 'f8f8ffff', + 'gold' => 'ffd700ff', + 'goldenrod' => 'daa520ff', + 'gray' => '808080ff', + 'grey' => '808080ff', + 'green' => '008000ff', + 'greenyellow' => 'adff2fff', + 'honeydew' => 'f0fff0ff', + 'hotpink' => 'ff69b4ff', + 'indianred' => 'cd5c5cff', + 'indigo' => '4b0082ff', + 'ivory' => 'fffff0ff', + 'khaki' => 'f0e68cff', + 'lavender' => 'e6e6faff', + 'lavenderblush' => 'fff0f5ff', + 'lawngreen' => '7cfc00ff', + 'lemonchiffon' => 'fffacdff', + 'lightblue' => 'add8e6ff', + 'lightcoral' => 'f08080ff', + 'lightcyan' => 'e0ffffff', + 'lightgoldenrodyellow' => 'fafad2ff', + 'ltgray' => 'd3d3d3ff', + 'lightgray' => 'd3d3d3ff', + 'lightgrey' => 'd3d3d3ff', + 'lightgreen' => '90ee90ff', + 'lightpink' => 'ffb6c1ff', + 'lightsalmon' => 'ffa07aff', + 'lightseagreen' => '20b2aaff', + 'lightskyblue' => '87cefaff', + 'lightslategray' => '778899ff', + 'lightslategrey' => '778899ff', + 'lightsteelblue' => 'b0c4deff', + 'lightyellow' => 'ffffe0ff', + 'lime' => '00ff00ff', + 'limegreen' => '32cd32ff', + 'linen' => 'faf0e6ff', + 'magenta' => 'ff00ffff', + 'maroon' => '800000ff', + 'mediumaquamarine' => '66cdaaff', + 'mediumblue' => '0000cdff', + 'mediumorchid' => 'ba55d3ff', + 'mediumpurple' => '9370d8ff', + 'mediumseagreen' => '3cb371ff', + 'mediumslateblue' => '7b68eeff', + 'mediumspringgreen' => '00fa9aff', + 'mediumturquoise' => '48d1ccff', + 'mediumvioletred' => 'c71585ff', + 'midnightblue' => '191970ff', + 'mintcream' => 'f5fffaff', + 'mistyrose' => 'ffe4e1ff', + 'moccasin' => 'ffe4b5ff', + 'navajowhite' => 'ffdeadff', + 'navy' => '000080ff', + 'oldlace' => 'fdf5e6ff', + 'olive' => '808000ff', + 'olivedrab' => '6b8e23ff', + 'orange' => 'ffa500ff', + 'orangered' => 'ff4500ff', + 'orchid' => 'da70d6ff', + 'palegoldenrod' => 'eee8aaff', + 'palegreen' => '98fb98ff', + 'paleturquoise' => 'afeeeeff', + 'palevioletred' => 'd87093ff', + 'papayawhip' => 'ffefd5ff', + 'peachpuff' => 'ffdab9ff', + 'peru' => 'cd853fff', + 'pink' => 'ffc0cbff', + 'plum' => 'dda0ddff', + 'powderblue' => 'b0e0e6ff', + 'purple' => '800080ff', + 'red' => 'ff0000ff', + 'rosybrown' => 'bc8f8fff', + 'royalblue' => '4169e1ff', + 'saddlebrown' => '8b4513ff', + 'salmon' => 'fa8072ff', + 'sandybrown' => 'f4a460ff', + 'seagreen' => '2e8b57ff', + 'seashell' => 'fff5eeff', + 'sienna' => 'a0522dff', + 'silver' => 'c0c0c0ff', + 'skyblue' => '87ceebff', + 'slateblue' => '6a5acdff', + 'slategray' => '708090ff', + 'slategrey' => '708090ff', + 'snow' => 'fffafaff', + 'springgreen' => '00ff7fff', + 'steelblue' => '4682b4ff', + 'tan' => 'd2b48cff', + 'teal' => '008080ff', + 'thistle' => 'd8bfd8ff', + 'tomato' => 'ff6347ff', + 'turquoise' => '40e0d0ff', + 'violet' => 'ee82eeff', + 'wheat' => 'f5deb3ff', + 'white' => 'ffffffff', + 'whitesmoke' => 'f5f5f5ff', + 'yellow' => 'ffff00ff', + 'yellowgreen' => '9acd32ff', + ]; + + /** + * Get the color hexadecimal hash code from name + * + * @param string $name Name of the color to search (e.g.: 'turquoise') + * + * @return string color hexadecimal code (e.g.: '40e0d0ff') + * + * @throws ColorException if the color is not found + */ + public function getHexFromName(string $name): string + { + $name = strtolower($name); + if (($dotpos = strpos($name, '.')) !== false) { + // remove parent name (i.e.: color.green) + $name = substr($name, ($dotpos + 1)); + } + + if (empty(self::WEBHEX[$name])) { + throw new ColorException('unable to find the color hex for the name: ' . $name); + } + + return self::WEBHEX[$name]; + } + + /** + * Get the color name code from hexadecimal hash + * + * @param string $hex hexadecimal color hash (i.e. #RRGGBBAA) + * + * @return string color name + * + * @throws ColorException if the color is not found + */ + public function getNameFromHex(string $hex): string + { + $name = array_search($this->extractHexCode($hex), self::WEBHEX, true); + if ($name === false) { + throw new ColorException('unable to find the color name for the hex code: ' . $hex); + } + + return $name; + } + + /** + * Extract the hexadecimal code from the input string and add the alpha channel if missing + * + * @param string $hex string containing the hexadecimal color hash (i.e. #RGB, #RGBA, #RRGGBB, #RRGGBBAA) + * + * @return string the hash code (e.g.: '40e0d0') + * + * @throws ColorException if the hash is not found or has an invalid format + */ + public function extractHexCode(string $hex): string + { + if (preg_match('/^[#]?([0-9a-f]{3,8})$/', strtolower($hex), $match) !== 1) { + throw new ColorException('unable to extract the color hash: ' . $hex); + } + + $hex = $match[1]; + switch (strlen($hex)) { + case 3: + return $hex[0] . $hex[0] . $hex[1] . $hex[1] . $hex[2] . $hex[2] . 'ff'; + case 4: + return $hex[0] . $hex[0] . $hex[1] . $hex[1] . $hex[2] . $hex[2] . $hex[3] . $hex[3]; + case 6: + return $hex . 'ff'; + } + + return $hex; + } + + /** + * Get the RGB color object from hexadecimal hash + * + * @param string $hex hexadecimal color hash (i.e. #RGB, #RGBA, #RRGGBB, #RRGGBBAA) + * + * @throws ColorException if the color is not found + */ + public function getRgbObjFromHex(string $hex): \Com\Tecnick\Color\Model\Rgb + { + return new \Com\Tecnick\Color\Model\Rgb( + $this->getHexArray( + $this->extractHexCode($hex) + ) + ); + } + + /** + * Get the RGB color object from color name + * + * @param string $name Color name + * + * @return \Com\Tecnick\Color\Model\Rgb object + * + * @throws ColorException if the color is not found + */ + public function getRgbObjFromName(string $name): \Com\Tecnick\Color\Model\Rgb + { + return new \Com\Tecnick\Color\Model\Rgb( + $this->getHexArray( + $this->getHexFromName($name) + ) + ); + } + + /** + * Get the RGB array from hexadecimal hash + * + * @param string $hex hexadecimal color hash (i.e. RRGGBBAA) + * + * @return array with keys ('red', 'green', 'blue', 'alpha') + */ + private function getHexArray(string $hex): array + { + return [ + 'red' => (hexdec(substr($hex, 0, 2)) / 255), + 'green' => (hexdec(substr($hex, 2, 2)) / 255), + 'blue' => (hexdec(substr($hex, 4, 2)) / 255), + 'alpha' => (hexdec(substr($hex, 6, 2)) / 255), + ]; + } + + /** + * Get the normalized integer value from [0..$max] to [0..1] + * + * @param int|float|string $value Value to convert + * @param int $max Max input value + * + * @return float value [0..1] + */ + public function normalizeValue(mixed $value, int $max): float + { + if (is_string($value) && (strpos($value, '%') !== false)) { + return max(0, min(1, ((float) $value / 100))); + } + + return max(0, min(1, ((float) $value / $max))); + } + + /** + * Parse the input color string and return the correspondent color Object + * + * @param string $color String containing web color definition + * + * @throws ColorException in case of error + */ + public function getColorObj(string $color): ?\Com\Tecnick\Color\Model + { + $color = preg_replace('/[\s]*+/', '', strtolower($color)); + if (empty($color) || (strpos($color, 'transparent') !== false)) { + return null; + } + + if ($color[0] === '#') { + return $this->getRgbObjFromHex($color); + } + + if ($color[0] === '[') { + return $this->getColorObjFromJs($color); + } + + $rex = '/^(t|g|rgba|rgb|hsla|hsl|cmyka|cmyk)[\(]/'; + if (preg_match($rex, $color, $col) === 1) { + return $this->getColorObjFromCss($col[1], $color); + } + + return $this->getRgbObjFromName($color); + } + + /** + * Get the square of the distance between 2 RGB points + * + * @param array $cola First color as RGB array + * @param array $colb Second color as RGB array + */ + public function getRgbSquareDistance(array $cola, array $colb): float + { + return ($cola['red'] - $colb['red']) ** 2 + + ($cola['green'] - $colb['green']) ** 2 + + ($cola['blue'] - $colb['blue']) ** 2; + } + + /** + * Get the name of the closest web color + * + * @param array $col Color as RGB array (keys: 'red', 'green', 'blue') + */ + public function getClosestWebColor(array $col): string + { + $color = ''; + $mindist = 3; // = 1^2 + 1^2 + 1^2 + foreach (self::WEBHEX as $name => $hex) { + $dist = $this->getRgbSquareDistance($col, $this->getHexArray($hex)); + if ($dist <= $mindist) { + $mindist = $dist; + $color = $name; + } + } + + return $color; + } +} diff --git a/vendor/tecnickcom/tc-lib-color/test/Model/CmykTest.php b/vendor/tecnickcom/tc-lib-color/test/Model/CmykTest.php new file mode 100644 index 0000000..b7e61b2 --- /dev/null +++ b/vendor/tecnickcom/tc-lib-color/test/Model/CmykTest.php @@ -0,0 +1,236 @@ + + * @copyright 2015-2024 Nicola Asuni - Tecnick.com LTD + * @license http://www.gnu.org/copyleft/lesser.html GNU-LGPL v3 (see LICENSE.TXT) + * @link https://github.com/tecnickcom/tc-lib-color + * + * This file is part of tc-lib-color software library. + */ + +namespace Test\Model; + +use Test\TestUtil; + +/** + * Cmyk Color class test + * + * @since 2015-02-21 + * @category Library + * @package Color + * @author Nicola Asuni + * @copyright 2015-2024 Nicola Asuni - Tecnick.com LTD + * @license http://www.gnu.org/copyleft/lesser.html GNU-LGPL v3 (see LICENSE.TXT) + * @link https://github.com/tecnickcom/tc-lib-color + */ +class CmykTest extends TestUtil +{ + protected function getTestObject(): \Com\Tecnick\Color\Model\Cmyk + { + return new \Com\Tecnick\Color\Model\Cmyk( + [ + 'cyan' => 0.666, + 'magenta' => 0.333, + 'yellow' => 0, + 'key' => 0.25, + 'alpha' => 0.85, + ] + ); + } + + public function testGetType(): void + { + $cmyk = $this->getTestObject(); + $type = $cmyk->getType(); + $this->assertEquals('CMYK', $type); + } + + public function testGetNormalizedValue(): void + { + $cmyk = $this->getTestObject(); + $res = $cmyk->getNormalizedValue(0.5, 255); + $this->assertEquals(128, $res); + } + + public function testGetHexValue(): void + { + $cmyk = $this->getTestObject(); + $res = $cmyk->getHexValue(0.5, 255); + $this->assertEquals('80', $res); + } + + public function testGetRgbaHexColor(): void + { + $cmyk = $this->getTestObject(); + $rgbaHexColor = $cmyk->getRgbaHexColor(); + $this->assertEquals('#4080bfd9', $rgbaHexColor); + } + + public function testGetRgbHexColor(): void + { + $cmyk = $this->getTestObject(); + $rgbHexColor = $cmyk->getRgbHexColor(); + $this->assertEquals('#4080bf', $rgbHexColor); + } + + public function testGetArray(): void + { + $cmyk = $this->getTestObject(); + $res = $cmyk->getArray(); + $this->assertEquals( + [ + 'C' => 0.666, + 'M' => 0.333, + 'Y' => 0, + 'K' => 0.25, + 'A' => 0.85, + ], + $res + ); + } + + public function testGetNormalizedArray(): void + { + $cmyk = $this->getTestObject(); + $res = $cmyk->getNormalizedArray(100); + $this->assertEquals( + [ + 'C' => 67, + 'M' => 33, + 'Y' => 0, + 'K' => 25, + 'A' => 0.85, + ], + $res + ); + } + + public function testGetCssColor(): void + { + $cmyk = $this->getTestObject(); + $cssColor = $cmyk->getCssColor(); + $this->assertEquals('rgba(25%,50%,75%,0.85)', $cssColor); + } + + public function testGetJsPdfColor(): void + { + $testObj = $this->getTestObject(); + $res = $testObj->getJsPdfColor(); + $this->assertEquals('["CMYK",0.666000,0.333000,0.000000,0.250000]', $res); + + $cmyk = new \Com\Tecnick\Color\Model\Cmyk( + [ + 'cyan' => 0.666, + 'magenta' => 0.333, + 'yellow' => 0, + 'key' => 0.25, + 'alpha' => 0, + ] + ); + $res = $cmyk->getJsPdfColor(); + $this->assertEquals('["T"]', $res); + } + + public function testGetComponentsString(): void + { + $cmyk = $this->getTestObject(); + $componentsString = $cmyk->getComponentsString(); + $this->assertEquals('0.666000 0.333000 0.000000 0.250000', $componentsString); + } + + public function testGetPdfColor(): void + { + $cmyk = $this->getTestObject(); + $res = $cmyk->getPdfColor(); + $this->assertEquals('0.666000 0.333000 0.000000 0.250000 k' . "\n", $res); + + $res = $cmyk->getPdfColor(false); + $this->assertEquals('0.666000 0.333000 0.000000 0.250000 k' . "\n", $res); + + $res = $cmyk->getPdfColor(true); + $this->assertEquals('0.666000 0.333000 0.000000 0.250000 K' . "\n", $res); + } + + public function testToGrayArray(): void + { + $cmyk = $this->getTestObject(); + $res = $cmyk->toGrayArray(); + $this->bcAssertEqualsWithDelta( + [ + 'gray' => 0.25, + 'alpha' => 0.85, + ], + $res + ); + } + + public function testToRgbArray(): void + { + $cmyk = $this->getTestObject(); + $res = $cmyk->toRgbArray(); + $this->bcAssertEqualsWithDelta( + [ + 'red' => 0.25, + 'green' => 0.50, + 'blue' => 0.75, + 'alpha' => 0.85, + ], + $res + ); + } + + public function testToHslArray(): void + { + $cmyk = $this->getTestObject(); + $res = $cmyk->toHslArray(); + $this->bcAssertEqualsWithDelta( + [ + 'hue' => 0.583, + 'saturation' => 0.5, + 'lightness' => 0.5, + 'alpha' => 0.85, + ], + $res + ); + } + + public function testToCmykArray(): void + { + $cmyk = $this->getTestObject(); + $res = $cmyk->toCmykArray(); + $this->bcAssertEqualsWithDelta( + [ + 'cyan' => 0.666, + 'magenta' => 0.333, + 'yellow' => 0, + 'key' => 0.25, + 'alpha' => 0.85, + ], + $res + ); + } + + public function testInvertColor(): void + { + $cmyk = $this->getTestObject(); + $cmyk->invertColor(); + + $res = $cmyk->toCmykArray(); + $this->bcAssertEqualsWithDelta( + [ + 'cyan' => 0.333, + 'magenta' => 0.666, + 'yellow' => 1, + 'key' => 0.75, + 'alpha' => 0.85, + ], + $res + ); + } +} diff --git a/vendor/tecnickcom/tc-lib-color/test/Model/GrayTest.php b/vendor/tecnickcom/tc-lib-color/test/Model/GrayTest.php new file mode 100644 index 0000000..a9f679c --- /dev/null +++ b/vendor/tecnickcom/tc-lib-color/test/Model/GrayTest.php @@ -0,0 +1,215 @@ + + * @copyright 2015-2024 Nicola Asuni - Tecnick.com LTD + * @license http://www.gnu.org/copyleft/lesser.html GNU-LGPL v3 (see LICENSE.TXT) + * @link https://github.com/tecnickcom/tc-lib-color + * + * This file is part of tc-lib-color software library. + */ + +namespace Test\Model; + +use Test\TestUtil; + +/** + * Gray Color class test + * + * @since 2015-02-21 + * @category Library + * @package Color + * @author Nicola Asuni + * @copyright 2015-2024 Nicola Asuni - Tecnick.com LTD + * @license http://www.gnu.org/copyleft/lesser.html GNU-LGPL v3 (see LICENSE.TXT) + * @link https://github.com/tecnickcom/tc-lib-color + */ +class GrayTest extends TestUtil +{ + protected function getTestObject(): \Com\Tecnick\Color\Model\Gray + { + return new \Com\Tecnick\Color\Model\Gray( + [ + 'gray' => 0.75, + 'alpha' => 0.85, + ] + ); + } + + public function testGetType(): void + { + $gray = $this->getTestObject(); + $type = $gray->getType(); + $this->assertEquals('GRAY', $type); + } + + public function testGetNormalizedValue(): void + { + $gray = $this->getTestObject(); + $res = $gray->getNormalizedValue(0.5, 255); + $this->assertEquals(128, $res); + } + + public function testGetHexValue(): void + { + $gray = $this->getTestObject(); + $res = $gray->getHexValue(0.5, 255); + $this->assertEquals('80', $res); + } + + public function testGetRgbaHexColor(): void + { + $gray = $this->getTestObject(); + $rgbaHexColor = $gray->getRgbaHexColor(); + $this->assertEquals('#bfbfbfd9', $rgbaHexColor); + } + + public function testGetRgbHexColor(): void + { + $gray = $this->getTestObject(); + $rgbHexColor = $gray->getRgbHexColor(); + $this->assertEquals('#bfbfbf', $rgbHexColor); + } + + public function testGetArray(): void + { + $gray = $this->getTestObject(); + $res = $gray->getArray(); + $this->assertEquals([ + 'G' => 0.75, + 'A' => 0.85, + ], $res); + } + + public function testGetNormalizedArray(): void + { + $gray = $this->getTestObject(); + $res = $gray->getNormalizedArray(255); + $this->assertEquals([ + 'G' => 191, + 'A' => 0.85, + ], $res); + } + + public function testGetCssColor(): void + { + $gray = $this->getTestObject(); + $cssColor = $gray->getCssColor(); + $this->assertEquals('rgba(75%,75%,75%,0.85)', $cssColor); + } + + public function testGetJsPdfColor(): void + { + $testObj = $this->getTestObject(); + $res = $testObj->getJsPdfColor(); + $this->assertEquals('["G",0.750000]', $res); + + $gray = new \Com\Tecnick\Color\Model\Gray( + [ + 'gray' => 0.5, + 'alpha' => 0, + ] + ); + $res = $gray->getJsPdfColor(); + $this->assertEquals('["T"]', $res); + } + + public function testGetComponentsString(): void + { + $gray = $this->getTestObject(); + $componentsString = $gray->getComponentsString(); + $this->assertEquals('0.750000', $componentsString); + } + + public function testGetPdfColor(): void + { + $gray = $this->getTestObject(); + $res = $gray->getPdfColor(); + $this->assertEquals('0.750000 g' . "\n", $res); + + $res = $gray->getPdfColor(false); + $this->assertEquals('0.750000 g' . "\n", $res); + + $res = $gray->getPdfColor(true); + $this->assertEquals('0.750000 G' . "\n", $res); + } + + public function testToGrayArray(): void + { + $gray = $this->getTestObject(); + $res = $gray->toGrayArray(); + $this->assertEquals( + [ + 'gray' => 0.75, + 'alpha' => 0.85, + ], + $res + ); + } + + public function testToRgbArray(): void + { + $gray = $this->getTestObject(); + $res = $gray->toRgbArray(); + $this->assertEquals( + [ + 'red' => 0.75, + 'green' => 0.75, + 'blue' => 0.75, + 'alpha' => 0.85, + ], + $res + ); + } + + public function testToHslArray(): void + { + $gray = $this->getTestObject(); + $res = $gray->toHslArray(); + $this->assertEquals( + [ + 'hue' => 0, + 'saturation' => 0, + 'lightness' => 0.75, + 'alpha' => 0.85, + ], + $res + ); + } + + public function testToCmykArray(): void + { + $gray = $this->getTestObject(); + $res = $gray->toCmykArray(); + $this->assertEquals( + [ + 'cyan' => 0, + 'magenta' => 0, + 'yellow' => 0, + 'key' => 0.75, + 'alpha' => 0.85, + ], + $res + ); + } + + public function testInvertColor(): void + { + $gray = $this->getTestObject(); + $gray->invertColor(); + + $res = $gray->toGrayArray(); + $this->assertEquals( + [ + 'gray' => 0.25, + 'alpha' => 0.85, + ], + $res + ); + } +} diff --git a/vendor/tecnickcom/tc-lib-color/test/Model/HslTest.php b/vendor/tecnickcom/tc-lib-color/test/Model/HslTest.php new file mode 100644 index 0000000..f5cb12f --- /dev/null +++ b/vendor/tecnickcom/tc-lib-color/test/Model/HslTest.php @@ -0,0 +1,309 @@ + + * @copyright 2015-2024 Nicola Asuni - Tecnick.com LTD + * @license http://www.gnu.org/copyleft/lesser.html GNU-LGPL v3 (see LICENSE.TXT) + * @link https://github.com/tecnickcom/tc-lib-color + * + * This file is part of tc-lib-color software library. + */ + +namespace Test\Model; + +use Test\TestUtil; + +/** + * Hsl Color class test + * + * @since 2015-02-21 + * @category Library + * @package Color + * @author Nicola Asuni + * @copyright 2015-2024 Nicola Asuni - Tecnick.com LTD + * @license http://www.gnu.org/copyleft/lesser.html GNU-LGPL v3 (see LICENSE.TXT) + * @link https://github.com/tecnickcom/tc-lib-color + */ +class HslTest extends TestUtil +{ + protected function getTestObject(): \Com\Tecnick\Color\Model\Hsl + { + return new \Com\Tecnick\Color\Model\Hsl( + [ + 'hue' => 0.583, + 'saturation' => 0.5, + 'lightness' => 0.5, + 'alpha' => 0.85, + ] + ); + } + + public function testGetType(): void + { + $hsl = $this->getTestObject(); + $type = $hsl->getType(); + $this->assertEquals('HSL', $type); + } + + public function testGetNormalizedValue(): void + { + $hsl = $this->getTestObject(); + $res = $hsl->getNormalizedValue(0.5, 255); + $this->assertEquals(128, $res); + } + + public function testGetHexValue(): void + { + $testObj = $this->getTestObject(); + $testObj = $this->getTestObject(); + + $res = $testObj->getHexValue(0.5, 255); + $this->assertEquals('80', $res); + } + + public function testGetRgbaHexColor(): void + { + $hsl = $this->getTestObject(); + $rgbaHexColor = $hsl->getRgbaHexColor(); + $this->assertEquals('#4080bfd9', $rgbaHexColor); + } + + public function testGetRgbHexColor(): void + { + $hsl = $this->getTestObject(); + $rgbHexColor = $hsl->getRgbHexColor(); + $this->assertEquals('#4080bf', $rgbHexColor); + } + + public function testGetArray(): void + { + $hsl = $this->getTestObject(); + $res = $hsl->getArray(); + $this->assertEquals( + [ + 'H' => 0.583, + 'S' => 0.5, + 'L' => 0.5, + 'A' => 0.85, + ], + $res + ); + } + + public function testGetNormalizedArray(): void + { + $hsl = $this->getTestObject(); + $res = $hsl->getNormalizedArray(255); + $this->assertEquals( + [ + 'H' => 210, + 'S' => 0.5, + 'L' => 0.5, + 'A' => 0.85, + ], + $res + ); + } + + public function testGetCssColor(): void + { + $hsl = $this->getTestObject(); + $cssColor = $hsl->getCssColor(); + $this->assertEquals('hsla(210,50%,50%,0.85)', $cssColor); + } + + public function testGetJsPdfColor(): void + { + $testObj = $this->getTestObject(); + $res = $testObj->getJsPdfColor(); + $this->assertEquals('["RGB",0.250000,0.501000,0.750000]', $res); + + $hsl = new \Com\Tecnick\Color\Model\Hsl( + [ + 'hue' => 0.583, + 'saturation' => 0.5, + 'lightness' => 0.5, + 'alpha' => 0, + ] + ); + $res = $hsl->getJsPdfColor(); + $this->assertEquals('["T"]', $res); + } + + public function testGetComponentsString(): void + { + $hsl = $this->getTestObject(); + $componentsString = $hsl->getComponentsString(); + $this->assertEquals('0.250000 0.501000 0.750000', $componentsString); + } + + public function testGetPdfColor(): void + { + $hsl = $this->getTestObject(); + $res = $hsl->getPdfColor(); + $this->assertEquals('0.250000 0.501000 0.750000 rg' . "\n", $res); + + $res = $hsl->getPdfColor(false); + $this->assertEquals('0.250000 0.501000 0.750000 rg' . "\n", $res); + + $res = $hsl->getPdfColor(true); + $this->assertEquals('0.250000 0.501000 0.750000 RG' . "\n", $res); + } + + public function testToGrayArray(): void + { + $hsl = $this->getTestObject(); + $res = $hsl->toGrayArray(); + $this->bcAssertEqualsWithDelta( + [ + 'gray' => 0.5, + 'alpha' => 0.85, + ], + $res + ); + } + + public function testToRgbArray(): void + { + $testObj = $this->getTestObject(); + $res = $testObj->toRgbArray(); + $this->bcAssertEqualsWithDelta( + [ + 'red' => 0.25, + 'green' => 0.50, + 'blue' => 0.75, + 'alpha' => 0.85, + ], + $res + ); + + $col = new \Com\Tecnick\Color\Model\Hsl( + [ + 'hue' => 0.583, + 'saturation' => 0.5, + 'lightness' => 0.4, + 'alpha' => 1, + ] + ); + $res = $col->toRgbArray(); + $this->bcAssertEqualsWithDelta( + [ + 'red' => 0.199, + 'green' => 0.400, + 'blue' => 0.600, + 'alpha' => 1, + ], + $res + ); + + $col = new \Com\Tecnick\Color\Model\Hsl( + [ + 'hue' => 0.583, + 'saturation' => 0, + 'lightness' => 0.4, + 'alpha' => 1, + ] + ); + $res = $col->toRgbArray(); + $this->bcAssertEqualsWithDelta( + [ + 'red' => 0.400, + 'green' => 0.400, + 'blue' => 0.400, + 'alpha' => 1, + ], + $res + ); + + $col = new \Com\Tecnick\Color\Model\Hsl( + [ + 'hue' => 0.01, + 'saturation' => 1, + 'lightness' => 0.4, + 'alpha' => 1, + ] + ); + $res = $col->toRgbArray(); + $this->bcAssertEqualsWithDelta( + [ + 'red' => 0.8, + 'green' => 0.048, + 'blue' => 0, + 'alpha' => 1, + ], + $res + ); + + $col = new \Com\Tecnick\Color\Model\Hsl( + [ + 'hue' => 1, + 'saturation' => 1, + 'lightness' => 0.4, + 'alpha' => 1, + ] + ); + $res = $col->toRgbArray(); + $this->bcAssertEqualsWithDelta( + [ + 'red' => 0.8, + 'green' => 0, + 'blue' => 0, + 'alpha' => 1, + ], + $res + ); + } + + public function testToHslArray(): void + { + $hsl = $this->getTestObject(); + $res = $hsl->toHslArray(); + $this->bcAssertEqualsWithDelta( + [ + 'hue' => 0.583, + 'saturation' => 0.5, + 'lightness' => 0.5, + 'alpha' => 0.85, + ], + $res + ); + } + + public function testToCmykArray(): void + { + $hsl = $this->getTestObject(); + $res = $hsl->toCmykArray(); + $this->bcAssertEqualsWithDelta( + [ + 'cyan' => 0.666, + 'magenta' => 0.333, + 'yellow' => 0, + 'key' => 0.25, + 'alpha' => 0.85, + ], + $res + ); + } + + public function testInvertColor(): void + { + $hsl = $this->getTestObject(); + $hsl->invertColor(); + + $res = $hsl->toHslArray(); + $this->bcAssertEqualsWithDelta( + [ + 'hue' => 0.083, + 'saturation' => 0.5, + 'lightness' => 0.5, + 'alpha' => 0.85, + ], + $res + ); + } +} diff --git a/vendor/tecnickcom/tc-lib-color/test/Model/RgbTest.php b/vendor/tecnickcom/tc-lib-color/test/Model/RgbTest.php new file mode 100644 index 0000000..dfa8b3a --- /dev/null +++ b/vendor/tecnickcom/tc-lib-color/test/Model/RgbTest.php @@ -0,0 +1,327 @@ + + * @copyright 2015-2024 Nicola Asuni - Tecnick.com LTD + * @license http://www.gnu.org/copyleft/lesser.html GNU-LGPL v3 (see LICENSE.TXT) + * @link https://github.com/tecnickcom/tc-lib-color + * + * This file is part of tc-lib-color software library. + */ + +namespace Test\Model; + +use Test\TestUtil; + +/** + * Rgb Color class test + * + * @since 2015-02-21 + * @category Library + * @package Color + * @author Nicola Asuni + * @copyright 2015-2024 Nicola Asuni - Tecnick.com LTD + * @license http://www.gnu.org/copyleft/lesser.html GNU-LGPL v3 (see LICENSE.TXT) + * @link https://github.com/tecnickcom/tc-lib-color + */ +class RgbTest extends TestUtil +{ + protected function getTestObject(): \Com\Tecnick\Color\Model\Rgb + { + return new \Com\Tecnick\Color\Model\Rgb( + [ + 'red' => 0.25, + 'green' => 0.50, + 'blue' => 0.75, + 'alpha' => 0.85, + ] + ); + } + + public function testGetType(): void + { + $rgb = $this->getTestObject(); + $type = $rgb->getType(); + $this->assertEquals('RGB', $type); + } + + public function testGetNormalizedValue(): void + { + $rgb = $this->getTestObject(); + $res = $rgb->getNormalizedValue(0.5, 255); + $this->assertEquals(128, $res); + } + + public function testGetHexValue(): void + { + $rgb = $this->getTestObject(); + $res = $rgb->getHexValue(0.5, 255); + $this->assertEquals('80', $res); + } + + public function testGetRgbaHexColor(): void + { + $rgb = $this->getTestObject(); + $rgbaHexColor = $rgb->getRgbaHexColor(); + $this->assertEquals('#4080bfd9', $rgbaHexColor); + } + + public function testGetRgbHexColor(): void + { + $rgb = $this->getTestObject(); + $rgbHexColor = $rgb->getRgbHexColor(); + $this->assertEquals('#4080bf', $rgbHexColor); + } + + public function testGetArray(): void + { + $rgb = $this->getTestObject(); + $res = $rgb->getArray(); + $this->assertEquals( + [ + 'R' => 0.25, + 'G' => 0.50, + 'B' => 0.75, + 'A' => 0.85, + ], + $res + ); + } + + public function testGetNormalizedArray(): void + { + $rgb = $this->getTestObject(); + $res = $rgb->getNormalizedArray(255); + $this->assertEquals( + [ + 'R' => 64, + 'G' => 128, + 'B' => 191, + 'A' => 0.85, + ], + $res + ); + } + + public function testGetCssColor(): void + { + $rgb = $this->getTestObject(); + $cssColor = $rgb->getCssColor(); + $this->assertEquals('rgba(25%,50%,75%,0.85)', $cssColor); + } + + public function testGetJsPdfColor(): void + { + $testObj = $this->getTestObject(); + $res = $testObj->getJsPdfColor(); + $this->assertEquals('["RGB",0.250000,0.500000,0.750000]', $res); + + $rgb = new \Com\Tecnick\Color\Model\Rgb( + [ + 'red' => 0.25, + 'green' => 0.50, + 'blue' => 0.75, + 'alpha' => 0, + ] + ); + $res = $rgb->getJsPdfColor(); + $this->assertEquals('["T"]', $res); + } + + public function testGetComponentsString(): void + { + $rgb = $this->getTestObject(); + $componentsString = $rgb->getComponentsString(); + $this->assertEquals('0.250000 0.500000 0.750000', $componentsString); + } + + public function testGetPdfColor(): void + { + $rgb = $this->getTestObject(); + $res = $rgb->getPdfColor(); + $this->assertEquals('0.250000 0.500000 0.750000 rg' . "\n", $res); + + $res = $rgb->getPdfColor(false); + $this->assertEquals('0.250000 0.500000 0.750000 rg' . "\n", $res); + + $res = $rgb->getPdfColor(true); + $this->assertEquals('0.250000 0.500000 0.750000 RG' . "\n", $res); + } + + public function testToGrayArray(): void + { + $rgb = $this->getTestObject(); + $res = $rgb->toGrayArray(); + $this->bcAssertEqualsWithDelta( + [ + 'gray' => 0.465, + 'alpha' => 0.85, + ], + $res + ); + } + + public function testToRgbArray(): void + { + $rgb = $this->getTestObject(); + $res = $rgb->toRgbArray(); + $this->bcAssertEqualsWithDelta( + [ + 'red' => 0.25, + 'green' => 0.50, + 'blue' => 0.75, + 'alpha' => 0.85, + ], + $res + ); + } + + public function testToHslArray(): void + { + $testObj = $this->getTestObject(); + $res = $testObj->toHslArray(); + $this->bcAssertEqualsWithDelta( + [ + 'hue' => 0.583, + 'saturation' => 0.5, + 'lightness' => 0.5, + 'alpha' => 0.85, + ], + $res + ); + + $col = new \Com\Tecnick\Color\Model\Rgb( + [ + 'red' => 0, + 'green' => 0, + 'blue' => 0, + 'alpha' => 1, + ] + ); + $res = $col->toHslArray(); + $this->bcAssertEqualsWithDelta( + [ + 'hue' => 0, + 'saturation' => 0, + 'lightness' => 0, + 'alpha' => 1, + ], + $res + ); + + $col = new \Com\Tecnick\Color\Model\Rgb( + [ + 'red' => 0.1, + 'green' => 0.3, + 'blue' => 0.2, + 'alpha' => 1, + ] + ); + $res = $col->toHslArray(); + $this->bcAssertEqualsWithDelta( + [ + 'hue' => 0.416, + 'saturation' => 0.500, + 'lightness' => 0.200, + 'alpha' => 1, + ], + $res + ); + + $col = new \Com\Tecnick\Color\Model\Rgb( + [ + 'red' => 0.3, + 'green' => 0.2, + 'blue' => 0.1, + 'alpha' => 1, + ] + ); + $res = $col->toHslArray(); + $this->bcAssertEqualsWithDelta( + [ + 'hue' => 0.0833, + 'saturation' => 0.500, + 'lightness' => 0.200, + 'alpha' => 1, + ], + $res + ); + + $col = new \Com\Tecnick\Color\Model\Rgb( + [ + 'red' => 1, + 'green' => 0.1, + 'blue' => 0.9, + 'alpha' => 1, + ] + ); + $res = $col->toHslArray(); + $this->bcAssertEqualsWithDelta( + [ + 'hue' => 0.852, + 'saturation' => 1, + 'lightness' => 0.55, + 'alpha' => 1, + ], + $res + ); + } + + public function testToCmykArray(): void + { + $testObj = $this->getTestObject(); + $res = $testObj->toCmykArray(); + $this->bcAssertEqualsWithDelta( + [ + 'cyan' => 0.666, + 'magenta' => 0.333, + 'yellow' => 0, + 'key' => 0.25, + 'alpha' => 0.85, + ], + $res + ); + + $rgb = new \Com\Tecnick\Color\Model\Rgb( + [ + 'red' => 0, + 'green' => 0, + 'blue' => 0, + 'alpha' => 1, + ] + ); + $res = $rgb->toCmykArray(); + $this->bcAssertEqualsWithDelta( + [ + 'cyan' => 0, + 'magenta' => 0, + 'yellow' => 0, + 'key' => 1, + 'alpha' => 1, + ], + $res + ); + } + + public function testInvertColor(): void + { + $rgb = $this->getTestObject(); + $rgb->invertColor(); + + $res = $rgb->toRgbArray(); + $this->bcAssertEqualsWithDelta( + [ + 'red' => 0.75, + 'green' => 0.50, + 'blue' => 0.25, + 'alpha' => 0.85, + ], + $res + ); + } +} diff --git a/vendor/tecnickcom/tc-lib-color/test/PdfTest.php b/vendor/tecnickcom/tc-lib-color/test/PdfTest.php new file mode 100644 index 0000000..54fd333 --- /dev/null +++ b/vendor/tecnickcom/tc-lib-color/test/PdfTest.php @@ -0,0 +1,277 @@ + + * @copyright 2015-2024 Nicola Asuni - Tecnick.com LTD + * @license http://www.gnu.org/copyleft/lesser.html GNU-LGPL v3 (see LICENSE.TXT) + * @link https://github.com/tecnickcom/tc-lib-color + * + * This file is part of tc-lib-color software library. + */ + +namespace Test; + +/** + * Pdf Color class test + * + * @since 2015-02-21 + * @category Library + * @package Color + * @author Nicola Asuni + * @copyright 2015-2024 Nicola Asuni - Tecnick.com LTD + * @license http://www.gnu.org/copyleft/lesser.html GNU-LGPL v3 (see LICENSE.TXT) + * @link https://github.com/tecnickcom/tc-lib-color + */ +class PdfTest extends TestUtil +{ + protected function getTestObject(): \Com\Tecnick\Color\Pdf + { + return new \Com\Tecnick\Color\Pdf(); + } + + public function testGetJsColorString(): void + { + $pdf = $this->getTestObject(); + $res = $pdf->getJsColorString('t()'); + $this->assertEquals('color.transparent', $res); + $res = $pdf->getJsColorString('["T"]'); + $this->assertEquals('color.transparent', $res); + $res = $pdf->getJsColorString('transparent'); + $this->assertEquals('color.transparent', $res); + $res = $pdf->getJsColorString('color.transparent'); + $this->assertEquals('color.transparent', $res); + $res = $pdf->getJsColorString('magenta'); + $this->assertEquals('color.magenta', $res); + $res = $pdf->getJsColorString('#1a2b3c4d'); + $this->assertEquals('["RGB",0.101961,0.168627,0.235294]', $res); + $res = $pdf->getJsColorString('#1a2b3c'); + $this->assertEquals('["RGB",0.101961,0.168627,0.235294]', $res); + $res = $pdf->getJsColorString('#1234'); + $this->assertEquals('["RGB",0.066667,0.133333,0.200000]', $res); + $res = $pdf->getJsColorString('#123'); + $this->assertEquals('["RGB",0.066667,0.133333,0.200000]', $res); + $res = $pdf->getJsColorString('["G",0.5]'); + $this->assertEquals('["G",0.500000]', $res); + $res = $pdf->getJsColorString('["RGB",0.25,0.50,0.75]'); + $this->assertEquals('["RGB",0.250000,0.500000,0.750000]', $res); + $res = $pdf->getJsColorString('["CMYK",0.666,0.333,0,0.25]'); + $this->assertEquals('["CMYK",0.666000,0.333000,0.000000,0.250000]', $res); + $res = $pdf->getJsColorString('g(50%)'); + $this->assertEquals('["G",0.500000]', $res); + $res = $pdf->getJsColorString('g(128)'); + $this->assertEquals('["G",0.501961]', $res); + $res = $pdf->getJsColorString('rgb(25%,50%,75%)'); + $this->assertEquals('["RGB",0.250000,0.500000,0.750000]', $res); + $res = $pdf->getJsColorString('rgb(64,128,191)'); + $this->assertEquals('["RGB",0.250980,0.501961,0.749020]', $res); + $res = $pdf->getJsColorString('rgba(25%,50%,75%,0.85)'); + $this->assertEquals('["RGB",0.250000,0.500000,0.750000]', $res); + $res = $pdf->getJsColorString('rgba(64,128,191,0.85)'); + $this->assertEquals('["RGB",0.250980,0.501961,0.749020]', $res); + $res = $pdf->getJsColorString('hsl(210,50%,50%)'); + $this->assertEquals('["RGB",0.250000,0.500000,0.750000]', $res); + $res = $pdf->getJsColorString('hsla(210,50%,50%,0.85)'); + $this->assertEquals('["RGB",0.250000,0.500000,0.750000]', $res); + $res = $pdf->getJsColorString('cmyk(67%,33%,0,25%)'); + $this->assertEquals('["CMYK",0.670000,0.330000,0.000000,0.250000]', $res); + $res = $pdf->getJsColorString('cmyk(67,33,0,25)'); + $this->assertEquals('["CMYK",0.670000,0.330000,0.000000,0.250000]', $res); + $res = $pdf->getJsColorString('cmyka(67,33,0,25,0.85)'); + $this->assertEquals('["CMYK",0.670000,0.330000,0.000000,0.250000]', $res); + $res = $pdf->getJsColorString('cmyka(67%,33%,0,25%,0.85)'); + $this->assertEquals('["CMYK",0.670000,0.330000,0.000000,0.250000]', $res); + $res = $pdf->getJsColorString('g(-)'); + $this->assertEquals('color.transparent', $res); + $res = $pdf->getJsColorString('rgb(-)'); + $this->assertEquals('color.transparent', $res); + $res = $pdf->getJsColorString('hsl(-)'); + $this->assertEquals('color.transparent', $res); + $res = $pdf->getJsColorString('cmyk(-)'); + $this->assertEquals('color.transparent', $res); + } + + public function testGetColorObject(): void + { + $pdf = $this->getTestObject(); + $res = $pdf->getColorObject(''); + $this->assertNull($res); + $res = $pdf->getColorObject('[*'); + $this->assertNull($res); + $res = $pdf->getColorObject('t()'); + $this->assertNull($res); + $res = $pdf->getColorObject('["T"]'); + $this->assertNull($res); + $res = $pdf->getColorObject('transparent'); + $this->assertNull($res); + $res = $pdf->getColorObject('color.transparent'); + $this->assertNull($res); + $res = $pdf->getColorObject('#1a2b3c4d'); + $this->assertNotNull($res); + $this->assertEquals('#1a2b3c4d', $res->getRgbaHexColor()); + $res = $pdf->getColorObject('#1a2b3c'); + $this->assertNotNull($res); + $this->assertEquals('#1a2b3cff', $res->getRgbaHexColor()); + $res = $pdf->getColorObject('#1234'); + $this->assertNotNull($res); + $this->assertEquals('#11223344', $res->getRgbaHexColor()); + $res = $pdf->getColorObject('#123'); + $this->assertNotNull($res); + $this->assertEquals('#112233ff', $res->getRgbaHexColor()); + $res = $pdf->getColorObject('["G",0.5]'); + $this->assertNotNull($res); + $this->assertEquals('#808080ff', $res->getRgbaHexColor()); + $res = $pdf->getColorObject('["RGB",0.25,0.50,0.75]'); + $this->assertNotNull($res); + $this->assertEquals('#4080bfff', $res->getRgbaHexColor()); + $res = $pdf->getColorObject('["CMYK",0.666,0.333,0,0.25]'); + $this->assertNotNull($res); + $this->assertEquals('#4080bfff', $res->getRgbaHexColor()); + $res = $pdf->getColorObject('g(50%)'); + $this->assertNotNull($res); + $this->assertEquals('#808080ff', $res->getRgbaHexColor()); + $res = $pdf->getColorObject('g(128)'); + $this->assertNotNull($res); + $this->assertEquals('#808080ff', $res->getRgbaHexColor()); + $res = $pdf->getColorObject('rgb(25%,50%,75%)'); + $this->assertNotNull($res); + $this->assertEquals('#4080bfff', $res->getRgbaHexColor()); + $res = $pdf->getColorObject('rgb(64,128,191)'); + $this->assertNotNull($res); + $this->assertEquals('#4080bfff', $res->getRgbaHexColor()); + $res = $pdf->getColorObject('rgba(25%,50%,75%,0.85)'); + $this->assertNotNull($res); + $this->assertEquals('#4080bfd9', $res->getRgbaHexColor()); + $res = $pdf->getColorObject('rgba(64,128,191,0.85)'); + $this->assertNotNull($res); + $this->assertEquals('#4080bfd9', $res->getRgbaHexColor()); + $res = $pdf->getColorObject('hsl(210,50%,50%)'); + $this->assertNotNull($res); + $this->assertEquals('#4080bfff', $res->getRgbaHexColor()); + $res = $pdf->getColorObject('hsla(210,50%,50%,0.85)'); + $this->assertNotNull($res); + $this->assertEquals('#4080bfd9', $res->getRgbaHexColor()); + $res = $pdf->getColorObject('cmyk(67%,33%,0,25%)'); + $this->assertNotNull($res); + $this->assertEquals('#3f80bfff', $res->getRgbaHexColor()); + $res = $pdf->getColorObject('cmyk(67,33,0,25)'); + $this->assertNotNull($res); + $this->assertEquals('#3f80bfff', $res->getRgbaHexColor()); + $res = $pdf->getColorObject('cmyka(67,33,0,25,0.85)'); + $this->assertNotNull($res); + $this->assertEquals('#3f80bfd9', $res->getRgbaHexColor()); + $res = $pdf->getColorObject('cmyka(67%,33%,0,25%,0.85)'); + $this->assertNotNull($res); + $this->assertEquals('#3f80bfd9', $res->getRgbaHexColor()); + $res = $pdf->getColorObject('none'); + $this->assertNotNull($res); + $this->assertEquals('0.000000 0.000000 0.000000 0.000000 k' . "\n", $res->getPdfColor()); + $res = $pdf->getColorObject('all'); + $this->assertNotNull($res); + $this->assertEquals('1.000000 1.000000 1.000000 1.000000 k' . "\n", $res->getPdfColor()); + $res = $pdf->getColorObject('["G"]'); + $this->assertNull($res); + $res = $pdf->getColorObject('["RGB"]'); + $this->assertNull($res); + $res = $pdf->getColorObject('["CMYK"]'); + $this->assertNull($res); + $res = $pdf->getColorObject('g(-)'); + $this->assertNull($res); + $res = $pdf->getColorObject('rgb(-)'); + $this->assertNull($res); + $res = $pdf->getColorObject('hsl(-)'); + $this->assertNull($res); + $res = $pdf->getColorObject('cmyk(-)'); + $this->assertNull($res); + } + + public function testGetPdfColor(): void + { + $pdf = $this->getTestObject(); + $res = $pdf->getPdfColor('magenta', false, 1); + $this->assertEquals('/CS1 cs 1.000000 scn' . "\n", $res); + $res = $pdf->getPdfColor('magenta', true, 1); + $this->assertEquals('/CS1 CS 1.000000 SCN' . "\n", $res); + $res = $pdf->getPdfColor('magenta', false, 0.5); + $this->assertEquals('/CS1 cs 0.500000 scn' . "\n", $res); + $res = $pdf->getPdfColor('magenta', true, 0.5); + $this->assertEquals('/CS1 CS 0.500000 SCN' . "\n", $res); + + $res = $pdf->getPdfColor('t()', false, 1); + $this->assertEquals('', $res); + $res = $pdf->getPdfColor('["T"]', false, 1); + $this->assertEquals('', $res); + $res = $pdf->getPdfColor('transparent', false, 1); + $this->assertEquals('', $res); + $res = $pdf->getPdfColor('color.transparent', false, 1); + $this->assertEquals('', $res); + $res = $pdf->getPdfColor('magenta', false, 1); + $this->assertEquals('/CS1 cs 1.000000 scn' . "\n", $res); + $res = $pdf->getPdfColor('#1a2b3c4d', false, 1); + $this->assertEquals('0.101961 0.168627 0.235294 rg' . "\n", $res); + $res = $pdf->getPdfColor('#1a2b3c', false, 1); + $this->assertEquals('0.101961 0.168627 0.235294 rg' . "\n", $res); + $res = $pdf->getPdfColor('#1234', false, 1); + $this->assertEquals('0.066667 0.133333 0.200000 rg' . "\n", $res); + $res = $pdf->getPdfColor('#123', false, 1); + $this->assertEquals('0.066667 0.133333 0.200000 rg' . "\n", $res); + $res = $pdf->getPdfColor('["G",0.5]', false, 1); + $this->assertEquals('0.500000 g' . "\n", $res); + $res = $pdf->getPdfColor('["RGB",0.25,0.50,0.75]', false, 1); + $this->assertEquals('0.250000 0.500000 0.750000 rg' . "\n", $res); + $res = $pdf->getPdfColor('["CMYK",0.666,0.333,0,0.25]', false, 1); + $this->assertEquals('0.666000 0.333000 0.000000 0.250000 k' . "\n", $res); + $res = $pdf->getPdfColor('g(50%)', false, 1); + $this->assertEquals('0.500000 g' . "\n", $res); + $res = $pdf->getPdfColor('g(128)', false, 1); + $this->assertEquals('0.501961 g' . "\n", $res); + $res = $pdf->getPdfColor('rgb(25%,50%,75%)', false, 1); + $this->assertEquals('0.250000 0.500000 0.750000 rg' . "\n", $res); + $res = $pdf->getPdfColor('rgb(64,128,191)', false, 1); + $this->assertEquals('0.250980 0.501961 0.749020 rg' . "\n", $res); + $res = $pdf->getPdfColor('rgba(25%,50%,75%,0.85)', false, 1); + $this->assertEquals('0.250000 0.500000 0.750000 rg' . "\n", $res); + $res = $pdf->getPdfColor('rgba(64,128,191,0.85)', false, 1); + $this->assertEquals('0.250980 0.501961 0.749020 rg' . "\n", $res); + $res = $pdf->getPdfColor('hsl(210,50%,50%)', false, 1); + $this->assertEquals('0.250000 0.500000 0.750000 rg' . "\n", $res); + $res = $pdf->getPdfColor('hsla(210,50%,50%,0.85)', false, 1); + $this->assertEquals('0.250000 0.500000 0.750000 rg' . "\n", $res); + $res = $pdf->getPdfColor('cmyk(67%,33%,0,25%)', false, 1); + $this->assertEquals('0.670000 0.330000 0.000000 0.250000 k' . "\n", $res); + $res = $pdf->getPdfColor('cmyk(67,33,0,25)', false, 1); + $this->assertEquals('0.670000 0.330000 0.000000 0.250000 k' . "\n", $res); + $res = $pdf->getPdfColor('cmyka(67,33,0,25,0.85)', false, 1); + $this->assertEquals('0.670000 0.330000 0.000000 0.250000 k' . "\n", $res); + $res = $pdf->getPdfColor('cmyka(67%,33%,0,25%,0.85)', false, 1); + $this->assertEquals('0.670000 0.330000 0.000000 0.250000 k' . "\n", $res); + $res = $pdf->getPdfColor('g(-)'); + $this->assertEquals('', $res); + $res = $pdf->getPdfColor('rgb(-)'); + $this->assertEquals('', $res); + $res = $pdf->getPdfColor('hsl(-)'); + $this->assertEquals('', $res); + $res = $pdf->getPdfColor('cmyk(-)'); + $this->assertEquals('', $res); + } + + public function testGetPdfRgbComponents(): void + { + $pdf = $this->getTestObject(); + $res = $pdf->getPdfRgbComponents(''); + $this->assertEquals('', $res); + + $res = $pdf->getPdfRgbComponents('red'); + $this->assertEquals('1.000000 0.000000 0.000000', $res); + + $res = $pdf->getPdfRgbComponents('#00ff00'); + $this->assertEquals('0.000000 1.000000 0.000000', $res); + + $res = $pdf->getPdfRgbComponents('rgb(0,0,255)'); + $this->assertEquals('0.000000 0.000000 1.000000', $res); + } +} diff --git a/vendor/tecnickcom/tc-lib-color/test/SpotTest.php b/vendor/tecnickcom/tc-lib-color/test/SpotTest.php new file mode 100644 index 0000000..8cde812 --- /dev/null +++ b/vendor/tecnickcom/tc-lib-color/test/SpotTest.php @@ -0,0 +1,179 @@ + + * @copyright 2015-2024 Nicola Asuni - Tecnick.com LTD + * @license http://www.gnu.org/copyleft/lesser.html GNU-LGPL v3 (see LICENSE.TXT) + * @link https://github.com/tecnickcom/tc-lib-color + * + * This file is part of tc-lib-color software library. + */ + +namespace Test; + +/** + * Spot Color class test + * + * @since 2015-02-21 + * @category Library + * @package Color + * @author Nicola Asuni + * @copyright 2015-2024 Nicola Asuni - Tecnick.com LTD + * @license http://www.gnu.org/copyleft/lesser.html GNU-LGPL v3 (see LICENSE.TXT) + * @link https://github.com/tecnickcom/tc-lib-color + */ +class SpotTest extends TestUtil +{ + protected function getTestObject(): \Com\Tecnick\Color\Spot + { + return new \Com\Tecnick\Color\Spot(); + } + + public function testGetSpotColors(): void + { + $spot = $this->getTestObject(); + $res = $spot->getSpotColors(); + $this->assertEquals(0, count($res)); + } + + public function testNormalizeSpotColorName(): void + { + $spot = $this->getTestObject(); + $res = $spot->normalizeSpotColorName('abc.FG12!-345'); + $this->assertEquals('abcfg12345', $res); + } + + public function testGetSpotColor(): void + { + $spot = $this->getTestObject(); + $res = $spot->getSpotColor('none'); + $this->assertEquals('0.000000 0.000000 0.000000 0.000000 k' . "\n", $res['color']->getPdfColor()); + $res = $spot->getSpotColor('all'); + $this->assertEquals('1.000000 1.000000 1.000000 1.000000 k' . "\n", $res['color']->getPdfColor()); + $res = $spot->getSpotColor('red'); + $this->assertEquals('0.000000 1.000000 1.000000 0.000000 K' . "\n", $res['color']->getPdfColor(true)); + } + + public function testGetSpotColorObj(): void + { + $spot = $this->getTestObject(); + $res = $spot->getSpotColorObj('none'); + $this->assertEquals('0.000000 0.000000 0.000000 0.000000 k' . "\n", $res->getPdfColor()); + $res = $spot->getSpotColorObj('all'); + $this->assertEquals('1.000000 1.000000 1.000000 1.000000 k' . "\n", $res->getPdfColor()); + $res = $spot->getSpotColorObj('red'); + $this->assertEquals('0.000000 1.000000 1.000000 0.000000 K' . "\n", $res->getPdfColor(true)); + } + + public function testAddSpotColor(): void + { + $spot = $this->getTestObject(); + $cmyk = new \Com\Tecnick\Color\Model\Cmyk( + [ + 'cyan' => 0.666, + 'magenta' => 0.333, + 'yellow' => 0, + 'key' => 0.25, + 'alpha' => 0.85, + ] + ); + $spot->addSpotColor('test', $cmyk); + $res = $spot->getSpotColors(); + $this->assertArrayHasKey('test', $res); + $this->assertEquals(1, $res['test']['i']); + $this->assertEquals('test', $res['test']['name']); + $this->assertEquals('0.666000 0.333000 0.000000 0.250000 k' . "\n", $res['test']['color']->getPdfColor()); + + // test overwrite + $cmyk = new \Com\Tecnick\Color\Model\Cmyk( + [ + 'cyan' => 0.25, + 'magenta' => 0.35, + 'yellow' => 0.45, + 'key' => 0.55, + 'alpha' => 0.65, + ] + ); + $key = $spot->addSpotColor('test', $cmyk); + $this->assertEquals('test', $key); + + $res = $spot->getSpotColors(); + $this->assertArrayHasKey('test', $res); + $this->assertEquals(1, $res['test']['i']); + $this->assertEquals('test', $res['test']['name']); + $this->assertEquals('0.250000 0.350000 0.450000 0.550000 k' . "\n", $res['test']['color']->getPdfColor()); + } + + public function testGetPdfSpotObjectsEmpty(): void + { + $spot = $this->getTestObject(); + $obj = 1; + $res = $spot->getPdfSpotObjects($obj); + $this->assertEquals(1, $obj); + $this->assertEquals('', $res); + } + + public function testGetPdfSpotResourcesEmpty(): void + { + $spot = $this->getTestObject(); + $pdfSpotResources = $spot->getPdfSpotResources(); + $this->assertEquals('', $pdfSpotResources); + } + + public function testGetPdfSpotObjects(): void + { + $spot = $this->getTestObject(); + $cmyk = new \Com\Tecnick\Color\Model\Cmyk( + [ + 'cyan' => 0.666, + 'magenta' => 0.333, + 'yellow' => 0, + 'key' => 0.25, + 'alpha' => 0.85, + ] + ); + $spot->addSpotColor('test', $cmyk); + $spot->getSpotColor('cyan'); + $spot->getSpotColor('magenta'); + $spot->getSpotColor('yellow'); + $spot->getSpotColor('key'); + + $obj = 1; + $res = $spot->getPdfSpotObjects($obj); + $this->assertEquals(6, $obj); + $this->assertEquals( + '2 0 obj' . "\n" + . '[/Separation /test /DeviceCMYK <>]' . "\n" + . 'endobj' . "\n" + . '3 0 obj' . "\n" + . '[/Separation /cyan /DeviceCMYK <>]' . "\n" + . 'endobj' . "\n" + . '4 0 obj' . "\n" + . '[/Separation /magenta /DeviceCMYK <>]' . "\n" + . 'endobj' . "\n" + . '5 0 obj' . "\n" + . '[/Separation /yellow /DeviceCMYK <>]' . "\n" + . 'endobj' . "\n" + . '6 0 obj' . "\n" + . '[/Separation /key /DeviceCMYK <>]' . "\n" + . 'endobj' . "\n", + $res + ); + + $res = $spot->getPdfSpotResources(); + $this->assertEquals('/ColorSpace << /CS1 2 0 R /CS2 3 0 R /CS3 4 0 R /CS4 5 0 R /CS5 6 0 R >>' . "\n", $res); + + $resk = $spot->getPdfSpotResourcesByKeys(['cyan','yellow']); + $this->assertEquals('/ColorSpace << /CS2 3 0 R /CS4 5 0 R >>' . "\n", $resk); + } +} diff --git a/vendor/tecnickcom/tc-lib-color/test/TestUtil.php b/vendor/tecnickcom/tc-lib-color/test/TestUtil.php new file mode 100644 index 0000000..e581902 --- /dev/null +++ b/vendor/tecnickcom/tc-lib-color/test/TestUtil.php @@ -0,0 +1,50 @@ + + * @copyright 2015-2024 Nicola Asuni - Tecnick.com LTD + * @license http://www.gnu.org/copyleft/lesser.html GNU-LGPL v3 (see LICENSE.TXT) + * @link https://github.com/tecnickcom/tc-lib-color + * + * This file is part of tc-lib-color software library. + */ + +namespace Test; + +use PHPUnit\Framework\TestCase; + +/** + * Web Color class test + * + * @since 2020-12-19 + * @category Library + * @package Color + * @author Nicola Asuni + * @copyright 2015-2024 Nicola Asuni - Tecnick.com LTD + * @license http://www.gnu.org/copyleft/lesser.html GNU-LGPL v3 (see LICENSE.TXT) + * @link https://github.com/tecnickcom/tc-lib-color + */ +class TestUtil extends TestCase +{ + public function bcAssertEqualsWithDelta( + mixed $expected, + mixed $actual, + float $delta = 0.01, + string $message = '' + ): void { + parent::assertEqualsWithDelta($expected, $actual, $delta, $message); + } + + /** + * @param class-string<\Throwable> $exception + */ + public function bcExpectException($exception): void + { + parent::expectException($exception); + } +} diff --git a/vendor/tecnickcom/tc-lib-color/test/WebTest.php b/vendor/tecnickcom/tc-lib-color/test/WebTest.php new file mode 100644 index 0000000..d7ef0fa --- /dev/null +++ b/vendor/tecnickcom/tc-lib-color/test/WebTest.php @@ -0,0 +1,306 @@ + + * @copyright 2015-2024 Nicola Asuni - Tecnick.com LTD + * @license http://www.gnu.org/copyleft/lesser.html GNU-LGPL v3 (see LICENSE.TXT) + * @link https://github.com/tecnickcom/tc-lib-color + * + * This file is part of tc-lib-color software library. + */ + +namespace Test; + +use PHPUnit\Framework\Attributes\DataProvider; + +/** + * Web Color class test + * + * @since 2015-02-21 + * @category Library + * @package Color + * @author Nicola Asuni + * @copyright 2015-2024 Nicola Asuni - Tecnick.com LTD + * @license http://www.gnu.org/copyleft/lesser.html GNU-LGPL v3 (see LICENSE.TXT) + * @link https://github.com/tecnickcom/tc-lib-color + */ +class WebTest extends TestUtil +{ + protected function getTestObject(): \Com\Tecnick\Color\Web + { + return new \Com\Tecnick\Color\Web(); + } + + public function testGetHexFromName(): void + { + $web = $this->getTestObject(); + $res = $web->getHexFromName('aliceblue'); + $this->assertEquals('f0f8ffff', $res); + $res = $web->getHexFromName('color.yellowgreen'); + $this->assertEquals('9acd32ff', $res); + } + + public function testGetHexFromNameInvalid(): void + { + $this->bcExpectException('\\' . \Com\Tecnick\Color\Exception::class); + $web = $this->getTestObject(); + $web->getHexFromName('invalid'); + } + + public function testGetNameFromHex(): void + { + $web = $this->getTestObject(); + $res = $web->getNameFromHex('f0f8ffff'); + $this->assertEquals('aliceblue', $res); + $res = $web->getNameFromHex('9acd32ff'); + $this->assertEquals('yellowgreen', $res); + } + + public function testGetNameFromHexBad(): void + { + $this->bcExpectException('\\' . \Com\Tecnick\Color\Exception::class); + $web = $this->getTestObject(); + $web->getNameFromHex('012345'); + } + + public function testExtractHexCode(): void + { + $web = $this->getTestObject(); + $res = $web->extractHexCode('abc'); + $this->assertEquals('aabbccff', $res); + $res = $web->extractHexCode('#abc'); + $this->assertEquals('aabbccff', $res); + $res = $web->extractHexCode('abcd'); + $this->assertEquals('aabbccdd', $res); + $res = $web->extractHexCode('#abcd'); + $this->assertEquals('aabbccdd', $res); + $res = $web->extractHexCode('112233'); + $this->assertEquals('112233ff', $res); + $res = $web->extractHexCode('#112233'); + $this->assertEquals('112233ff', $res); + $res = $web->extractHexCode('11223344'); + $this->assertEquals('11223344', $res); + $res = $web->extractHexCode('#11223344'); + $this->assertEquals('11223344', $res); + } + + public function testExtractHexCodeBad(): void + { + $this->bcExpectException('\\' . \Com\Tecnick\Color\Exception::class); + $web = $this->getTestObject(); + $web->extractHexCode(''); + } + + public function testGetRgbObjFromHex(): void + { + $web = $this->getTestObject(); + $rgb = $web->getRgbObjFromHex('#87ceebff'); + $this->assertEquals('#87ceebff', $rgb->getRgbaHexColor()); + } + + public function testGetRgbObjFromHexBad(): void + { + $this->bcExpectException('\\' . \Com\Tecnick\Color\Exception::class); + $web = $this->getTestObject(); + $web->getRgbObjFromHex('xx'); + } + + public function testGetRgbObjFromName(): void + { + $web = $this->getTestObject(); + $rgb = $web->getRgbObjFromName('skyblue'); + $this->assertEquals('#87ceebff', $rgb->getRgbaHexColor()); + } + + public function testGetRgbObjFromNameBad(): void + { + $this->bcExpectException('\\' . \Com\Tecnick\Color\Exception::class); + $web = $this->getTestObject(); + $web->getRgbObjFromName('xx'); + } + + public function testNormalizeValue(): void + { + $web = $this->getTestObject(); + $res = $web->normalizeValue('50%', 50); + $this->assertEquals(0.5, $res); + $res = $web->normalizeValue(128, 255); + $this->bcAssertEqualsWithDelta(0.5, $res); + } + + public function testGetColorObj(): void + { + $web = $this->getTestObject(); + $res = $web->getColorObj(''); + $this->assertNull($res); + $res = $web->getColorObj('t()'); + $this->assertNull($res); + $res = $web->getColorObj('["T"]'); + $this->assertNull($res); + $res = $web->getColorObj('transparent'); + $this->assertNull($res); + $res = $web->getColorObj('color.transparent'); + $this->assertNull($res); + $res = $web->getColorObj('royalblue'); + $this->assertNotNull($res); + $this->assertEquals('#4169e1ff', $res->getRgbaHexColor()); + $res = $web->getColorObj('#1a2b3c4d'); + $this->assertNotNull($res); + $this->assertEquals('#1a2b3c4d', $res->getRgbaHexColor()); + $res = $web->getColorObj('#1a2b3c'); + $this->assertNotNull($res); + $this->assertEquals('#1a2b3cff', $res->getRgbaHexColor()); + $res = $web->getColorObj('#1234'); + $this->assertNotNull($res); + $this->assertEquals('#11223344', $res->getRgbaHexColor()); + $res = $web->getColorObj('#123'); + $this->assertNotNull($res); + $this->assertEquals('#112233ff', $res->getRgbaHexColor()); + $res = $web->getColorObj('["G",0.5]'); + $this->assertNotNull($res); + $this->assertEquals('#808080ff', $res->getRgbaHexColor()); + $res = $web->getColorObj('["RGB",0.25,0.50,0.75]'); + $this->assertNotNull($res); + $this->assertEquals('#4080bfff', $res->getRgbaHexColor()); + $res = $web->getColorObj('["CMYK",0.666,0.333,0,0.25]'); + $this->assertNotNull($res); + $this->assertEquals('#4080bfff', $res->getRgbaHexColor()); + $res = $web->getColorObj('g(50%)'); + $this->assertNotNull($res); + $this->assertEquals('#808080ff', $res->getRgbaHexColor()); + $res = $web->getColorObj('g(128)'); + $this->assertNotNull($res); + $this->assertEquals('#808080ff', $res->getRgbaHexColor()); + $res = $web->getColorObj('rgb(25%,50%,75%)'); + $this->assertNotNull($res); + $this->assertEquals('#4080bfff', $res->getRgbaHexColor()); + $res = $web->getColorObj('rgb(64,128,191)'); + $this->assertNotNull($res); + $this->assertEquals('#4080bfff', $res->getRgbaHexColor()); + $res = $web->getColorObj('rgba(25%,50%,75%,0.85)'); + $this->assertNotNull($res); + $this->assertEquals('#4080bfd9', $res->getRgbaHexColor()); + $res = $web->getColorObj('rgba(64,128,191,0.85)'); + $this->assertNotNull($res); + $this->assertEquals('#4080bfd9', $res->getRgbaHexColor()); + $res = $web->getColorObj('hsl(210,50%,50%)'); + $this->assertNotNull($res); + $this->assertEquals('#4080bfff', $res->getRgbaHexColor()); + $res = $web->getColorObj('hsla(210,50%,50%,0.85)'); + $this->assertNotNull($res); + $this->assertEquals('#4080bfd9', $res->getRgbaHexColor()); + $res = $web->getColorObj('cmyk(67%,33%,0,25%)'); + $this->assertNotNull($res); + $this->assertEquals('#3f80bfff', $res->getRgbaHexColor()); + $res = $web->getColorObj('cmyk(67,33,0,25)'); + $this->assertNotNull($res); + $this->assertEquals('#3f80bfff', $res->getRgbaHexColor()); + $res = $web->getColorObj('cmyka(67,33,0,25,0.85)'); + $this->assertNotNull($res); + $this->assertEquals('#3f80bfd9', $res->getRgbaHexColor()); + $res = $web->getColorObj('cmyka(67%,33%,0,25%,0.85)'); + $this->assertNotNull($res); + $this->assertEquals('#3f80bfd9', $res->getRgbaHexColor()); + } + + /** + * @return array + */ + public static function getBadColor(): array + { + return [['g(-)'], ['rgb(-)'], ['hsl(-)'], ['cmyk(-)']]; + } + + + #[DataProvider('getBadColor')] + public function testGetColorObjBad(string $bad): void + { + $this->bcExpectException('\\' . \Com\Tecnick\Color\Exception::class); + $web = $this->getTestObject(); + $web->getColorObj($bad); + } + + public function testGetRgbSquareDistance(): void + { + $web = $this->getTestObject(); + $cola = [ + 'red' => 0, + 'green' => 0, + 'blue' => 0, + ]; + $colb = [ + 'red' => 1, + 'green' => 1, + 'blue' => 1, + ]; + $dist = $web->getRgbSquareDistance($cola, $colb); + $this->assertEquals(3, $dist); + + $cola = [ + 'red' => 0.5, + 'green' => 0.5, + 'blue' => 0.5, + ]; + $colb = [ + 'red' => 0.5, + 'green' => 0.5, + 'blue' => 0.5, + ]; + $dist = $web->getRgbSquareDistance($cola, $colb); + $this->assertEquals(0, $dist); + + $cola = [ + 'red' => 0.25, + 'green' => 0.50, + 'blue' => 0.75, + ]; + $colb = [ + 'red' => 0.50, + 'green' => 0.75, + 'blue' => 1.00, + ]; + $dist = $web->getRgbSquareDistance($cola, $colb); + $this->assertEquals(0.1875, $dist); + } + + public function testGetClosestWebColor(): void + { + $web = $this->getTestObject(); + $col = [ + 'red' => 1, + 'green' => 0, + 'blue' => 0, + ]; + $color = $web->getClosestWebColor($col); + $this->assertEquals('red', $color); + + $col = [ + 'red' => 0, + 'green' => 1, + 'blue' => 0, + ]; + $color = $web->getClosestWebColor($col); + $this->assertEquals('lime', $color); + + $col = [ + 'red' => 0, + 'green' => 0, + 'blue' => 1, + ]; + $color = $web->getClosestWebColor($col); + $this->assertEquals('blue', $color); + + $col = [ + 'red' => 0.33, + 'green' => 0.4, + 'blue' => 0.18, + ]; + $color = $web->getClosestWebColor($col); + $this->assertEquals('darkolivegreen', $color); + } +}