From 934c44b3c3fe2d609990e83c56c74383725b0a21 Mon Sep 17 00:00:00 2001 From: nulano Date: Mon, 12 Oct 2020 02:02:59 +0100 Subject: [PATCH 1/2] -Werror=implicit-function-declaration --- Makefile | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/Makefile b/Makefile index cbee5923b..4fd031b69 100644 --- a/Makefile +++ b/Makefile @@ -64,7 +64,7 @@ install: .PHONY: install-coverage install-coverage: - CFLAGS="-coverage" python3 setup.py build_ext install + CFLAGS="-coverage -Werror=implicit-function-declaration" python3 setup.py build_ext install python3 selftest.py .PHONY: debug From 40c9a5a2a0266979d8b915007361e928daddfbc7 Mon Sep 17 00:00:00 2001 From: nulano Date: Mon, 12 Oct 2020 02:58:08 +0100 Subject: [PATCH 2/2] compatibility for LCMS<2.7, vix LCMS version string --- Tests/test_imagecms.py | 2 +- src/PIL/features.py | 7 ++++++- src/_imagingcms.c | 10 +++++++++- 3 files changed, 16 insertions(+), 3 deletions(-) diff --git a/Tests/test_imagecms.py b/Tests/test_imagecms.py index 72f732d78..9fab41746 100644 --- a/Tests/test_imagecms.py +++ b/Tests/test_imagecms.py @@ -48,7 +48,7 @@ def test_sanity(): assert list(map(type, v)) == [str, str, str, str] # internal version number - assert re.search(r"\d+\.\d+$", features.version_module("littlecms2")) + assert re.search(r"\d+\.\d+(\.\d+)?$", features.version_module("littlecms2")) skip_missing() i = ImageCms.profileToProfile(hopper(), SRGB, SRGB) diff --git a/src/PIL/features.py b/src/PIL/features.py index fa86b9cb0..c2df9c525 100644 --- a/src/PIL/features.py +++ b/src/PIL/features.py @@ -224,6 +224,8 @@ def pilinfo(out=None, supported_formats=True): If ``True``, a list of all supported image file formats will be printed. """ + from pkg_resources import parse_version + if out is None: out = sys.stdout @@ -269,7 +271,10 @@ def pilinfo(out=None, supported_formats=True): else: v = version(name) if v is not None: - t = "compiled for" if name in ("pil", "jpg") else "loaded" + version_static = name in ("pil", "jpg") + if name == "littlecms2": + version_static = parse_version(v) < parse_version("2.7.0") + t = "compiled for" if version_static else "loaded" print("---", feature, "support ok,", t, v, file=out) else: print("---", feature, "support ok", file=out) diff --git a/src/_imagingcms.c b/src/_imagingcms.c index cba41ec90..59c7318a9 100644 --- a/src/_imagingcms.c +++ b/src/_imagingcms.c @@ -1512,8 +1512,16 @@ setup_module(PyObject* m) { d = PyModule_GetDict(m); +#if LCMS_VERSION < 2070 + vn = LCMS_VERSION; +#else vn = cmsGetEncodedCMMversion(); - v = PyUnicode_FromFormat("%d.%d", vn / 100, vn % 100); +#endif + if (vn % 10) { + v = PyUnicode_FromFormat("%d.%d.%d", vn / 1000, (vn / 10) % 100, vn % 10); + } else { + v = PyUnicode_FromFormat("%d.%d", vn / 1000, (vn / 10) % 100); + } PyDict_SetItemString(d, "littlecms_version", v); return 0;