Backport fixes from Qt patch collection
This commit is contained in:
parent
e95c09f61c
commit
d5c1a8e92e
182
0001-Unset-mouseGrabberPopup-if-it-s-removed-from-childre.patch
Normal file
182
0001-Unset-mouseGrabberPopup-if-it-s-removed-from-childre.patch
Normal file
@ -0,0 +1,182 @@
|
|||||||
|
From bfdaef37a08a24f043e7b24023ae3835e03ef68a Mon Sep 17 00:00:00 2001
|
||||||
|
From: David Redondo <qt@david-redondo.de>
|
||||||
|
Date: Mon, 19 Jul 2021 10:06:17 +0200
|
||||||
|
Subject: [PATCH 1/6] Unset mouseGrabberPopup if it's removed from children
|
||||||
|
|
||||||
|
The mouseGrabberPopup is supposed to be unset in handleRelease, however
|
||||||
|
when the exit transition of the mouseGrabberPopup (that closed itself on
|
||||||
|
button press) finishes before the release event is delivered, it
|
||||||
|
unparents itself from the overlay (see
|
||||||
|
QQuickPopupPrivate::finalizeExitTransition) and the overlay sets itself
|
||||||
|
invisible if there is nothing else visible in it. Because the overlay
|
||||||
|
is not visible it handles no events anymore and the release is missed
|
||||||
|
and the grabber is never unset. When opening another non-modal popup
|
||||||
|
the overlay then will continue forwarding the events to now invisible
|
||||||
|
popup.
|
||||||
|
So when the overlay loses the currently grabbing popup as a child we need
|
||||||
|
to reset mouseGrabberPopup.
|
||||||
|
|
||||||
|
Fixes: QTBUG-95259
|
||||||
|
Change-Id: I3c832d47f3cee216b81ef1b5cb7dd77bf4149991
|
||||||
|
Reviewed-by: Mitch Curtis <mitch.curtis@qt.io>
|
||||||
|
(adapted from commit d07ee1345acd8100fa5cbb7f05c0aaf5f87f4cae)
|
||||||
|
|
||||||
|
(cherry picked from commit 1a59ef4218658ffc476909ef4fca13d6cf86d04b)
|
||||||
|
---
|
||||||
|
src/quicktemplates2/qquickoverlay.cpp | 5 +-
|
||||||
|
.../data/releaseAfterExitTransition.qml | 78 +++++++++++++++++++
|
||||||
|
tests/auto/qquickpopup/tst_qquickpopup.cpp | 29 +++++++
|
||||||
|
3 files changed, 111 insertions(+), 1 deletion(-)
|
||||||
|
create mode 100644 tests/auto/qquickpopup/data/releaseAfterExitTransition.qml
|
||||||
|
|
||||||
|
diff --git a/src/quicktemplates2/qquickoverlay.cpp b/src/quicktemplates2/qquickoverlay.cpp
|
||||||
|
index b8d417f29..c8cd142ae 100644
|
||||||
|
--- a/src/quicktemplates2/qquickoverlay.cpp
|
||||||
|
+++ b/src/quicktemplates2/qquickoverlay.cpp
|
||||||
|
@@ -399,8 +399,11 @@ void QQuickOverlay::itemChange(ItemChange change, const ItemChangeData &data)
|
||||||
|
Q_D(QQuickOverlay);
|
||||||
|
QQuickItem::itemChange(change, data);
|
||||||
|
|
||||||
|
- if (change == ItemChildAddedChange || change == ItemChildRemovedChange)
|
||||||
|
+ if (change == ItemChildAddedChange || change == ItemChildRemovedChange) {
|
||||||
|
setVisible(!d->allDrawers.isEmpty() || !childItems().isEmpty());
|
||||||
|
+ if (data.item->parent() == d->mouseGrabberPopup)
|
||||||
|
+ d->setMouseGrabberPopup(nullptr);
|
||||||
|
+ }
|
||||||
|
}
|
||||||
|
|
||||||
|
void QQuickOverlay::geometryChanged(const QRectF &newGeometry, const QRectF &oldGeometry)
|
||||||
|
diff --git a/tests/auto/qquickpopup/data/releaseAfterExitTransition.qml b/tests/auto/qquickpopup/data/releaseAfterExitTransition.qml
|
||||||
|
new file mode 100644
|
||||||
|
index 000000000..9e4598b9f
|
||||||
|
--- /dev/null
|
||||||
|
+++ b/tests/auto/qquickpopup/data/releaseAfterExitTransition.qml
|
||||||
|
@@ -0,0 +1,78 @@
|
||||||
|
+/****************************************************************************
|
||||||
|
+**
|
||||||
|
+** Copyright (C) 2021 The Qt Company Ltd.
|
||||||
|
+** Contact: https://www.qt.io/licensing/
|
||||||
|
+**
|
||||||
|
+** This file is part of the test suite of the Qt Toolkit.
|
||||||
|
+**
|
||||||
|
+** $QT_BEGIN_LICENSE:BSD$
|
||||||
|
+** Commercial License Usage
|
||||||
|
+** Licensees holding valid commercial Qt licenses may use this file in
|
||||||
|
+** accordance with the commercial license agreement provided with the
|
||||||
|
+** Software or, alternatively, in accordance with the terms contained in
|
||||||
|
+** a written agreement between you and The Qt Company. For licensing terms
|
||||||
|
+** and conditions see https://www.qt.io/terms-conditions. For further
|
||||||
|
+** information use the contact form at https://www.qt.io/contact-us.
|
||||||
|
+**
|
||||||
|
+** BSD License Usage
|
||||||
|
+** Alternatively, you may use this file under the terms of the BSD license
|
||||||
|
+** as follows:
|
||||||
|
+**
|
||||||
|
+** "Redistribution and use in source and binary forms, with or without
|
||||||
|
+** modification, are permitted provided that the following conditions are
|
||||||
|
+** met:
|
||||||
|
+** * Redistributions of source code must retain the above copyright
|
||||||
|
+** notice, this list of conditions and the following disclaimer.
|
||||||
|
+** * Redistributions in binary form must reproduce the above copyright
|
||||||
|
+** notice, this list of conditions and the following disclaimer in
|
||||||
|
+** the documentation and/or other materials provided with the
|
||||||
|
+** distribution.
|
||||||
|
+** * Neither the name of The Qt Company Ltd nor the names of its
|
||||||
|
+** contributors may be used to endorse or promote products derived
|
||||||
|
+** from this software without specific prior written permission.
|
||||||
|
+**
|
||||||
|
+**
|
||||||
|
+** THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
|
||||||
|
+** "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
|
||||||
|
+** LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
|
||||||
|
+** A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
|
||||||
|
+** OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
|
||||||
|
+** SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
|
||||||
|
+** LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
|
||||||
|
+** DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
|
||||||
|
+** THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
|
||||||
|
+** (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
|
||||||
|
+** OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE."
|
||||||
|
+**
|
||||||
|
+** $QT_END_LICENSE$
|
||||||
|
+**
|
||||||
|
+****************************************************************************/
|
||||||
|
+
|
||||||
|
+import QtQuick 2.15
|
||||||
|
+import QtQuick.Controls 2.15
|
||||||
|
+
|
||||||
|
+ApplicationWindow {
|
||||||
|
+ id: window
|
||||||
|
+ width: 400
|
||||||
|
+ height: 400
|
||||||
|
+ title: "releaseAfterExitTransition"
|
||||||
|
+
|
||||||
|
+ property alias popup: popup
|
||||||
|
+ property alias modalPopup: modalPopup
|
||||||
|
+
|
||||||
|
+ Popup {
|
||||||
|
+ id: popup
|
||||||
|
+ y: parent.height - height
|
||||||
|
+ width: 50
|
||||||
|
+ height: 50
|
||||||
|
+ }
|
||||||
|
+
|
||||||
|
+ Popup {
|
||||||
|
+ id: modalPopup
|
||||||
|
+ modal: true
|
||||||
|
+ y: parent.height - height
|
||||||
|
+ width: 50
|
||||||
|
+ height: 50
|
||||||
|
+ exit: Transition { PauseAnimation { duration: 100 } }
|
||||||
|
+ }
|
||||||
|
+}
|
||||||
|
diff --git a/tests/auto/qquickpopup/tst_qquickpopup.cpp b/tests/auto/qquickpopup/tst_qquickpopup.cpp
|
||||||
|
index ede3640c2..f1840946b 100644
|
||||||
|
--- a/tests/auto/qquickpopup/tst_qquickpopup.cpp
|
||||||
|
+++ b/tests/auto/qquickpopup/tst_qquickpopup.cpp
|
||||||
|
@@ -97,6 +97,7 @@ private slots:
|
||||||
|
void invisibleToolTipOpen();
|
||||||
|
void centerInOverlayWithinStackViewItem();
|
||||||
|
void destroyDuringExitTransition();
|
||||||
|
+ void releaseAfterExitTransition();
|
||||||
|
};
|
||||||
|
|
||||||
|
void tst_QQuickPopup::initTestCase()
|
||||||
|
@@ -1459,6 +1460,34 @@ void tst_QQuickPopup::destroyDuringExitTransition()
|
||||||
|
QVERIFY(!button->isDown());
|
||||||
|
}
|
||||||
|
|
||||||
|
+void tst_QQuickPopup::releaseAfterExitTransition()
|
||||||
|
+{
|
||||||
|
+ QQuickApplicationHelper helper(this, "releaseAfterExitTransition.qml");
|
||||||
|
+ QVERIFY2(helper.ready, helper.failureMessage());
|
||||||
|
+
|
||||||
|
+ QQuickWindow *window = helper.window;
|
||||||
|
+ window->show();
|
||||||
|
+ QVERIFY(QTest::qWaitForWindowActive(window));
|
||||||
|
+
|
||||||
|
+ QQuickOverlay *overlay = QQuickOverlay::overlay(window);
|
||||||
|
+ QQuickPopup *modalPopup = window->property("modalPopup").value<QQuickPopup *>();
|
||||||
|
+ QQuickPopup *popup = window->property("popup").value<QQuickPopup *>();
|
||||||
|
+
|
||||||
|
+ modalPopup->open();
|
||||||
|
+ QTRY_VERIFY(modalPopup->isOpened());
|
||||||
|
+
|
||||||
|
+ QTest::mousePress(window, Qt::LeftButton, Qt::NoModifier, QPoint(1, 1));
|
||||||
|
+ // wait until the transition is finished and the overlay hides itself
|
||||||
|
+ QTRY_VERIFY(!overlay->isVisible());
|
||||||
|
+ QTest::mouseRelease(window, Qt::LeftButton, Qt::NoModifier, QPoint(1, 1));
|
||||||
|
+
|
||||||
|
+ popup->open();
|
||||||
|
+ QTRY_VERIFY(popup->isOpened());
|
||||||
|
+ QTest::mouseClick(window, Qt::LeftButton, Qt::NoModifier, QPoint(1, 1));
|
||||||
|
+ QTRY_VERIFY(!popup->isOpened());
|
||||||
|
+}
|
||||||
|
+
|
||||||
|
+
|
||||||
|
QTEST_QUICKCONTROLS_MAIN(tst_QQuickPopup)
|
||||||
|
|
||||||
|
#include "tst_qquickpopup.moc"
|
||||||
|
--
|
||||||
|
2.37.2
|
||||||
|
|
@ -0,0 +1,83 @@
|
|||||||
|
From d652727e3564d3a5f21788d9f75f903efbd4840c Mon Sep 17 00:00:00 2001
|
||||||
|
From: Aleix Pol <aleixpol@kde.org>
|
||||||
|
Date: Tue, 4 Jan 2022 16:34:16 +0100
|
||||||
|
Subject: [PATCH 2/6] Ensure we don't crash when changing sizes after cleanup
|
||||||
|
|
||||||
|
This addresses the problems I've seen during destruction. Only
|
||||||
|
encountered it when using complex layouts on a DialogButtonBox.
|
||||||
|
|
||||||
|
Pick-to: 6.2 6.3
|
||||||
|
Change-Id: I54528c8a2b57b4798d90f7e2021e3127f8404762
|
||||||
|
(cherry picked from commit 8b24d2bf1655e8491bdd74013579e09cd009e8fc in
|
||||||
|
qtdeclarative)
|
||||||
|
---
|
||||||
|
src/quicktemplates2/qquickcontainer.cpp | 5 +++--
|
||||||
|
src/quicktemplates2/qquickdialogbuttonbox.cpp | 8 +++++++-
|
||||||
|
2 files changed, 10 insertions(+), 3 deletions(-)
|
||||||
|
|
||||||
|
diff --git a/src/quicktemplates2/qquickcontainer.cpp b/src/quicktemplates2/qquickcontainer.cpp
|
||||||
|
index f38c2b09c..6eed2a024 100644
|
||||||
|
--- a/src/quicktemplates2/qquickcontainer.cpp
|
||||||
|
+++ b/src/quicktemplates2/qquickcontainer.cpp
|
||||||
|
@@ -225,6 +225,7 @@ void QQuickContainerPrivate::cleanup()
|
||||||
|
QObject::disconnect(contentModel, &QQmlObjectModel::countChanged, q, &QQuickContainer::countChanged);
|
||||||
|
QObject::disconnect(contentModel, &QQmlObjectModel::childrenChanged, q, &QQuickContainer::contentChildrenChanged);
|
||||||
|
delete contentModel;
|
||||||
|
+ contentModel = nullptr;
|
||||||
|
}
|
||||||
|
|
||||||
|
QQuickItem *QQuickContainerPrivate::itemAt(int index) const
|
||||||
|
@@ -436,7 +437,7 @@ void QQuickContainerPrivate::contentChildren_clear(QQmlListProperty<QQuickItem>
|
||||||
|
void QQuickContainerPrivate::updateContentWidth()
|
||||||
|
{
|
||||||
|
Q_Q(QQuickContainer);
|
||||||
|
- if (hasContentWidth || qFuzzyCompare(contentWidth, implicitContentWidth))
|
||||||
|
+ if (hasContentWidth || qFuzzyCompare(contentWidth, implicitContentWidth) || !contentModel)
|
||||||
|
return;
|
||||||
|
|
||||||
|
contentWidth = implicitContentWidth;
|
||||||
|
@@ -446,7 +447,7 @@ void QQuickContainerPrivate::updateContentWidth()
|
||||||
|
void QQuickContainerPrivate::updateContentHeight()
|
||||||
|
{
|
||||||
|
Q_Q(QQuickContainer);
|
||||||
|
- if (hasContentHeight || qFuzzyCompare(contentHeight, implicitContentHeight))
|
||||||
|
+ if (hasContentHeight || qFuzzyCompare(contentHeight, implicitContentHeight) || !contentModel)
|
||||||
|
return;
|
||||||
|
|
||||||
|
contentHeight = implicitContentHeight;
|
||||||
|
diff --git a/src/quicktemplates2/qquickdialogbuttonbox.cpp b/src/quicktemplates2/qquickdialogbuttonbox.cpp
|
||||||
|
index e6db14eb5..6197d1547 100644
|
||||||
|
--- a/src/quicktemplates2/qquickdialogbuttonbox.cpp
|
||||||
|
+++ b/src/quicktemplates2/qquickdialogbuttonbox.cpp
|
||||||
|
@@ -237,7 +237,7 @@ static QRectF alignedRect(Qt::LayoutDirection direction, Qt::Alignment alignment
|
||||||
|
void QQuickDialogButtonBoxPrivate::resizeContent()
|
||||||
|
{
|
||||||
|
Q_Q(QQuickDialogButtonBox);
|
||||||
|
- if (!contentItem)
|
||||||
|
+ if (!contentItem || !contentModel)
|
||||||
|
return;
|
||||||
|
|
||||||
|
QRectF geometry = q->boundingRect().adjusted(q->leftPadding(), q->topPadding(), -q->rightPadding(), -q->bottomPadding());
|
||||||
|
@@ -322,6 +322,9 @@ void QQuickDialogButtonBoxPrivate::updateLayout()
|
||||||
|
qreal QQuickDialogButtonBoxPrivate::getContentWidth() const
|
||||||
|
{
|
||||||
|
Q_Q(const QQuickDialogButtonBox);
|
||||||
|
+ if (!contentModel)
|
||||||
|
+ return 0;
|
||||||
|
+
|
||||||
|
const int count = contentModel->count();
|
||||||
|
const qreal totalSpacing = qMax(0, count - 1) * spacing;
|
||||||
|
qreal totalWidth = totalSpacing;
|
||||||
|
@@ -341,6 +344,9 @@ qreal QQuickDialogButtonBoxPrivate::getContentWidth() const
|
||||||
|
qreal QQuickDialogButtonBoxPrivate::getContentHeight() const
|
||||||
|
{
|
||||||
|
Q_Q(const QQuickDialogButtonBox);
|
||||||
|
+ if (!contentModel)
|
||||||
|
+ return 0;
|
||||||
|
+
|
||||||
|
const int count = contentModel->count();
|
||||||
|
qreal maxHeight = 0;
|
||||||
|
for (int i = 0; i < count; ++i) {
|
||||||
|
--
|
||||||
|
2.37.2
|
||||||
|
|
@ -0,0 +1,49 @@
|
|||||||
|
From 5ac8f83ed1d34712d11a6b75a5bb1f877b24706a Mon Sep 17 00:00:00 2001
|
||||||
|
From: Oliver Eftevaag <oliver.eftevaag@qt.io>
|
||||||
|
Date: Wed, 19 Jan 2022 22:09:56 +0100
|
||||||
|
Subject: [PATCH 3/6] QQuickAction: don't grab the same shortcut multiple times
|
||||||
|
|
||||||
|
If the entry for the QQuickItem that the QQuickAction is set on has
|
||||||
|
already grabbed the shortcut, then m_shortcutId is no longer 0 and we
|
||||||
|
must not overwrite the value. Otherwise, the QQuickItem removing itself
|
||||||
|
from the action might not remove the correct entry from Qt's shortcut
|
||||||
|
map, leaving a dangling pointer behind.
|
||||||
|
|
||||||
|
Multiple calls to QQuickActionPrivate::ShortcutEntry::grab are possible,
|
||||||
|
because we grab the shortcut whenever the shortcut changes, or when an
|
||||||
|
item representing the action becomes visible.
|
||||||
|
|
||||||
|
The test case added reproduces this scenario by adding the action to a
|
||||||
|
menu item and then making the menu explicitly visible, resulting in two
|
||||||
|
calls to grab() which should be idempotent.
|
||||||
|
|
||||||
|
Fixes: QTBUG-96551
|
||||||
|
Fixes: QTBUG-96561
|
||||||
|
Pick-to: 6.2
|
||||||
|
Change-Id: I7d42a4f4c04f7d8759f2d0f24a133720f10e4c47
|
||||||
|
Reviewed-by: Mitch Curtis <mitch.curtis@qt.io>
|
||||||
|
Reviewed-by: Jarkko Koivikko <jarkko.koivikko@code-q.fi>
|
||||||
|
Reviewed-by: Volker Hilsheimer <volker.hilsheimer@qt.io>
|
||||||
|
|
||||||
|
(cherry picked from commit 45af5ef2f63704adc515e29260ad8c6aaf51f08e in
|
||||||
|
qtdeclarative)
|
||||||
|
---
|
||||||
|
src/quicktemplates2/qquickaction.cpp | 2 +-
|
||||||
|
1 file changed, 1 insertion(+), 1 deletion(-)
|
||||||
|
|
||||||
|
diff --git a/src/quicktemplates2/qquickaction.cpp b/src/quicktemplates2/qquickaction.cpp
|
||||||
|
index 2041e7741..8610cdfae 100644
|
||||||
|
--- a/src/quicktemplates2/qquickaction.cpp
|
||||||
|
+++ b/src/quicktemplates2/qquickaction.cpp
|
||||||
|
@@ -145,7 +145,7 @@ int QQuickActionPrivate::ShortcutEntry::shortcutId() const
|
||||||
|
|
||||||
|
void QQuickActionPrivate::ShortcutEntry::grab(const QKeySequence &shortcut, bool enabled)
|
||||||
|
{
|
||||||
|
- if (shortcut.isEmpty())
|
||||||
|
+ if (shortcut.isEmpty() || m_shortcutId)
|
||||||
|
return;
|
||||||
|
|
||||||
|
Qt::ShortcutContext context = Qt::WindowShortcut; // TODO
|
||||||
|
--
|
||||||
|
2.37.2
|
||||||
|
|
89
0004-QQuickAbstractButton-fix-crash-on-destruction.patch
Normal file
89
0004-QQuickAbstractButton-fix-crash-on-destruction.patch
Normal file
@ -0,0 +1,89 @@
|
|||||||
|
From 38dbeb8f5aa346f490003c75d9fa6e4b817f5bc8 Mon Sep 17 00:00:00 2001
|
||||||
|
From: Ulf Hermann <ulf.hermann@qt.io>
|
||||||
|
Date: Tue, 11 Jan 2022 12:42:47 +0100
|
||||||
|
Subject: [PATCH 4/6] QQuickAbstractButton: fix crash on destruction
|
||||||
|
|
||||||
|
If we listen for size changes we also need to remove the object listened
|
||||||
|
to when it's deleted.
|
||||||
|
|
||||||
|
Pick-to: 5.15 6.2 6.3
|
||||||
|
Fixes: QTBUG-99644
|
||||||
|
Change-Id: I613855ebd986b1e67685088020b88d8b070659cf
|
||||||
|
Reviewed-by: Mitch Curtis <mitch.curtis@qt.io>
|
||||||
|
(cherry picked from commit 720ffaeb60d43123522066e1de3a69ad551644aa in
|
||||||
|
qtdeclarative)
|
||||||
|
---
|
||||||
|
src/quicktemplates2/qquickabstractbutton.cpp | 11 +++++++++
|
||||||
|
.../qquickabstractbutton_p_p.h | 1 +
|
||||||
|
tests/auto/controls/data/tst_switch.qml | 23 +++++++++++++++++++
|
||||||
|
3 files changed, 35 insertions(+)
|
||||||
|
|
||||||
|
diff --git a/src/quicktemplates2/qquickabstractbutton.cpp b/src/quicktemplates2/qquickabstractbutton.cpp
|
||||||
|
index 950e4e099..1df0c706d 100644
|
||||||
|
--- a/src/quicktemplates2/qquickabstractbutton.cpp
|
||||||
|
+++ b/src/quicktemplates2/qquickabstractbutton.cpp
|
||||||
|
@@ -387,6 +387,17 @@ void QQuickAbstractButtonPrivate::itemImplicitHeightChanged(QQuickItem *item)
|
||||||
|
emit q->implicitIndicatorHeightChanged();
|
||||||
|
}
|
||||||
|
|
||||||
|
+void QQuickAbstractButtonPrivate::itemDestroyed(QQuickItem *item)
|
||||||
|
+{
|
||||||
|
+ Q_Q(QQuickAbstractButton);
|
||||||
|
+ QQuickControlPrivate::itemDestroyed(item);
|
||||||
|
+ if (item == indicator) {
|
||||||
|
+ indicator = nullptr;
|
||||||
|
+ emit q->implicitIndicatorWidthChanged();
|
||||||
|
+ emit q->implicitIndicatorHeightChanged();
|
||||||
|
+ }
|
||||||
|
+}
|
||||||
|
+
|
||||||
|
QQuickAbstractButton *QQuickAbstractButtonPrivate::findCheckedButton() const
|
||||||
|
{
|
||||||
|
Q_Q(const QQuickAbstractButton);
|
||||||
|
diff --git a/src/quicktemplates2/qquickabstractbutton_p_p.h b/src/quicktemplates2/qquickabstractbutton_p_p.h
|
||||||
|
index 9291c1a87..b729720f2 100644
|
||||||
|
--- a/src/quicktemplates2/qquickabstractbutton_p_p.h
|
||||||
|
+++ b/src/quicktemplates2/qquickabstractbutton_p_p.h
|
||||||
|
@@ -109,6 +109,7 @@ public:
|
||||||
|
|
||||||
|
void itemImplicitWidthChanged(QQuickItem *item) override;
|
||||||
|
void itemImplicitHeightChanged(QQuickItem *item) override;
|
||||||
|
+ void itemDestroyed(QQuickItem *item) override;
|
||||||
|
|
||||||
|
// copied from qabstractbutton.cpp
|
||||||
|
static const int AUTO_REPEAT_DELAY = 300;
|
||||||
|
diff --git a/tests/auto/controls/data/tst_switch.qml b/tests/auto/controls/data/tst_switch.qml
|
||||||
|
index b3fab41ca..10b6baa02 100644
|
||||||
|
--- a/tests/auto/controls/data/tst_switch.qml
|
||||||
|
+++ b/tests/auto/controls/data/tst_switch.qml
|
||||||
|
@@ -608,4 +608,27 @@ TestCase {
|
||||||
|
mouseClick(control.indicator)
|
||||||
|
verify(control.activeFocus)
|
||||||
|
}
|
||||||
|
+
|
||||||
|
+ Component {
|
||||||
|
+ id: deletionOrder1
|
||||||
|
+ Item {
|
||||||
|
+ Image { id: innerImage }
|
||||||
|
+ Switch { indicator: innerImage }
|
||||||
|
+ }
|
||||||
|
+ }
|
||||||
|
+
|
||||||
|
+ Component {
|
||||||
|
+ id: deletionOrder2
|
||||||
|
+ Item {
|
||||||
|
+ Switch { indicator: innerImage }
|
||||||
|
+ Image { id: innerImage }
|
||||||
|
+ }
|
||||||
|
+ }
|
||||||
|
+
|
||||||
|
+ function test_deletionOrder() {
|
||||||
|
+ var control1 = createTemporaryObject(deletionOrder1, testCase)
|
||||||
|
+ verify(control1)
|
||||||
|
+ var control2 = createTemporaryObject(deletionOrder2, testCase)
|
||||||
|
+ verify(control2)
|
||||||
|
+ }
|
||||||
|
}
|
||||||
|
--
|
||||||
|
2.37.2
|
||||||
|
|
443
0005-Revert-Allow-creation-of-custom-QQuickPopupItem-deri.patch
Normal file
443
0005-Revert-Allow-creation-of-custom-QQuickPopupItem-deri.patch
Normal file
@ -0,0 +1,443 @@
|
|||||||
|
From 59cc1cc5b3719713598a1f426d82a9d895b5dccb Mon Sep 17 00:00:00 2001
|
||||||
|
From: Albert Astals Cid <aacid@kde.org>
|
||||||
|
Date: Fri, 17 Jun 2022 15:24:13 +0200
|
||||||
|
Subject: [PATCH 5/6] Revert "Allow creation of custom QQuickPopupItem-derived
|
||||||
|
types"
|
||||||
|
|
||||||
|
This reverts commit 6b8a9673.
|
||||||
|
|
||||||
|
The follow-up commit a063cd0b
|
||||||
|
|
||||||
|
causes QTBUG-94764, so we don't need this enabling change for now.
|
||||||
|
|
||||||
|
Task-number: QTBUG-83630
|
||||||
|
Task-number: QTBUG-94764
|
||||||
|
Pick-to: 5.15 6.1 6.2
|
||||||
|
Change-Id: I1aec8571dcdcc2103d0e56c3d0bbfc4a4872d8db
|
||||||
|
Reviewed-by: default avatarRichard Moe Gustavsen <richard.gustavsen@qt.io>
|
||||||
|
|
||||||
|
(cherry-picked from qtdeclarative b69d071c10dfa4c5d7b62692b8a9d7bb659a4ab5)
|
||||||
|
---
|
||||||
|
src/quicktemplates2/qquickmenu.cpp | 1 -
|
||||||
|
src/quicktemplates2/qquickmenu_p_p.h | 2 +-
|
||||||
|
src/quicktemplates2/qquickpopup.cpp | 17 +--
|
||||||
|
src/quicktemplates2/qquickpopup_p_p.h | 4 +-
|
||||||
|
src/quicktemplates2/qquickpopupitem.cpp | 70 +++++++------
|
||||||
|
src/quicktemplates2/qquickpopupitem_p.h | 121 ----------------------
|
||||||
|
src/quicktemplates2/qquickpopupitem_p_p.h | 80 +++++++++-----
|
||||||
|
src/quicktemplates2/quicktemplates2.pri | 1 -
|
||||||
|
8 files changed, 100 insertions(+), 196 deletions(-)
|
||||||
|
delete mode 100644 src/quicktemplates2/qquickpopupitem_p.h
|
||||||
|
|
||||||
|
diff --git a/src/quicktemplates2/qquickmenu.cpp b/src/quicktemplates2/qquickmenu.cpp
|
||||||
|
index a934fa8ae..0043dddde 100644
|
||||||
|
--- a/src/quicktemplates2/qquickmenu.cpp
|
||||||
|
+++ b/src/quicktemplates2/qquickmenu.cpp
|
||||||
|
@@ -222,7 +222,6 @@ QQuickMenuPrivate::QQuickMenuPrivate()
|
||||||
|
void QQuickMenuPrivate::init()
|
||||||
|
{
|
||||||
|
Q_Q(QQuickMenu);
|
||||||
|
- QQuickPopupPrivate::init();
|
||||||
|
contentModel = new QQmlObjectModel(q);
|
||||||
|
}
|
||||||
|
|
||||||
|
diff --git a/src/quicktemplates2/qquickmenu_p_p.h b/src/quicktemplates2/qquickmenu_p_p.h
|
||||||
|
index b1fbb1efb..63553f8a5 100644
|
||||||
|
--- a/src/quicktemplates2/qquickmenu_p_p.h
|
||||||
|
+++ b/src/quicktemplates2/qquickmenu_p_p.h
|
||||||
|
@@ -73,7 +73,7 @@ public:
|
||||||
|
return menu->d_func();
|
||||||
|
}
|
||||||
|
|
||||||
|
- void init() override;
|
||||||
|
+ void init();
|
||||||
|
|
||||||
|
QQuickItem *itemAt(int index) const;
|
||||||
|
void insertItem(int index, QQuickItem *item);
|
||||||
|
diff --git a/src/quicktemplates2/qquickpopup.cpp b/src/quicktemplates2/qquickpopup.cpp
|
||||||
|
index 8a03198e5..bdc6dff27 100644
|
||||||
|
--- a/src/quicktemplates2/qquickpopup.cpp
|
||||||
|
+++ b/src/quicktemplates2/qquickpopup.cpp
|
||||||
|
@@ -275,21 +275,9 @@ QQuickPopupPrivate::QQuickPopupPrivate()
|
||||||
|
void QQuickPopupPrivate::init()
|
||||||
|
{
|
||||||
|
Q_Q(QQuickPopup);
|
||||||
|
- createPopupItem();
|
||||||
|
+ popupItem = new QQuickPopupItem(q);
|
||||||
|
popupItem->setVisible(false);
|
||||||
|
q->setParentItem(qobject_cast<QQuickItem *>(parent));
|
||||||
|
- connectToPopupItem();
|
||||||
|
-}
|
||||||
|
-
|
||||||
|
-void QQuickPopupPrivate::createPopupItem()
|
||||||
|
-{
|
||||||
|
- Q_Q(QQuickPopup);
|
||||||
|
- popupItem = new QQuickPopupItem(q);
|
||||||
|
-}
|
||||||
|
-
|
||||||
|
-void QQuickPopupPrivate::connectToPopupItem()
|
||||||
|
-{
|
||||||
|
- Q_Q(QQuickPopup);
|
||||||
|
QObject::connect(popupItem, &QQuickControl::paddingChanged, q, &QQuickPopup::paddingChanged);
|
||||||
|
QObject::connect(popupItem, &QQuickControl::backgroundChanged, q, &QQuickPopup::backgroundChanged);
|
||||||
|
QObject::connect(popupItem, &QQuickControl::contentItemChanged, q, &QQuickPopup::contentItemChanged);
|
||||||
|
@@ -854,7 +842,8 @@ QQuickPopup::QQuickPopup(QObject *parent)
|
||||||
|
QQuickPopup::QQuickPopup(QQuickPopupPrivate &dd, QObject *parent)
|
||||||
|
: QObject(dd, parent)
|
||||||
|
{
|
||||||
|
- dd.init();
|
||||||
|
+ Q_D(QQuickPopup);
|
||||||
|
+ d->init();
|
||||||
|
}
|
||||||
|
|
||||||
|
QQuickPopup::~QQuickPopup()
|
||||||
|
diff --git a/src/quicktemplates2/qquickpopup_p_p.h b/src/quicktemplates2/qquickpopup_p_p.h
|
||||||
|
index 2fc0f133d..ef4b112e2 100644
|
||||||
|
--- a/src/quicktemplates2/qquickpopup_p_p.h
|
||||||
|
+++ b/src/quicktemplates2/qquickpopup_p_p.h
|
||||||
|
@@ -96,9 +96,7 @@ public:
|
||||||
|
QQmlListProperty<QObject> contentData();
|
||||||
|
QQmlListProperty<QQuickItem> contentChildren();
|
||||||
|
|
||||||
|
- virtual void init();
|
||||||
|
- void createPopupItem();
|
||||||
|
- void connectToPopupItem();
|
||||||
|
+ void init();
|
||||||
|
void closeOrReject();
|
||||||
|
bool tryClose(const QPointF &pos, QQuickPopup::ClosePolicy flags);
|
||||||
|
|
||||||
|
diff --git a/src/quicktemplates2/qquickpopupitem.cpp b/src/quicktemplates2/qquickpopupitem.cpp
|
||||||
|
index 992d74570..0069b9fc1 100644
|
||||||
|
--- a/src/quicktemplates2/qquickpopupitem.cpp
|
||||||
|
+++ b/src/quicktemplates2/qquickpopupitem.cpp
|
||||||
|
@@ -53,33 +53,38 @@
|
||||||
|
|
||||||
|
QT_BEGIN_NAMESPACE
|
||||||
|
|
||||||
|
+class QQuickPopupItemPrivate : public QQuickPagePrivate
|
||||||
|
+{
|
||||||
|
+ Q_DECLARE_PUBLIC(QQuickPopupItem)
|
||||||
|
+
|
||||||
|
+public:
|
||||||
|
+ QQuickPopupItemPrivate(QQuickPopup *popup);
|
||||||
|
+
|
||||||
|
+ void implicitWidthChanged() override;
|
||||||
|
+ void implicitHeightChanged() override;
|
||||||
|
+
|
||||||
|
+ void resolveFont() override;
|
||||||
|
+ void resolvePalette() override;
|
||||||
|
+
|
||||||
|
+ QQuickItem *getContentItem() override;
|
||||||
|
+
|
||||||
|
+ void cancelContentItem() override;
|
||||||
|
+ void executeContentItem(bool complete = false) override;
|
||||||
|
+
|
||||||
|
+ void cancelBackground() override;
|
||||||
|
+ void executeBackground(bool complete = false) override;
|
||||||
|
+
|
||||||
|
+ int backId = 0;
|
||||||
|
+ int escapeId = 0;
|
||||||
|
+ QQuickPopup *popup = nullptr;
|
||||||
|
+};
|
||||||
|
+
|
||||||
|
QQuickPopupItemPrivate::QQuickPopupItemPrivate(QQuickPopup *popup)
|
||||||
|
: popup(popup)
|
||||||
|
{
|
||||||
|
isTabFence = true;
|
||||||
|
}
|
||||||
|
|
||||||
|
-void QQuickPopupItemPrivate::init()
|
||||||
|
-{
|
||||||
|
- Q_Q(QQuickPopupItem);
|
||||||
|
- q->setParent(popup);
|
||||||
|
- q->setFlag(QQuickItem::ItemIsFocusScope);
|
||||||
|
- q->setAcceptedMouseButtons(Qt::AllButtons);
|
||||||
|
-#if QT_CONFIG(quicktemplates2_multitouch)
|
||||||
|
- q->setAcceptTouchEvents(true);
|
||||||
|
-#endif
|
||||||
|
-#if QT_CONFIG(cursor)
|
||||||
|
- q->setCursor(Qt::ArrowCursor);
|
||||||
|
-#endif
|
||||||
|
-
|
||||||
|
-#if QT_CONFIG(quicktemplates2_hover)
|
||||||
|
- // TODO: switch to QStyleHints::useHoverEffects in Qt 5.8
|
||||||
|
- q->setHoverEnabled(true);
|
||||||
|
- // setAcceptHoverEvents(QGuiApplication::styleHints()->useHoverEffects());
|
||||||
|
- // connect(QGuiApplication::styleHints(), &QStyleHints::useHoverEffectsChanged, this, &QQuickItem::setAcceptHoverEvents);
|
||||||
|
-#endif
|
||||||
|
-}
|
||||||
|
-
|
||||||
|
void QQuickPopupItemPrivate::implicitWidthChanged()
|
||||||
|
{
|
||||||
|
QQuickPagePrivate::implicitWidthChanged();
|
||||||
|
@@ -156,15 +161,22 @@ void QQuickPopupItemPrivate::executeBackground(bool complete)
|
||||||
|
QQuickPopupItem::QQuickPopupItem(QQuickPopup *popup)
|
||||||
|
: QQuickPage(*(new QQuickPopupItemPrivate(popup)), nullptr)
|
||||||
|
{
|
||||||
|
- Q_D(QQuickPopupItem);
|
||||||
|
- d->init();
|
||||||
|
-}
|
||||||
|
+ setParent(popup);
|
||||||
|
+ setFlag(ItemIsFocusScope);
|
||||||
|
+ setAcceptedMouseButtons(Qt::AllButtons);
|
||||||
|
+#if QT_CONFIG(quicktemplates2_multitouch)
|
||||||
|
+ setAcceptTouchEvents(true);
|
||||||
|
+#endif
|
||||||
|
+#if QT_CONFIG(cursor)
|
||||||
|
+ setCursor(Qt::ArrowCursor);
|
||||||
|
+#endif
|
||||||
|
|
||||||
|
-QQuickPopupItem::QQuickPopupItem(QQuickPopupItemPrivate &dd) :
|
||||||
|
- QQuickPage(dd, nullptr)
|
||||||
|
-{
|
||||||
|
- Q_D(QQuickPopupItem);
|
||||||
|
- d->init();
|
||||||
|
+#if QT_CONFIG(quicktemplates2_hover)
|
||||||
|
+ // TODO: switch to QStyleHints::useHoverEffects in Qt 5.8
|
||||||
|
+ setHoverEnabled(true);
|
||||||
|
+ // setAcceptHoverEvents(QGuiApplication::styleHints()->useHoverEffects());
|
||||||
|
+ // connect(QGuiApplication::styleHints(), &QStyleHints::useHoverEffectsChanged, this, &QQuickItem::setAcceptHoverEvents);
|
||||||
|
+#endif
|
||||||
|
}
|
||||||
|
|
||||||
|
void QQuickPopupItem::grabShortcut()
|
||||||
|
diff --git a/src/quicktemplates2/qquickpopupitem_p.h b/src/quicktemplates2/qquickpopupitem_p.h
|
||||||
|
deleted file mode 100644
|
||||||
|
index df67e7453..000000000
|
||||||
|
--- a/src/quicktemplates2/qquickpopupitem_p.h
|
||||||
|
+++ /dev/null
|
||||||
|
@@ -1,121 +0,0 @@
|
||||||
|
-/****************************************************************************
|
||||||
|
-**
|
||||||
|
-** Copyright (C) 2021 The Qt Company Ltd.
|
||||||
|
-** Contact: https://www.qt.io/licensing/
|
||||||
|
-**
|
||||||
|
-** This file is part of the Qt Quick Templates 2 module of the Qt Toolkit.
|
||||||
|
-**
|
||||||
|
-** $QT_BEGIN_LICENSE:COMM$
|
||||||
|
-**
|
||||||
|
-** Commercial License Usage
|
||||||
|
-** Licensees holding valid commercial Qt licenses may use this file in
|
||||||
|
-** accordance with the commercial license agreement provided with the
|
||||||
|
-** Software or, alternatively, in accordance with the terms contained in
|
||||||
|
-** a written agreement between you and The Qt Company. For licensing terms
|
||||||
|
-** and conditions see https://www.qt.io/terms-conditions. For further
|
||||||
|
-** information use the contact form at https://www.qt.io/contact-us.
|
||||||
|
-**
|
||||||
|
-** $QT_END_LICENSE$
|
||||||
|
-**
|
||||||
|
-**
|
||||||
|
-**
|
||||||
|
-**
|
||||||
|
-**
|
||||||
|
-**
|
||||||
|
-**
|
||||||
|
-**
|
||||||
|
-**
|
||||||
|
-**
|
||||||
|
-**
|
||||||
|
-**
|
||||||
|
-**
|
||||||
|
-**
|
||||||
|
-**
|
||||||
|
-**
|
||||||
|
-****************************************************************************/
|
||||||
|
-
|
||||||
|
-#ifndef QQUICKPOPUPITEM_P_H
|
||||||
|
-#define QQUICKPOPUPITEM_P_H
|
||||||
|
-
|
||||||
|
-//
|
||||||
|
-// W A R N I N G
|
||||||
|
-// -------------
|
||||||
|
-//
|
||||||
|
-// This file is not part of the Qt API. It exists purely as an
|
||||||
|
-// implementation detail. This header file may change from version to
|
||||||
|
-// version without notice, or even be removed.
|
||||||
|
-//
|
||||||
|
-// We mean it.
|
||||||
|
-//
|
||||||
|
-
|
||||||
|
-#include <QtQuickTemplates2/private/qquickpage_p.h>
|
||||||
|
-#include <QtQuickTemplates2/private/qquickpage_p_p.h>
|
||||||
|
-
|
||||||
|
-QT_BEGIN_NAMESPACE
|
||||||
|
-
|
||||||
|
-class QQuickPopup;
|
||||||
|
-class QQuickPopupItemPrivate;
|
||||||
|
-
|
||||||
|
-class QQuickPopupItem : public QQuickPage
|
||||||
|
-{
|
||||||
|
- Q_OBJECT
|
||||||
|
-
|
||||||
|
-public:
|
||||||
|
- explicit QQuickPopupItem(QQuickPopup *popup);
|
||||||
|
-
|
||||||
|
- void grabShortcut();
|
||||||
|
- void ungrabShortcut();
|
||||||
|
-
|
||||||
|
-protected:
|
||||||
|
- void updatePolish() override;
|
||||||
|
-
|
||||||
|
- bool event(QEvent *event) override;
|
||||||
|
- bool childMouseEventFilter(QQuickItem *child, QEvent *event) override;
|
||||||
|
- void focusInEvent(QFocusEvent *event) override;
|
||||||
|
- void focusOutEvent(QFocusEvent *event) override;
|
||||||
|
- void keyPressEvent(QKeyEvent *event) override;
|
||||||
|
- void keyReleaseEvent(QKeyEvent *event) override;
|
||||||
|
- void mousePressEvent(QMouseEvent *event) override;
|
||||||
|
- void mouseMoveEvent(QMouseEvent *event) override;
|
||||||
|
- void mouseReleaseEvent(QMouseEvent *event) override;
|
||||||
|
- void mouseDoubleClickEvent(QMouseEvent *event) override;
|
||||||
|
- void mouseUngrabEvent() override;
|
||||||
|
-#if QT_CONFIG(quicktemplates2_multitouch)
|
||||||
|
- void touchEvent(QTouchEvent *event) override;
|
||||||
|
- void touchUngrabEvent() override;
|
||||||
|
-#endif
|
||||||
|
-#if QT_CONFIG(wheelevent)
|
||||||
|
- void wheelEvent(QWheelEvent *event) override;
|
||||||
|
-#endif
|
||||||
|
-
|
||||||
|
- void contentItemChange(QQuickItem *newItem, QQuickItem *oldItem) override;
|
||||||
|
- void contentSizeChange(const QSizeF &newSize, const QSizeF &oldSize) override;
|
||||||
|
- void fontChange(const QFont &newFont, const QFont &oldFont) override;
|
||||||
|
- void geometryChanged(const QRectF &newGeometry, const QRectF &oldGeometry) override;
|
||||||
|
- void localeChange(const QLocale &newLocale, const QLocale &oldLocale) override;
|
||||||
|
- void mirrorChange() override;
|
||||||
|
- void itemChange(ItemChange change, const ItemChangeData &data) override;
|
||||||
|
- void paddingChange(const QMarginsF &newPadding, const QMarginsF &oldPadding) override;
|
||||||
|
- void paletteChange(const QPalette &newPalette, const QPalette &oldPalette) override;
|
||||||
|
- void enabledChange() override;
|
||||||
|
-
|
||||||
|
- QFont defaultFont() const override;
|
||||||
|
- QPalette defaultPalette() const override;
|
||||||
|
-
|
||||||
|
-#if QT_CONFIG(accessibility)
|
||||||
|
- QAccessible::Role accessibleRole() const override;
|
||||||
|
- void accessibilityActiveChanged(bool active) override;
|
||||||
|
-#endif
|
||||||
|
-
|
||||||
|
-protected:
|
||||||
|
- QQuickPopupItem(QQuickPopupItemPrivate &dd);
|
||||||
|
-
|
||||||
|
-private:
|
||||||
|
- Q_DISABLE_COPY(QQuickPopupItem)
|
||||||
|
- Q_DECLARE_PRIVATE(QQuickPopupItem)
|
||||||
|
- friend class QQuickPopup;
|
||||||
|
-};
|
||||||
|
-
|
||||||
|
-QT_END_NAMESPACE
|
||||||
|
-
|
||||||
|
-#endif // QQUICKPOPUPITEM_P_H
|
||||||
|
diff --git a/src/quicktemplates2/qquickpopupitem_p_p.h b/src/quicktemplates2/qquickpopupitem_p_p.h
|
||||||
|
index 65b33b21e..a12e43e0a 100644
|
||||||
|
--- a/src/quicktemplates2/qquickpopupitem_p_p.h
|
||||||
|
+++ b/src/quicktemplates2/qquickpopupitem_p_p.h
|
||||||
|
@@ -48,39 +48,67 @@
|
||||||
|
// We mean it.
|
||||||
|
//
|
||||||
|
|
||||||
|
-#include <QtQuickTemplates2/private/qquickpopupitem_p.h>
|
||||||
|
-#include <QtQuickTemplates2/private/qquickpalette_p.h>
|
||||||
|
+#include <QtQuickTemplates2/private/qquickpage_p.h>
|
||||||
|
|
||||||
|
QT_BEGIN_NAMESPACE
|
||||||
|
|
||||||
|
class QQuickPopup;
|
||||||
|
-
|
||||||
|
-class QQuickPopupItemPrivate : public QQuickPagePrivate
|
||||||
|
+class QQuickPopupItemPrivate;
|
||||||
|
+class QQuickPopupItem : public QQuickPage
|
||||||
|
{
|
||||||
|
- Q_DECLARE_PUBLIC(QQuickPopupItem)
|
||||||
|
+ Q_OBJECT
|
||||||
|
|
||||||
|
public:
|
||||||
|
- QQuickPopupItemPrivate(QQuickPopup *popup);
|
||||||
|
-
|
||||||
|
- void init();
|
||||||
|
-
|
||||||
|
- void implicitWidthChanged() override;
|
||||||
|
- void implicitHeightChanged() override;
|
||||||
|
-
|
||||||
|
- void resolveFont() override;
|
||||||
|
- void resolvePalette() override;
|
||||||
|
-
|
||||||
|
- QQuickItem *getContentItem() override;
|
||||||
|
-
|
||||||
|
- void cancelContentItem() override;
|
||||||
|
- void executeContentItem(bool complete = false) override;
|
||||||
|
-
|
||||||
|
- void cancelBackground() override;
|
||||||
|
- void executeBackground(bool complete = false) override;
|
||||||
|
-
|
||||||
|
- int backId = 0;
|
||||||
|
- int escapeId = 0;
|
||||||
|
- QQuickPopup *popup = nullptr;
|
||||||
|
+ explicit QQuickPopupItem(QQuickPopup *popup);
|
||||||
|
+
|
||||||
|
+ void grabShortcut();
|
||||||
|
+ void ungrabShortcut();
|
||||||
|
+
|
||||||
|
+protected:
|
||||||
|
+ void updatePolish() override;
|
||||||
|
+
|
||||||
|
+ bool event(QEvent *event) override;
|
||||||
|
+ bool childMouseEventFilter(QQuickItem *child, QEvent *event) override;
|
||||||
|
+ void focusInEvent(QFocusEvent *event) override;
|
||||||
|
+ void focusOutEvent(QFocusEvent *event) override;
|
||||||
|
+ void keyPressEvent(QKeyEvent *event) override;
|
||||||
|
+ void keyReleaseEvent(QKeyEvent *event) override;
|
||||||
|
+ void mousePressEvent(QMouseEvent *event) override;
|
||||||
|
+ void mouseMoveEvent(QMouseEvent *event) override;
|
||||||
|
+ void mouseReleaseEvent(QMouseEvent *event) override;
|
||||||
|
+ void mouseDoubleClickEvent(QMouseEvent *event) override;
|
||||||
|
+ void mouseUngrabEvent() override;
|
||||||
|
+#if QT_CONFIG(quicktemplates2_multitouch)
|
||||||
|
+ void touchEvent(QTouchEvent *event) override;
|
||||||
|
+ void touchUngrabEvent() override;
|
||||||
|
+#endif
|
||||||
|
+#if QT_CONFIG(wheelevent)
|
||||||
|
+ void wheelEvent(QWheelEvent *event) override;
|
||||||
|
+#endif
|
||||||
|
+
|
||||||
|
+ void contentItemChange(QQuickItem *newItem, QQuickItem *oldItem) override;
|
||||||
|
+ void contentSizeChange(const QSizeF &newSize, const QSizeF &oldSize) override;
|
||||||
|
+ void fontChange(const QFont &newFont, const QFont &oldFont) override;
|
||||||
|
+ void geometryChanged(const QRectF &newGeometry, const QRectF &oldGeometry) override;
|
||||||
|
+ void localeChange(const QLocale &newLocale, const QLocale &oldLocale) override;
|
||||||
|
+ void mirrorChange() override;
|
||||||
|
+ void itemChange(ItemChange change, const ItemChangeData &data) override;
|
||||||
|
+ void paddingChange(const QMarginsF &newPadding, const QMarginsF &oldPadding) override;
|
||||||
|
+ void paletteChange(const QPalette &newPalette, const QPalette &oldPalette) override;
|
||||||
|
+ void enabledChange() override;
|
||||||
|
+
|
||||||
|
+ QFont defaultFont() const override;
|
||||||
|
+ QPalette defaultPalette() const override;
|
||||||
|
+
|
||||||
|
+#if QT_CONFIG(accessibility)
|
||||||
|
+ QAccessible::Role accessibleRole() const override;
|
||||||
|
+ void accessibilityActiveChanged(bool active) override;
|
||||||
|
+#endif
|
||||||
|
+
|
||||||
|
+private:
|
||||||
|
+ Q_DISABLE_COPY(QQuickPopupItem)
|
||||||
|
+ Q_DECLARE_PRIVATE(QQuickPopupItem)
|
||||||
|
+ friend class QQuickPopup;
|
||||||
|
};
|
||||||
|
|
||||||
|
QT_END_NAMESPACE
|
||||||
|
diff --git a/src/quicktemplates2/quicktemplates2.pri b/src/quicktemplates2/quicktemplates2.pri
|
||||||
|
index ba09591bf..fa6929f92 100644
|
||||||
|
--- a/src/quicktemplates2/quicktemplates2.pri
|
||||||
|
+++ b/src/quicktemplates2/quicktemplates2.pri
|
||||||
|
@@ -60,7 +60,6 @@ HEADERS += \
|
||||||
|
$$PWD/qquickpopup_p_p.h \
|
||||||
|
$$PWD/qquickpopupanchors_p.h \
|
||||||
|
$$PWD/qquickpopupanchors_p_p.h \
|
||||||
|
- $$PWD/qquickpopupitem_p.h \
|
||||||
|
$$PWD/qquickpopupitem_p_p.h \
|
||||||
|
$$PWD/qquickpopuppositioner_p_p.h \
|
||||||
|
$$PWD/qquickpresshandler_p_p.h \
|
||||||
|
--
|
||||||
|
2.37.2
|
||||||
|
|
179
0006-Fix-scroll-bars-not-showing-up-when-binding-to-stand.patch
Normal file
179
0006-Fix-scroll-bars-not-showing-up-when-binding-to-stand.patch
Normal file
@ -0,0 +1,179 @@
|
|||||||
|
From d0642867ab629daf36a1194274a74758111140be Mon Sep 17 00:00:00 2001
|
||||||
|
From: Mitch Curtis <mitch.curtis@qt.io>
|
||||||
|
Date: Mon, 18 Jul 2022 15:21:49 +0800
|
||||||
|
Subject: [PATCH 6/6] Fix scroll bars not showing up when binding to standalone
|
||||||
|
contentItem
|
||||||
|
|
||||||
|
908aa77d16e00f2bccc0ddae0f8b61955c56a6a1 hid old scroll bars, but
|
||||||
|
didn't account for the situation where the old scroll bars would be put
|
||||||
|
back into place, and so they never showed up.
|
||||||
|
|
||||||
|
In the case of the linked bug report, since there was a binding to the
|
||||||
|
ScrollView's contentItem, a default Flickable would be created. After
|
||||||
|
that binding was evaluated, the contentItem was set, causing the scroll
|
||||||
|
bars to be hidden (as part of the process of disconnecting from the old
|
||||||
|
flickable). To fix the issue, we now do the reverse of hideOldItem when
|
||||||
|
a new contentItem is set.
|
||||||
|
|
||||||
|
Fixes: QTBUG-104983
|
||||||
|
Pick-to: 6.2 6.3 6.4
|
||||||
|
Change-Id: I910259cc3e8f6a6231ae6c87c7d4f0f652bd0545
|
||||||
|
Reviewed-by: Fabian Kosmale <fabian.kosmale@qt.io>
|
||||||
|
Reviewed-by: Nate Graham
|
||||||
|
|
||||||
|
(cherry picked from qtdeclarative 58bae53237417f28eac6d772fa6ecab657f8a73f)
|
||||||
|
---
|
||||||
|
src/quicktemplates2/qquickcontrol.cpp | 30 +++++++++++++
|
||||||
|
src/quicktemplates2/qquickcontrol_p_p.h | 1 +
|
||||||
|
src/quicktemplates2/qquickscrollbar.cpp | 11 +++++
|
||||||
|
tests/auto/controls/data/tst_scrollview.qml | 47 +++++++++++++++++++++
|
||||||
|
4 files changed, 89 insertions(+)
|
||||||
|
|
||||||
|
diff --git a/src/quicktemplates2/qquickcontrol.cpp b/src/quicktemplates2/qquickcontrol.cpp
|
||||||
|
index bbbd0e622..1f4b47343 100644
|
||||||
|
--- a/src/quicktemplates2/qquickcontrol.cpp
|
||||||
|
+++ b/src/quicktemplates2/qquickcontrol.cpp
|
||||||
|
@@ -845,6 +845,13 @@ void QQuickControlPrivate::executeBackground(bool complete)
|
||||||
|
quickCompleteDeferred(q, backgroundName(), background);
|
||||||
|
}
|
||||||
|
|
||||||
|
+/*
|
||||||
|
+ \internal
|
||||||
|
+
|
||||||
|
+ Hides an item that was replaced by a newer one, rather than
|
||||||
|
+ deleting it, as the item is typically created in QML and hence
|
||||||
|
+ we don't own it.
|
||||||
|
+*/
|
||||||
|
void QQuickControlPrivate::hideOldItem(QQuickItem *item)
|
||||||
|
{
|
||||||
|
if (!item)
|
||||||
|
@@ -863,6 +870,29 @@ void QQuickControlPrivate::hideOldItem(QQuickItem *item)
|
||||||
|
#endif
|
||||||
|
}
|
||||||
|
|
||||||
|
+/*
|
||||||
|
+ \internal
|
||||||
|
+
|
||||||
|
+ Named "unhide" because it's used for cases where an item
|
||||||
|
+ that was previously hidden by \l hideOldItem() wants to be
|
||||||
|
+ shown by a control again, such as a ScrollBar in ScrollView.
|
||||||
|
+*/
|
||||||
|
+void QQuickControlPrivate::unhideOldItem(QQuickControl *control, QQuickItem *item)
|
||||||
|
+{
|
||||||
|
+ Q_ASSERT(item);
|
||||||
|
+ qCDebug(lcItemManagement) << "unhiding old item" << item;
|
||||||
|
+
|
||||||
|
+ item->setVisible(true);
|
||||||
|
+ item->setParentItem(control);
|
||||||
|
+
|
||||||
|
+#if QT_CONFIG(accessibility)
|
||||||
|
+ // Add the item back in to the accessibility tree.
|
||||||
|
+ QQuickAccessibleAttached *accessible = accessibleAttached(item);
|
||||||
|
+ if (accessible)
|
||||||
|
+ accessible->setIgnored(false);
|
||||||
|
+#endif
|
||||||
|
+}
|
||||||
|
+
|
||||||
|
void QQuickControlPrivate::updateBaselineOffset()
|
||||||
|
{
|
||||||
|
Q_Q(QQuickControl);
|
||||||
|
diff --git a/src/quicktemplates2/qquickcontrol_p_p.h b/src/quicktemplates2/qquickcontrol_p_p.h
|
||||||
|
index 8e979079e..a6e624c91 100644
|
||||||
|
--- a/src/quicktemplates2/qquickcontrol_p_p.h
|
||||||
|
+++ b/src/quicktemplates2/qquickcontrol_p_p.h
|
||||||
|
@@ -173,6 +173,7 @@ public:
|
||||||
|
virtual void executeBackground(bool complete = false);
|
||||||
|
|
||||||
|
static void hideOldItem(QQuickItem *item);
|
||||||
|
+ static void unhideOldItem(QQuickControl *control, QQuickItem *item);
|
||||||
|
|
||||||
|
void updateBaselineOffset();
|
||||||
|
|
||||||
|
diff --git a/src/quicktemplates2/qquickscrollbar.cpp b/src/quicktemplates2/qquickscrollbar.cpp
|
||||||
|
index 4e2f509db..1c4b308cd 100644
|
||||||
|
--- a/src/quicktemplates2/qquickscrollbar.cpp
|
||||||
|
+++ b/src/quicktemplates2/qquickscrollbar.cpp
|
||||||
|
@@ -797,6 +797,14 @@ void QQuickScrollBarAttachedPrivate::initHorizontal()
|
||||||
|
if (parent && parent == flickable->parentItem())
|
||||||
|
horizontal->stackAfter(flickable);
|
||||||
|
|
||||||
|
+ // If a scroll bar was previously hidden (due to e.g. setting a new contentItem
|
||||||
|
+ // on a ScrollView), we need to make sure that we un-hide it.
|
||||||
|
+ // We don't bother checking if the item is actually the old one, because
|
||||||
|
+ // if it's not, all of the things the function does (setting parent, visibility, etc.)
|
||||||
|
+ // should be no-ops anyway.
|
||||||
|
+ if (auto control = qobject_cast<QQuickControl*>(q_ptr->parent()))
|
||||||
|
+ QQuickControlPrivate::unhideOldItem(control, horizontal);
|
||||||
|
+
|
||||||
|
layoutHorizontal();
|
||||||
|
horizontal->setSize(area->property("widthRatio").toReal());
|
||||||
|
horizontal->setPosition(area->property("xPosition").toReal());
|
||||||
|
@@ -818,6 +826,9 @@ void QQuickScrollBarAttachedPrivate::initVertical()
|
||||||
|
if (parent && parent == flickable->parentItem())
|
||||||
|
vertical->stackAfter(flickable);
|
||||||
|
|
||||||
|
+ if (auto control = qobject_cast<QQuickControl*>(q_ptr->parent()))
|
||||||
|
+ QQuickControlPrivate::unhideOldItem(control, vertical);
|
||||||
|
+
|
||||||
|
layoutVertical();
|
||||||
|
vertical->setSize(area->property("heightRatio").toReal());
|
||||||
|
vertical->setPosition(area->property("yPosition").toReal());
|
||||||
|
diff --git a/tests/auto/controls/data/tst_scrollview.qml b/tests/auto/controls/data/tst_scrollview.qml
|
||||||
|
index 0e8b08352..cd4931184 100644
|
||||||
|
--- a/tests/auto/controls/data/tst_scrollview.qml
|
||||||
|
+++ b/tests/auto/controls/data/tst_scrollview.qml
|
||||||
|
@@ -576,4 +576,51 @@ TestCase {
|
||||||
|
verify(newHorizontalScrollBar.visible)
|
||||||
|
verify(!oldHorizontalScrollBar.visible)
|
||||||
|
}
|
||||||
|
+
|
||||||
|
+ Component {
|
||||||
|
+ id: bindingToContentItemAndStandaloneFlickable
|
||||||
|
+
|
||||||
|
+ Item {
|
||||||
|
+ width: 200
|
||||||
|
+ height: 200
|
||||||
|
+
|
||||||
|
+ property alias scrollView: scrollView
|
||||||
|
+
|
||||||
|
+ ScrollView {
|
||||||
|
+ id: scrollView
|
||||||
|
+ anchors.fill: parent
|
||||||
|
+ contentItem: listView
|
||||||
|
+
|
||||||
|
+ property Item someBinding: contentItem
|
||||||
|
+ }
|
||||||
|
+ ListView {
|
||||||
|
+ id: listView
|
||||||
|
+ model: 10
|
||||||
|
+ delegate: ItemDelegate {
|
||||||
|
+ text: modelData
|
||||||
|
+ width: listView.width
|
||||||
|
+ }
|
||||||
|
+ }
|
||||||
|
+ }
|
||||||
|
+ }
|
||||||
|
+
|
||||||
|
+ // Tests that scroll bars show up for a ScrollView where
|
||||||
|
+ // - its contentItem is declared as a standalone, separate item
|
||||||
|
+ // - there is a binding to contentItem (which causes a default Flickable to be created)
|
||||||
|
+ function test_bindingToContentItemAndStandaloneFlickable() {
|
||||||
|
+ let root = createTemporaryObject(bindingToContentItemAndStandaloneFlickable, testCase)
|
||||||
|
+ verify(root)
|
||||||
|
+
|
||||||
|
+ let control = root.scrollView
|
||||||
|
+ let verticalScrollBar = control.ScrollBar.vertical
|
||||||
|
+ let horizontalScrollBar = control.ScrollBar.horizontal
|
||||||
|
+ compare(verticalScrollBar.parent, control)
|
||||||
|
+ compare(horizontalScrollBar.parent, control)
|
||||||
|
+ verify(verticalScrollBar.visible)
|
||||||
|
+ verify(horizontalScrollBar.visible)
|
||||||
|
+
|
||||||
|
+ mouseDrag(verticalScrollBar, verticalScrollBar.width / 2, verticalScrollBar.height / 2, 0, 50)
|
||||||
|
+ verify(verticalScrollBar.active)
|
||||||
|
+ verify(horizontalScrollBar.active)
|
||||||
|
+ }
|
||||||
|
}
|
||||||
|
--
|
||||||
|
2.37.2
|
||||||
|
|
@ -3,13 +3,21 @@
|
|||||||
Name: qt5-%{qt_module}
|
Name: qt5-%{qt_module}
|
||||||
Summary: Qt5 - module with set of QtQuick controls for embedded
|
Summary: Qt5 - module with set of QtQuick controls for embedded
|
||||||
Version: 5.15.5
|
Version: 5.15.5
|
||||||
Release: 2%{?dist}
|
Release: 3%{?dist}
|
||||||
|
|
||||||
License: GPLv2+ or LGPLv3 and GFDL
|
License: GPLv2+ or LGPLv3 and GFDL
|
||||||
Url: http://www.qt.io
|
Url: http://www.qt.io
|
||||||
%global majmin %(echo %{version} | cut -d. -f1-2)
|
%global majmin %(echo %{version} | cut -d. -f1-2)
|
||||||
Source0: https://download.qt.io/official_releases/qt/%{majmin}/%{version}/submodules/%{qt_module}-everywhere-opensource-src-%{version}.tar.xz
|
Source0: https://download.qt.io/official_releases/qt/%{majmin}/%{version}/submodules/%{qt_module}-everywhere-opensource-src-%{version}.tar.xz
|
||||||
|
|
||||||
|
Patch1: 0001-Unset-mouseGrabberPopup-if-it-s-removed-from-childre.patch
|
||||||
|
Patch2: 0002-Ensure-we-don-t-crash-when-changing-sizes-after-clea.patch
|
||||||
|
Patch3: 0003-QQuickAction-don-t-grab-the-same-shortcut-multiple-t.patch
|
||||||
|
Patch4: 0004-QQuickAbstractButton-fix-crash-on-destruction.patch
|
||||||
|
Patch5: 0005-Revert-Allow-creation-of-custom-QQuickPopupItem-deri.patch
|
||||||
|
Patch6: 0006-Fix-scroll-bars-not-showing-up-when-binding-to-stand.patch
|
||||||
|
|
||||||
|
|
||||||
# filter qml provides
|
# filter qml provides
|
||||||
%global __provides_exclude_from ^%{_qt5_archdatadir}/qml/.*\\.so$
|
%global __provides_exclude_from ^%{_qt5_archdatadir}/qml/.*\\.so$
|
||||||
|
|
||||||
@ -104,6 +112,9 @@ rm -f %{buildroot}%{_qt5_libdir}/libQt5*.la
|
|||||||
%{_libdir}/cmake/Qt5QuickTemplates2/
|
%{_libdir}/cmake/Qt5QuickTemplates2/
|
||||||
|
|
||||||
%changelog
|
%changelog
|
||||||
|
* Wed Aug 24 2022 Jan Grulich <jgrulich@redhat.com> - 5.15.5-3
|
||||||
|
- Backport fixes from Qt patch collection
|
||||||
|
|
||||||
* Sat Jul 23 2022 Fedora Release Engineering <releng@fedoraproject.org> - 5.15.5-2
|
* Sat Jul 23 2022 Fedora Release Engineering <releng@fedoraproject.org> - 5.15.5-2
|
||||||
- Rebuilt for https://fedoraproject.org/wiki/Fedora_37_Mass_Rebuild
|
- Rebuilt for https://fedoraproject.org/wiki/Fedora_37_Mass_Rebuild
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user