From cb46c29481b082c3313baa8c30077250bb900b7e Mon Sep 17 00:00:00 2001 From: Daniel Lenski Date: Fri, 14 Apr 2023 11:43:44 -0700 Subject: [PATCH] use latest ZXing release (3.5.1) and JCommander release (1.82) MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit Release 3.5.0 finally includes all of the improvements that I contributed in 2020 🙌 - https://github.com/zxing/zxing/pull/1333 (decode PDF417 barcodes rotated 90° or 270°) - https://github.com/zxing/zxing/pull/1330 (Aztec encoding of non-default charsets) - https://github.com/zxing/zxing/pull/1328 (Aztec decoding of non-default charsets) Added a test image to verify this. --- README.md | 4 ++-- setup.py | 6 +++--- test/barcodes/AZTEC-utf8.png | Bin 0 -> 195 bytes test/test_all.py | 1 + 4 files changed, 6 insertions(+), 5 deletions(-) create mode 100644 test/barcodes/AZTEC-utf8.png diff --git a/README.md b/README.md index 342fa7e..f51869b 100644 --- a/README.md +++ b/README.md @@ -12,7 +12,7 @@ It will allow you to read and decode barcode images from Python. Use the Python 3 version of pip (usually invoked via `pip3`) to install: `pip3 install zxing` * You'll neeed to have a recent `java` binary somewhere in your path. (Tested with OpenJDK v7, v8, v11.) -* pip will automatically download the relevant [JAR](https://en.wikipedia.org/wiki/JAR_(file_format)) files for the Java ZXing libraries (currently v3.4.1) +* pip will automatically download the relevant [JAR](https://en.wikipedia.org/wiki/JAR_(file_format)) files for the Java ZXing libraries (currently v3.5.1) ## Usage @@ -22,7 +22,7 @@ The `BarCodeReader` class is used to decode images: >>> import zxing >>> reader = zxing.BarCodeReader() >>> print(reader.zxing_version, reader.zxing_version_info) -3.4.1 (3, 4, 1) +3.5.1 (3, 5, 1) >>> barcode = reader.decode("test/barcodes/QR_CODE-easy.png") >>> print(barcode) BarCode(raw='This should be QR_CODE', parsed='This should be QR_CODE', path='test/barcodes/QR_CODE-easy.png', format='QR_CODE', type='TEXT', points=[(15.0, 87.0), (15.0, 15.0), (87.0, 15.0), (75.0, 75.0)]) diff --git a/setup.py b/setup.py index 4039973..82e3e6f 100644 --- a/setup.py +++ b/setup.py @@ -23,9 +23,9 @@ def download_java_files(force=False): - files = {'java/javase.jar': 'https://repo1.maven.org/maven2/com/google/zxing/javase/3.4.1/javase-3.4.1.jar', - 'java/core.jar': 'https://repo1.maven.org/maven2/com/google/zxing/core/3.4.1/core-3.4.1.jar', - 'java/jcommander.jar': 'https://repo1.maven.org/maven2/com/beust/jcommander/1.78/jcommander-1.78.jar'} + files = {'java/javase.jar': 'https://repo1.maven.org/maven2/com/google/zxing/javase/3.5.1/javase-3.5.1.jar', + 'java/core.jar': 'https://repo1.maven.org/maven2/com/google/zxing/core/3.5.1/core-3.5.1.jar', + 'java/jcommander.jar': 'https://repo1.maven.org/maven2/com/beust/jcommander/1.82/jcommander-1.82.jar'} for fn, url in files.items(): p = path.join(path.dirname(__file__), 'zxing', fn) diff --git a/test/barcodes/AZTEC-utf8.png b/test/barcodes/AZTEC-utf8.png new file mode 100644 index 0000000000000000000000000000000000000000..b72554e6c19aa9fa8434a10e69e63e14fc8b613e GIT binary patch literal 195 zcmeAS@N?(olH%oJU|`_&^l%9R(rO^g2qYL9+^#SKsWwj+$B>FSre_R!xtbjWS|4sd zXLhK;(uGgq$fXcDh2tkod6x->eN$l+XPrIK_u=h#k3XK@G3SGoHbcW^zy6th)qmIN zD|;Jn-SYB=n7c#9{8^8#6P;9r_QY4Y>)mX?gwcaQwI uEWg43mdKI;VstUM>KLHc;&V literal 0 HcmV?d00001 diff --git a/test/test_all.py b/test/test_all.py index 06d1b64..45ca26e 100644 --- a/test/test_all.py +++ b/test/test_all.py @@ -16,6 +16,7 @@ ('CODE_128-easy.jpg', 'CODE_128', 'This should be CODE_128'), ('PDF_417-easy.bmp', 'PDF_417', 'This should be PDF_417'), ('AZTEC-easy.jpg', 'AZTEC', 'This should be AZTEC'), + ('AZTEC-utf8.png', 'AZTEC', 'L’état, c’est moi'), ('QR CODE (¡filenáme törture test! 😉).png', 'QR_CODE', 'This should be QR_CODE'), ('QR_CODE-png-but-wrong-extension.bmp', 'QR_CODE', 'This should be QR_CODE'), ('QR_CODE-fun-with-whitespace.png', 'QR_CODE', '\n\r\t\r\r\r\n '),