bisected different upstream commit as culprit for plasma notification crasher (#1758263)
This commit is contained in:
parent
a438d8b4e3
commit
9cec05b881
115
0026-Fix-ListView-footer-positioned-wrong-after-last-item.patch
Normal file
115
0026-Fix-ListView-footer-positioned-wrong-after-last-item.patch
Normal file
@ -0,0 +1,115 @@
|
|||||||
|
From 692b2da77427259a3589cf8a1311075863f2f5ec Mon Sep 17 00:00:00 2001
|
||||||
|
From: Eirik Aavitsland <eirik.aavitsland@qt.io>
|
||||||
|
Date: Fri, 21 Jun 2019 15:12:36 +0200
|
||||||
|
Subject: [PATCH 26/56] Fix: ListView footer positioned wrong after last item
|
||||||
|
removed
|
||||||
|
|
||||||
|
The refill() method would bail out early on an empty model. Make sure
|
||||||
|
that it at least updates the header and footer in such situations.
|
||||||
|
|
||||||
|
Fixes: QTBUG-31677
|
||||||
|
Change-Id: I1f3a1848ff263a8f7f9ccfc3b20f16b61348f57b
|
||||||
|
Reviewed-by: Mitch Curtis <mitch.curtis@qt.io>
|
||||||
|
---
|
||||||
|
src/quick/items/qquickitemview.cpp | 8 ++++-
|
||||||
|
.../quick/qquicklistview/data/footer2.qml | 33 +++++++++++++++++++
|
||||||
|
.../qquicklistview/tst_qquicklistview.cpp | 16 +++++++++
|
||||||
|
3 files changed, 56 insertions(+), 1 deletion(-)
|
||||||
|
create mode 100644 tests/auto/quick/qquicklistview/data/footer2.qml
|
||||||
|
|
||||||
|
diff --git a/src/quick/items/qquickitemview.cpp b/src/quick/items/qquickitemview.cpp
|
||||||
|
index eead84d51..d0715cdb7 100644
|
||||||
|
--- a/src/quick/items/qquickitemview.cpp
|
||||||
|
+++ b/src/quick/items/qquickitemview.cpp
|
||||||
|
@@ -1717,8 +1717,14 @@ void QQuickItemViewPrivate::refill()
|
||||||
|
void QQuickItemViewPrivate::refill(qreal from, qreal to)
|
||||||
|
{
|
||||||
|
Q_Q(QQuickItemView);
|
||||||
|
- if (!isValid() || !q->isComponentComplete())
|
||||||
|
+ if (!model || !model->isValid() || !q->isComponentComplete())
|
||||||
|
return;
|
||||||
|
+ if (!model->count()) {
|
||||||
|
+ updateHeader();
|
||||||
|
+ updateFooter();
|
||||||
|
+ updateViewport();
|
||||||
|
+ return;
|
||||||
|
+ }
|
||||||
|
|
||||||
|
do {
|
||||||
|
bufferPause.stop();
|
||||||
|
diff --git a/tests/auto/quick/qquicklistview/data/footer2.qml b/tests/auto/quick/qquicklistview/data/footer2.qml
|
||||||
|
new file mode 100644
|
||||||
|
index 000000000..bba74d89f
|
||||||
|
--- /dev/null
|
||||||
|
+++ b/tests/auto/quick/qquicklistview/data/footer2.qml
|
||||||
|
@@ -0,0 +1,33 @@
|
||||||
|
+import QtQuick 2.0
|
||||||
|
+
|
||||||
|
+Rectangle {
|
||||||
|
+ width: 240
|
||||||
|
+ height: 320
|
||||||
|
+
|
||||||
|
+ Timer {
|
||||||
|
+ running: true
|
||||||
|
+ repeat: false
|
||||||
|
+ interval: 100
|
||||||
|
+ onTriggered: {
|
||||||
|
+ list.model -= 3;
|
||||||
|
+ }
|
||||||
|
+ }
|
||||||
|
+
|
||||||
|
+ ListView {
|
||||||
|
+ id: list
|
||||||
|
+ objectName: "list"
|
||||||
|
+ anchors.fill: parent
|
||||||
|
+ model: 3
|
||||||
|
+ delegate: Rectangle {
|
||||||
|
+ color: "red"
|
||||||
|
+ width: 240
|
||||||
|
+ height: 10
|
||||||
|
+ }
|
||||||
|
+ footer: Rectangle {
|
||||||
|
+ color: "blue"
|
||||||
|
+ width: 240
|
||||||
|
+ height: 10
|
||||||
|
+ }
|
||||||
|
+ }
|
||||||
|
+}
|
||||||
|
+
|
||||||
|
diff --git a/tests/auto/quick/qquicklistview/tst_qquicklistview.cpp b/tests/auto/quick/qquicklistview/tst_qquicklistview.cpp
|
||||||
|
index fddba77f3..cfd740f33 100644
|
||||||
|
--- a/tests/auto/quick/qquicklistview/tst_qquicklistview.cpp
|
||||||
|
+++ b/tests/auto/quick/qquicklistview/tst_qquicklistview.cpp
|
||||||
|
@@ -152,6 +152,7 @@ private slots:
|
||||||
|
void headerChangesViewport();
|
||||||
|
void footer();
|
||||||
|
void footer_data();
|
||||||
|
+ void footer2();
|
||||||
|
void extents();
|
||||||
|
void extents_data();
|
||||||
|
void resetModel_headerFooter();
|
||||||
|
@@ -4138,6 +4139,21 @@ void tst_QQuickListView::footer_data()
|
||||||
|
<< QPointF(0, -(30 * 20) - 10);
|
||||||
|
}
|
||||||
|
|
||||||
|
+void tst_QQuickListView::footer2() // QTBUG-31677
|
||||||
|
+{
|
||||||
|
+ QQuickView *window = getView();
|
||||||
|
+ window->setSource(testFileUrl("footer2.qml"));
|
||||||
|
+ window->show();
|
||||||
|
+ QVERIFY(QTest::qWaitForWindowExposed(window));
|
||||||
|
+
|
||||||
|
+ QQuickListView *listview = findItem<QQuickListView>(window->rootObject(), "list");
|
||||||
|
+ QTRY_VERIFY(listview != nullptr);
|
||||||
|
+
|
||||||
|
+ QQuickItem *footer = listview->footerItem();
|
||||||
|
+ QVERIFY(footer != nullptr);
|
||||||
|
+ QTRY_COMPARE(footer->y(), 0.0);
|
||||||
|
+}
|
||||||
|
+
|
||||||
|
class LVAccessor : public QQuickListView
|
||||||
|
{
|
||||||
|
public:
|
||||||
|
--
|
||||||
|
2.21.0
|
||||||
|
|
@ -1,162 +0,0 @@
|
|||||||
From f806d64249c6e961ab12270d3a045e9980e19cf4 Mon Sep 17 00:00:00 2001
|
|
||||||
From: Wang Chuan <ouchuanm@outlook.com>
|
|
||||||
Date: Thu, 11 Jul 2019 10:24:38 +0800
|
|
||||||
Subject: [PATCH 45/56] QQuickItemView: refill itself before populate
|
|
||||||
transition
|
|
||||||
|
|
||||||
The view uses a visible items list, which is maintained by the refill()
|
|
||||||
method, to determine which items should be triggered to do the populate
|
|
||||||
transition. The refill() was only invoked when component completed
|
|
||||||
before doing the populate transition; but if the size of the view
|
|
||||||
depends on the size of window (for example, using anchors.fill), more
|
|
||||||
delegates could become visible after component completed. In such a
|
|
||||||
case, part of visible items were not be triggered to do the transition.
|
|
||||||
|
|
||||||
[ChangeLog][QtQuick][Item Views] Item views such as ListView now properly
|
|
||||||
populate delegates with a populate transition when the view is resized
|
|
||||||
after componentComplete.
|
|
||||||
|
|
||||||
Fixes: QTBUG-76487
|
|
||||||
Change-Id: Id90c3f73d9911c8a1d6d8b1ea0c51f6c27d0ed5b
|
|
||||||
Reviewed-by: Shawn Rutledge <shawn.rutledge@qt.io>
|
|
||||||
---
|
|
||||||
src/quick/items/qquickitemview.cpp | 3 +
|
|
||||||
.../data/resizeAfterComponentComplete.qml | 77 +++++++++++++++++++
|
|
||||||
.../qquicklistview/tst_qquicklistview.cpp | 16 ++++
|
|
||||||
3 files changed, 96 insertions(+)
|
|
||||||
create mode 100644 tests/auto/quick/qquicklistview/data/resizeAfterComponentComplete.qml
|
|
||||||
|
|
||||||
diff --git a/src/quick/items/qquickitemview.cpp b/src/quick/items/qquickitemview.cpp
|
|
||||||
index d0715cdb7..21d644dad 100644
|
|
||||||
--- a/src/quick/items/qquickitemview.cpp
|
|
||||||
+++ b/src/quick/items/qquickitemview.cpp
|
|
||||||
@@ -1845,6 +1845,9 @@ void QQuickItemViewPrivate::layout()
|
|
||||||
forceLayout = false;
|
|
||||||
|
|
||||||
if (transitioner && transitioner->canTransition(QQuickItemViewTransitioner::PopulateTransition, true)) {
|
|
||||||
+ // Give the view one more chance to refill itself,
|
|
||||||
+ // in case its size is changed such that more delegates become visible after component completed
|
|
||||||
+ refill();
|
|
||||||
for (FxViewItem *item : qAsConst(visibleItems)) {
|
|
||||||
if (!item->transitionScheduledOrRunning())
|
|
||||||
item->transitionNextReposition(transitioner, QQuickItemViewTransitioner::PopulateTransition, true);
|
|
||||||
diff --git a/tests/auto/quick/qquicklistview/data/resizeAfterComponentComplete.qml b/tests/auto/quick/qquicklistview/data/resizeAfterComponentComplete.qml
|
|
||||||
new file mode 100644
|
|
||||||
index 000000000..851d8f9a0
|
|
||||||
--- /dev/null
|
|
||||||
+++ b/tests/auto/quick/qquicklistview/data/resizeAfterComponentComplete.qml
|
|
||||||
@@ -0,0 +1,77 @@
|
|
||||||
+/****************************************************************************
|
|
||||||
+**
|
|
||||||
+** Copyright (C) 2019 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.12
|
|
||||||
+
|
|
||||||
+ListView {
|
|
||||||
+ id: listView
|
|
||||||
+ property var lastItem
|
|
||||||
+ anchors.fill: parent
|
|
||||||
+ model: 10
|
|
||||||
+ delegate: Rectangle {
|
|
||||||
+ width: parent.width
|
|
||||||
+ height: 40
|
|
||||||
+ border.color: "lightsteelblue"
|
|
||||||
+ Text {
|
|
||||||
+ text: "Item" + (index + 1)
|
|
||||||
+ }
|
|
||||||
+ Component.onCompleted: {
|
|
||||||
+ if (index == 9)
|
|
||||||
+ listView.lastItem = this
|
|
||||||
+ }
|
|
||||||
+ }
|
|
||||||
+
|
|
||||||
+ populate: Transition {
|
|
||||||
+ NumberAnimation {
|
|
||||||
+ properties: "x,y"
|
|
||||||
+ duration: 1000
|
|
||||||
+ }
|
|
||||||
+ }
|
|
||||||
+}
|
|
||||||
diff --git a/tests/auto/quick/qquicklistview/tst_qquicklistview.cpp b/tests/auto/quick/qquicklistview/tst_qquicklistview.cpp
|
|
||||||
index cfd740f33..d956d8929 100644
|
|
||||||
--- a/tests/auto/quick/qquicklistview/tst_qquicklistview.cpp
|
|
||||||
+++ b/tests/auto/quick/qquicklistview/tst_qquicklistview.cpp
|
|
||||||
@@ -276,6 +276,7 @@ private slots:
|
|
||||||
void addOnCompleted();
|
|
||||||
void setPositionOnLayout();
|
|
||||||
void touchCancel();
|
|
||||||
+ void resizeAfterComponentComplete();
|
|
||||||
|
|
||||||
private:
|
|
||||||
template <class T> void items(const QUrl &source);
|
|
||||||
@@ -8994,6 +8995,21 @@ void tst_QQuickListView::touchCancel() // QTBUG-74679
|
|
||||||
QTRY_COMPARE(listview->contentY(), 500.0);
|
|
||||||
}
|
|
||||||
|
|
||||||
+void tst_QQuickListView::resizeAfterComponentComplete() // QTBUG-76487
|
|
||||||
+{
|
|
||||||
+ QScopedPointer<QQuickView> window(createView());
|
|
||||||
+ window->setSource(testFileUrl("resizeAfterComponentComplete.qml"));
|
|
||||||
+ window->resize(640, 480);
|
|
||||||
+ window->show();
|
|
||||||
+ QVERIFY(QTest::qWaitForWindowExposed(window.data()));
|
|
||||||
+
|
|
||||||
+ QObject *listView = window->rootObject();
|
|
||||||
+ QVERIFY(listView);
|
|
||||||
+
|
|
||||||
+ QObject *lastItem = qvariant_cast<QObject *>(listView->property("lastItem"));
|
|
||||||
+ QTRY_COMPARE(lastItem->property("y").toInt(), 9 * lastItem->property("height").toInt());
|
|
||||||
+}
|
|
||||||
+
|
|
||||||
QTEST_MAIN(tst_QQuickListView)
|
|
||||||
|
|
||||||
#include "tst_qquicklistview.moc"
|
|
||||||
--
|
|
||||||
2.21.0
|
|
||||||
|
|
@ -8,7 +8,7 @@
|
|||||||
Summary: Qt5 - QtDeclarative component
|
Summary: Qt5 - QtDeclarative component
|
||||||
Name: qt5-%{qt_module}
|
Name: qt5-%{qt_module}
|
||||||
Version: 5.12.5
|
Version: 5.12.5
|
||||||
Release: 2%{?dist}
|
Release: 3%{?dist}
|
||||||
|
|
||||||
# See LICENSE.GPL LICENSE.LGPL LGPL_EXCEPTION.txt, for details
|
# See LICENSE.GPL LICENSE.LGPL LGPL_EXCEPTION.txt, for details
|
||||||
License: LGPLv2 with exceptions or GPLv3 with exceptions
|
License: LGPLv2 with exceptions or GPLv3 with exceptions
|
||||||
@ -25,7 +25,7 @@ Source5: qv4global_p-multilib.h
|
|||||||
## upstreamable patches
|
## upstreamable patches
|
||||||
# revert upstream commit that seemingly causes regressions with plasma-5.15.x notifcations applet
|
# revert upstream commit that seemingly causes regressions with plasma-5.15.x notifcations applet
|
||||||
# https://bugzilla.redhat.com/1758263
|
# https://bugzilla.redhat.com/1758263
|
||||||
Patch145: 0045-QQuickItemView-refill-itself-before-populate-transit.patch
|
Patch126: 0026-Fix-ListView-footer-positioned-wrong-after-last-item.patch
|
||||||
|
|
||||||
# filter qml provides
|
# filter qml provides
|
||||||
%global __provides_exclude_from ^%{_qt5_archdatadir}/qml/.*\\.so$
|
%global __provides_exclude_from ^%{_qt5_archdatadir}/qml/.*\\.so$
|
||||||
@ -81,7 +81,7 @@ Requires: %{name}%{?_isa} = %{version}-%{release}
|
|||||||
%prep
|
%prep
|
||||||
%setup -q -n %{qt_module}-everywhere-src-%{version}
|
%setup -q -n %{qt_module}-everywhere-src-%{version}
|
||||||
|
|
||||||
%patch145 -p1 -R
|
%patch126 -p1 -R
|
||||||
|
|
||||||
|
|
||||||
%build
|
%build
|
||||||
@ -196,6 +196,9 @@ make check -k -C tests ||:
|
|||||||
|
|
||||||
|
|
||||||
%changelog
|
%changelog
|
||||||
|
* Tue Oct 08 2019 Rex Dieter <rdieter@fedoraproject.org> - 5.12.5-3
|
||||||
|
- bisected different upstream commit as culprit for plasma notification crasher (#1758263)
|
||||||
|
|
||||||
* Mon Oct 07 2019 Rex Dieter <rdieter@fedoraproject.org> - 5.12.5-2
|
* Mon Oct 07 2019 Rex Dieter <rdieter@fedoraproject.org> - 5.12.5-2
|
||||||
- revert upstream commit possibly related to plasma notification applet crashes (#1758263)
|
- revert upstream commit possibly related to plasma notification applet crashes (#1758263)
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user