forked from pool/krita
ce2af6d313
- Add patches to support libjxl >= 0.9.0: * 0001-Fix-build-with-libjxl-0.9.0.patch * 0002-KisFileIconCreator-add-workaround-for-JPEG-XL-too.patch * 0003-JPEG-XL-Disable-export-bug-workaround-for-libjxl-0.9.patch OBS-URL: https://build.opensuse.org/request/show/1139885 OBS-URL: https://build.opensuse.org/package/show/KDE:Extra/krita?expand=0&rev=193
96 lines
5.5 KiB
Diff
96 lines
5.5 KiB
Diff
From 0bb4659b49ba3086cb757bd5db1839a91db9ffa9 Mon Sep 17 00:00:00 2001
|
|
From: Timo Gurr <timo.gurr@gmail.com>
|
|
Date: Fri, 5 Jan 2024 14:04:50 +0000
|
|
Subject: [PATCH 1/3] Fix build with libjxl 0.9.0
|
|
|
|
Fix build with libjxl 0.9.0
|
|
|
|
BUG:478987
|
|
|
|
Test Plan
|
|
---------
|
|
|
|
* Upgrade to libjxl 0.9.0
|
|
* Apply patch from MR and build krita (5.2.2)
|
|
* Open/Display a sample image e.g. https://jpegxl.info/test-page/red-room.jxl
|
|
|
|
Formalities Checklist
|
|
---------------------
|
|
|
|
- [x] I confirmed this builds.
|
|
- [x] I confirmed Krita ran and the relevant functions work (Could successfully open/display a sample image https://jpegxl.info/test-page/red-room.jxl).
|
|
- [ ] I tested the relevant unit tests and can confirm they are not broken. (If not possible, don't hesitate to ask for help!)
|
|
- [x] I made sure my commits build individually and have good descriptions as per [KDE guidelines](https://community.kde.org/Policies/Commit_Policy).
|
|
- [x] I made sure my code conforms to the standards set in the HACKING file.
|
|
- [x] I can confirm the code is licensed and attributed appropriately, and that unattributed code is mine, as per [KDE Licensing Policy](https://community.kde.org/Policies/Licensing_Policy).
|
|
|
|
_**Reminder: the reviewer is responsible for merging the patch, this is to ensure at the least two people can build the patch. In case a patch breaks the build, both the author and the reviewer should be contacted to fix the build.**_
|
|
_**If this is not possible, the commits shall be reverted, and a notification with the reasoning and any relevant logs shall be sent to the mailing list, kimageshop@kde.org.**_
|
|
|
|
(cherry picked from commit ace7edcca6ad322581ab39620f21ccf3ffbd3b5a)
|
|
---
|
|
plugins/impex/jxl/JPEGXLImport.cpp | 15 ++++++++++++++-
|
|
1 file changed, 14 insertions(+), 1 deletion(-)
|
|
|
|
diff --git a/plugins/impex/jxl/JPEGXLImport.cpp b/plugins/impex/jxl/JPEGXLImport.cpp
|
|
index 573bae412473..f5b989b3b704 100644
|
|
--- a/plugins/impex/jxl/JPEGXLImport.cpp
|
|
+++ b/plugins/impex/jxl/JPEGXLImport.cpp
|
|
@@ -511,7 +511,9 @@ JPEGXLImport::convert(KisDocument *document, QIODevice *io, KisPropertiesConfigu
|
|
JxlColorEncoding colorEncoding{};
|
|
if (JXL_DEC_SUCCESS
|
|
== JxlDecoderGetColorAsEncodedProfile(dec.get(),
|
|
+#if JPEGXL_NUMERIC_VERSION < JPEGXL_COMPUTE_NUMERIC_VERSION(0, 9, 0)
|
|
nullptr,
|
|
+#endif
|
|
JXL_COLOR_PROFILE_TARGET_DATA,
|
|
&colorEncoding)) {
|
|
const TransferCharacteristics transferFunction = [&]() {
|
|
@@ -635,7 +637,12 @@ JPEGXLImport::convert(KisDocument *document, QIODevice *io, KisPropertiesConfigu
|
|
size_t iccSize = 0;
|
|
QByteArray iccProfile;
|
|
if (JXL_DEC_SUCCESS
|
|
- != JxlDecoderGetICCProfileSize(dec.get(), nullptr, JXL_COLOR_PROFILE_TARGET_DATA, &iccSize)) {
|
|
+ != JxlDecoderGetICCProfileSize(dec.get(),
|
|
+#if JPEGXL_NUMERIC_VERSION < JPEGXL_COMPUTE_NUMERIC_VERSION(0,9,0)
|
|
+ nullptr,
|
|
+#endif
|
|
+ JXL_COLOR_PROFILE_TARGET_DATA,
|
|
+ &iccSize)) {
|
|
errFile << "ICC profile size retrieval failed";
|
|
document->setErrorMessage(i18nc("JPEG-XL errors", "Unable to read the image profile."));
|
|
return ImportExportCodes::ErrorWhileReading;
|
|
@@ -643,7 +650,9 @@ JPEGXLImport::convert(KisDocument *document, QIODevice *io, KisPropertiesConfigu
|
|
iccProfile.resize(static_cast<int>(iccSize));
|
|
if (JXL_DEC_SUCCESS
|
|
!= JxlDecoderGetColorAsICCProfile(dec.get(),
|
|
+#if JPEGXL_NUMERIC_VERSION < JPEGXL_COMPUTE_NUMERIC_VERSION(0,9,0)
|
|
nullptr,
|
|
+#endif
|
|
JXL_COLOR_PROFILE_TARGET_DATA,
|
|
reinterpret_cast<uint8_t *>(iccProfile.data()),
|
|
static_cast<size_t>(iccProfile.size()))) {
|
|
@@ -657,7 +666,9 @@ JPEGXLImport::convert(KisDocument *document, QIODevice *io, KisPropertiesConfigu
|
|
if (!d.m_info.uses_original_profile) {
|
|
if (JXL_DEC_SUCCESS
|
|
!= JxlDecoderGetICCProfileSize(dec.get(),
|
|
+#if JPEGXL_NUMERIC_VERSION < JPEGXL_COMPUTE_NUMERIC_VERSION(0,9,0)
|
|
nullptr,
|
|
+#endif
|
|
JXL_COLOR_PROFILE_TARGET_ORIGINAL,
|
|
&iccTargetSize)) {
|
|
errFile << "ICC profile size retrieval failed";
|
|
@@ -667,7 +678,9 @@ JPEGXLImport::convert(KisDocument *document, QIODevice *io, KisPropertiesConfigu
|
|
iccTargetProfile.resize(static_cast<int>(iccTargetSize));
|
|
if (JXL_DEC_SUCCESS
|
|
!= JxlDecoderGetColorAsICCProfile(dec.get(),
|
|
+#if JPEGXL_NUMERIC_VERSION < JPEGXL_COMPUTE_NUMERIC_VERSION(0,9,0)
|
|
nullptr,
|
|
+#endif
|
|
JXL_COLOR_PROFILE_TARGET_ORIGINAL,
|
|
reinterpret_cast<uint8_t *>(iccTargetProfile.data()),
|
|
static_cast<size_t>(iccTargetProfile.size()))) {
|
|
--
|
|
2.43.0
|
|
|