diff --git a/qt6-qtsvg.spec b/qt6-qtsvg.spec index d23979b..0d5fb90 100644 --- a/qt6-qtsvg.spec +++ b/qt6-qtsvg.spec @@ -24,12 +24,6 @@ Source0: https://download.qt.io/development_releases/qt/%{majmin}/%{qt_version}/ Source0: https://download.qt.io/official_releases/qt/%{majmin}/%{version}/submodules/%{qt_module}-everywhere-src-%{version}.tar.xz %endif -# QTBUG-117944 -# QML Image bad source crashes application instead of error status (QSvgHandler::parse) -Patch0: qtsvg-fix-nullptr-dereference-with-invalid-svg.patch -Patch1: qtsvg-make-sure-we-dont-load-invalid-svg-twice.patch -Patch2: qtsvg-verify-loading-of-invalid-svg-files-dont-crash.patch - # filter plugin provides %global __provides_exclude_from ^%{_qt6_plugindir}/.*\\.so$ diff --git a/qtsvg-fix-nullptr-dereference-with-invalid-svg.patch b/qtsvg-fix-nullptr-dereference-with-invalid-svg.patch deleted file mode 100644 index c6b6d7f..0000000 --- a/qtsvg-fix-nullptr-dereference-with-invalid-svg.patch +++ /dev/null @@ -1,26 +0,0 @@ -From effc44495a33babd4cf7a2044123f420e6b3da1c Mon Sep 17 00:00:00 2001 -From: Paul Olav Tvete -Date: Tue, 10 Oct 2023 10:14:22 +0200 -Subject: [PATCH] Fix nullptr dereference with invalid SVG - -Fixes: QTBUG-117944 -Pick-to: 6.5 6.2 -Change-Id: I9059dc28c750fc0585f1fb982152b211c323c6cd -Reviewed-by: Eskil Abrahamsen Blomfeldt -(cherry picked from commit edc8ca7f1e45302223b4b7962a57a30918f84c8d) -Reviewed-by: Qt Cherry-pick Bot ---- - -diff --git a/src/svg/qsvghandler.cpp b/src/svg/qsvghandler.cpp -index 2649422..335500a 100644 ---- a/src/svg/qsvghandler.cpp -+++ b/src/svg/qsvghandler.cpp -@@ -3606,6 +3606,8 @@ - - static bool detectCycles(const QSvgNode *node, QList active = {}) - { -+ if (Q_UNLIKELY(!node)) -+ return false; - switch (node->type()) { - case QSvgNode::DOC: - case QSvgNode::G: diff --git a/qtsvg-make-sure-we-dont-load-invalid-svg-twice.patch b/qtsvg-make-sure-we-dont-load-invalid-svg-twice.patch deleted file mode 100644 index 5994585..0000000 --- a/qtsvg-make-sure-we-dont-load-invalid-svg-twice.patch +++ /dev/null @@ -1,76 +0,0 @@ -From 0bfb420574f192a097c7ab3dbdd452b39464dc84 Mon Sep 17 00:00:00 2001 -From: Paul Olav Tvete -Date: Tue, 10 Oct 2023 11:41:41 +0200 -Subject: [PATCH] Make sure we don't load invalid SVGs twice - -Fixes a bug where loading an invalid SVG that happens -to be valid XML could behave differently in QML and C++, -because readimage() in qquickpixmapcache.cpp calls -QImageReader::size() twice. - -Task-number: QTBUG-117944 -Pick-to: 6.5 -Change-Id: Ibef7f54627c76414c66f81804f5f46f2db3594ba -Reviewed-by: Eirik Aavitsland -Reviewed-by: Qt CI Bot -(cherry picked from commit a090bd1f9a7bfa14f06b14570c6a5a37843931c6) -Reviewed-by: Qt Cherry-pick Bot ---- - -diff --git a/src/plugins/imageformats/svg/qsvgiohandler.cpp b/src/plugins/imageformats/svg/qsvgiohandler.cpp -index b04ee6b..570c982 100644 ---- a/src/plugins/imageformats/svg/qsvgiohandler.cpp -+++ b/src/plugins/imageformats/svg/qsvgiohandler.cpp -@@ -19,7 +19,7 @@ - { - public: - QSvgIOHandlerPrivate(QSvgIOHandler *qq) -- : q(qq), loaded(false), readDone(false), backColor(Qt::transparent) -+ : q(qq), loadAttempted(false), loadStatus(false), readDone(false), backColor(Qt::transparent) - {} - - bool load(QIODevice *device); -@@ -31,7 +31,8 @@ - QRect clipRect; - QSize scaledSize; - QRect scaledClipRect; -- bool loaded; -+ bool loadAttempted; -+ bool loadStatus; - bool readDone; - QColor backColor; - }; -@@ -39,8 +40,9 @@ - - bool QSvgIOHandlerPrivate::load(QIODevice *device) - { -- if (loaded) -- return true; -+ if (loadAttempted) -+ return loadStatus; -+ loadAttempted = true; - if (q->format().isEmpty()) - q->canRead(); - -@@ -63,10 +65,10 @@ - - if (res) { - defaultSize = r.defaultSize(); -- loaded = true; -+ loadStatus = true; - } - -- return loaded; -+ return loadStatus; - } - - -@@ -105,7 +107,7 @@ - { - if (!device()) - return false; -- if (d->loaded && !d->readDone) -+ if (d->loadStatus && !d->readDone) - return true; // Will happen if we have been asked for the size - - bool isCompressed = false; diff --git a/qtsvg-verify-loading-of-invalid-svg-files-dont-crash.patch b/qtsvg-verify-loading-of-invalid-svg-files-dont-crash.patch deleted file mode 100644 index 7c2d060..0000000 --- a/qtsvg-verify-loading-of-invalid-svg-files-dont-crash.patch +++ /dev/null @@ -1,115 +0,0 @@ -From f12f893931603bb6561149d813ca88b86e169ffd Mon Sep 17 00:00:00 2001 -From: Paul Olav Tvete -Date: Tue, 10 Oct 2023 14:25:19 +0200 -Subject: [PATCH] Verify that loading of invalid SVG files don't crash - -Also verify that we don't try to load invalid SVGs -twice. - -Pick-to: 6.5 -Task-number: QTBUG-117944 -Change-Id: If3938384940112510d64a675f58c1e4e97e74986 -Reviewed-by: Eskil Abrahamsen Blomfeldt -(cherry picked from commit 7eb8f63915a470b89b96eb274252543a22e774a7) -Reviewed-by: Qt Cherry-pick Bot ---- - -diff --git a/tests/auto/qsvgplugin/CMakeLists.txt b/tests/auto/qsvgplugin/CMakeLists.txt -index e678708..c913cd3 100644 ---- a/tests/auto/qsvgplugin/CMakeLists.txt -+++ b/tests/auto/qsvgplugin/CMakeLists.txt -@@ -37,6 +37,9 @@ - "simple_Utf16BE.svg" - "simple_Utf32LE.svg" - "simple_Utf32BE.svg" -+ "invalid_xml.svg" -+ "xml_not_svg.svg" -+ "invalid_then_valid.svg" - ) - - qt_internal_add_resource(tst_qsvgplugin "resources" -diff --git a/tests/auto/qsvgplugin/invalid_then_valid.svg b/tests/auto/qsvgplugin/invalid_then_valid.svg -new file mode 100644 -index 0000000..d09f598 ---- /dev/null -+++ b/tests/auto/qsvgplugin/invalid_then_valid.svg -@@ -0,0 +1,18 @@ -+ -+ -+ -+ -+ -+ -+ -+ -+ -+ -+ -+ -+ -+ -+ -+ -+ -+ -diff --git a/tests/auto/qsvgplugin/invalid_xml.svg b/tests/auto/qsvgplugin/invalid_xml.svg -new file mode 100644 -index 0000000..e0814ae ---- /dev/null -+++ b/tests/auto/qsvgplugin/invalid_xml.svg -@@ -0,0 +1,2 @@ -+ -+ -+ -+ -+ -+ -+ -+ -+ -+ -+ -+ -+