SUMMARY I build kdenlive from git branch Applications/19.04 (build type RelWithDebInfo), on top of a self-compiled Qt 5.13 from git, in debug mode. kdenlive asserts on startup, because setProperty() is called on GLWidget (a QQuickView) from the QtQuick render thread. setProperty calls sendEvent (with a QDynamicPropertyChangeEvent), which leads to the assert. (gdb) bt #0 0x00007fffed807160 in raise () at /lib64/libc.so.6 #1 0x00007fffed808741 in abort () at /lib64/libc.so.6 #2 0x00007fffee722044 in qt_message_fatal(QtMsgType, QMessageLogContext const&, QString const&) (context=..., message="ASSERT failure in QCoreApplication::sendEvent: \"Cannot send events to objects owned by a different thread. Current thread 0x0x5446c90. Receiver '' (of type 'GLWidget') was created in thread 0x0xe57a80\", file /d/qt/5/kde/qtbase/src/corelib/kernel/qcoreapplication.cpp, line 578") at /d/qt/5/kde/qtbase/src/corelib/global/qlogging.cpp:1904 #3 0x00007fffee722b30 in QMessageLogger::fatal(char const*, ...) const (this=this@entry=0x7fff8dc033b0, msg=msg@entry=0x7fffee9d9858 "ASSERT failure in %s: \"%s\", file %s, line %d") at /d/qt/5/kde/qtbase/src/corelib/global/qlogging.cpp:888 #4 0x00007fffee71cb69 in qt_assert_x(char const*, char const*, char const*, int) (where=where@entry=0x7fffeeab30cb "QCoreApplication::sendEvent", what=<optimized out>, file=file@entry=0x7fffeeab2968 "/d/qt/5/kde/qtbase/src/corelib/kernel/qcoreapplication.cpp", line=line@entry=578) at /d/qt/5/kde/qtbase/src/corelib/global/qglobal.cpp:3262 #5 0x00007fffee8f4d9d in QCoreApplicationPrivate::checkReceiverThread(QObject*) (receiver=receiver@entry=0x25ecff0) at /d/qt/5/kde/qtbase/src/corelib/kernel/qcoreapplication.cpp:572 #6 0x00007ffff04a0c0a in QApplication::notify(QObject*, QEvent*) (this=0x7fffffffcce0, receiver=0x25ecff0, e=0x7fff8dc036b0) at /d/qt/5/kde/qtbase/src/widgets/kernel/qapplication.cpp:2942 #7 0x00007fffee8f5378 in QCoreApplication::notifyInternal2(QObject*, QEvent*) (receiver=0x25ecff0, event=0x7fff8dc036b0) at /d/qt/5/kde/qtbase/src/corelib/kernel/qcoreapplication.cpp:1086 #8 0x00007fffee8f55a0 in QCoreApplication::sendEvent(QObject*, QEvent*) (receiver=<optimized out>, event=<optimized out>) at /d/qt/5/kde/qtbase/src/corelib/kernel/qcoreapplication.cpp:1481 #9 0x00007fffee92e13b in QObject::setProperty(char const*, QVariant const&) (this=this@entry=0x25ecff0, name=name@entry=0xade4de "mlt_service", value=...) at /d/qt/5/kde/qtbase/src/corelib/kernel/qobject.cpp:3946 #10 0x0000000000785058 in GLWidget::reconfigure(bool) (this=this@entry=0x25ecff0, reload=reload@entry=false) at /d/kde/src/5/kde/kdemultimedia/kdenlive/src/monitor/glwidget.cpp:1222 #11 0x0000000000785c9c in GLWidget::initializeGL() (this=0x25ecff0) at /d/kde/src/5/kde/kdemultimedia/kdenlive/src/monitor/glwidget.cpp:227 #12 0x00007fffee926fd3 in QtPrivate::QSlotObjectBase::call(QObject*, void**) (a=0x7fff8dc039c8, r=0x25ecff0, this=<optimized out>) at ../../include/QtCore/../../../../qtbase/src/corelib/kernel/qobjectdefs_impl.h:394 #13 0x00007fffee926fd3 in QMetaObject::activate(QObject*, int, int, void**) (sender=sender@entry=0x25ecff0, signalOffset=<optimized out>, local_signal_index=local_signal_index@entry=2, argv=0x7fff8dc039c8, argv@entry=0x0) at /d/qt/5/kde/qtbase/src/corelib/kernel/qobject.cpp:3787 #14 0x00007fffee927429 in QMetaObject::activate(QObject*, QMetaObject const*, int, void**) (sender=0x25ecff0, m=m@entry=0x7ffff2cc3b00 <QQuickWindow::staticMetaObject>, local_signal_index=local_signal_index@entry=2, argv=argv@entry=0x0) at /d/qt/5/kde/qtbase/src/corelib/kernel/qobject.cpp:3658 #15 0x00007ffff2806098 in QQuickWindow::sceneGraphInitialized() (this=<optimized out>) at .moc/moc_qquickwindow.cpp:503 #16 0x00007ffff280a466 in QQuickWindow::qt_static_metacall(QObject*, QMetaObject::Call, int, void**) (_o=_o@entry=0x25ecff0, _c=_c@entry=QMetaObject::InvokeMetaMethod, _id=_id@entry=2, _a=_a@entry=0x7fff8dc03b18) at .moc/moc_qquickwindow.cpp:263 #17 0x00007fffee92715d in QMetaObject::activate(QObject*, int, int, void**) (sender=sender@entry=0x263fae0, signalOffset=<optimized out>, local_signal_index=local_signal_index@entry=0, argv=0x7fff8dc03b18, argv@entry=0x0) at /d/qt/5/kde/qtbase/src/corelib/kernel/qobject.cpp:3807 #18 0x00007fffee927429 in QMetaObject::activate(QObject*, QMetaObject const*, int, void**) (sender=sender@entry=0x263fae0, m=m@entry=0x7ffff2cbebc0 <QSGRenderContext::staticMetaObject>, local_signal_index=local_signal_index@entry=0, argv=argv@entry=0x0) at /d/qt/5/kde/qtbase/src/corelib/kernel/qobject.cpp:3658 #19 0x00007ffff277d26e in QSGRenderContext::initialized() (this=this@entry=0x263fae0) at .moc/moc_qsgcontext_p.cpp:221 #20 0x00007ffff279f232 in QSGDefaultRenderContext::initialize(void*) (this=0x263fae0, context=<optimized out>) at /d/qt/5/kde/qtdeclarative/src/quick/scenegraph/qsgdefaultrendercontext.cpp:112 #21 0x00007ffff27aeee4 in QSGRenderThread::run() (this=0x5446c90) at /d/qt/5/kde/qtdeclarative/src/quick/scenegraph/qsgthreadedrenderloop.cpp:729 #22 0x00007fffee72d010 in QThreadPrivate::start(void*) (arg=0x5446c90) at /d/qt/5/kde/qtbase/src/corelib/thread/qthread_unix.cpp:364 #23 0x00007fffea99d569 in start_thread () at /lib64/libpthread.so.0 #24 0x00007fffed8c99ef in clone () at /lib64/libc.so.6 (gdb) fr 10 #10 0x0000000000785058 in GLWidget::reconfigure (this=this@entry=0x25ecff0, reload=reload@entry=false) at /d/kde/src/5/kde/kdemultimedia/kdenlive/src/monitor/glwidget.cpp:1222 1222 setProperty("mlt_service", serviceName); (gdb) p thread() [Thread 0x7fffb5625700 (LWP 17890) exited] $1 = (QAdoptedThread *) 0xe57a80 I'm guessing the GLWidget was created in this thread: (gdb) thr 13 [Switching to thread 13 (Thread 0x7fff8f9c5700 (LWP 17898))] #0 0x00007fffed8c4269 in syscall () from /lib64/libc.so.6 (gdb) bt #0 0x00007fffed8c4269 in syscall () at /lib64/libc.so.6 #1 0x00007fffee72f705 in QtLinuxFutex::_q_futex(int*, int, int, unsigned long long, int*, int) (val3=0, addr2=0x0, val2=0, val=0, op=0, addr=<optimized out>) at /d/qt/5/kde/qtbase/src/corelib/thread/qfutex_p.h:92 #2 0x00007fffee72f705 in QtLinuxFutex::futexWait<QBasicAtomicInteger<unsigned int> >(QBasicAtomicInteger<unsigned int>&, QBasicAtomicInteger<unsigned int>::Type) (expectedValue=0, futex=...) at /d/qt/5/kde/qtbase/src/corelib/thread/qfutex_p.h:107 #3 0x00007fffee72f705 in futexSemaphoreTryAcquire_loop<false>(QBasicAtomicInteger<unsigned long long>&, unsigned long long, unsigned long long, int) (u=..., curValue=curValue@entry=4294967296, nn=nn@entry=8589934593, timeout=timeout@entry=-1) at /d/qt/5/kde/qtbase/src/corelib/thread/qsemaphore.cpp:219 #4 0x00007fffee72f828 in futexSemaphoreTryAcquire<false>(QBasicAtomicInteger<unsigned long long>&, int, int) (u=..., n=n@entry=1, timeout=timeout@entry=-1) at /d/qt/5/kde/qtbase/src/corelib/thread/qsemaphore.cpp:262 #5 0x00007fffee72f5e8 in QSemaphore::acquire(int) (this=this@entry=0x2b0f388, n=n@entry=1) at /d/qt/5/kde/qtbase/src/corelib/thread/qsemaphore.cpp:326 #6 0x000000000078213e in GLWidget::createThread(RenderThread**, void* (*)(void*), void*) (this=0x2b0f2d0, thread=0x64ebe70, function=0x7ffff1e6a410, data=0x6526090) at /d/kde/src/5/kde/kdemultimedia/kdenlive/src/monitor/glwidget.cpp:850 #7 0x0000000000782195 in onThreadCreate(mlt_properties, GLWidget*, RenderThread**, int*, thread_function_t, void*) (owner=<optimized out>, self=0x2b0f2d0, thread=<optimized out>, priority=<optimized out>, function=<optimized out>, data=<optimized out>) at /d/kde/src/5/kde/kdemultimedia/kdenlive/src/monitor/glwidget.cpp:862 #8 0x00007ffff1e61b9e in mlt_events_fire () at /usr/lib64/libmlt.so.6 #9 0x00007ffff1e6b8e7 in mlt_consumer_rt_frame () at /usr/lib64/libmlt.so.6 #10 0x00007fffbd0e0e30 in () at /usr/lib64/mlt-6/libmltsdl2.so #11 0x00007fffea99d569 in start_thread () at /lib64/libpthread.so.0 #12 0x00007fffed8c99ef in clone () at /lib64/libc.so.6 I guess the fix is to use a queued invokeMethod for this setProperty call? Assuming of course that it can wait until the owner thread processes it... STEPS TO REPRODUCE 1. kdenlive Linux: openSUSE Leap 15.1 (but Qt/KF5/kdenlive compiled by me) KDE Plasma Version: 5.16.3 KDE Frameworks Version: 5.60.0 Qt Version: 5.13.0 ADDITIONAL INFORMATION I can test a fix if you provide one.
Build Kdenlive is tricky because you need lot's of libraries. Do you followed this steps: https://community.kde.org/Kdenlive/Development I all fails try with the current Kdenlive AppImage version 19.04.3b https://files.kde.org/kdenlive/release/
Confirmed with current Git master 4ce5e54f.
Confirming this with Linux: Gentoo KDE Plasma Version: 5.19.5 KDE Frameworks Version: 5.74.0 Qt Version: 5.15.1
*** Bug 428632 has been marked as a duplicate of this bug. ***
Please note my debug results: https://bugs.kde.org/show_bug.cgi?id=428632#c2
Can you please test again? This has hopefully been fixed to day with https://invent.kde.org/multimedia/kdenlive/-/commit/5f712c9178170af239ad1db0b21caf130e350e3d
Julius, it works. Kdenlive starts now. But I get new crash: just after kdenlive is started -> "New" button click -> change nothing in ProjectSettings dialog -> "Ok"-> crash 1 Mlt::Properties::set(const char *, int) 0x7ffff5640010 2 GLWidget::requestRefresh shared_ptr_base.h 1020 0x5555559018f2 3 ProjectManager::disableBinEffects unique_ptr.h 154 0x55555597598d 4 Bin::setBinEffectsEnabled unique_ptr.h 154 0x555555730f8c 5 Bin::setDocument bin.cpp 1692 0x555555742ed1 6 ProjectManager::newFile unique_ptr.h 154 0x55555597bc4d 7 ProjectManager::newFile projectmanager.cpp 142 0x55555597c58d 8 ProjectManager::qt_static_metacall moc_projectmanager.cpp 216 0x555555656b3a 9 doActivate<false> qobject.cpp 3898 0x7ffff513bea0 10 QMetaObject::activate qobject.cpp 3946 0x7ffff5134f1a 11 QAction::triggered moc_qaction.cpp 379 0x7ffff6684b02 12 QAction::activate qaction.cpp 1161 0x7ffff66877c2 13 QAbstractButtonPrivate::click qabstractbutton.cpp ....
Git commit f32f9d9f1709e9aeb7c68afea28b95895cf10c76 by Jean-Baptiste Mardelle. Committed on 30/03/2021 at 13:34. Pushed by mardelle into branch 'release/21.04'. Fix unconfigured consumer causing various crashes. M +1 -0 src/monitor/glwidget.cpp M +1 -1 src/monitor/glwidget.h https://invent.kde.org/multimedia/kdenlive/commit/f32f9d9f1709e9aeb7c68afea28b95895cf10c76
Git commit 11e5be5ea2c98fda76780aec9a9f796fe6ef14e2 by Jean-Baptiste Mardelle. Committed on 30/03/2021 at 13:35. Pushed by mardelle into branch 'master'. Fix unconfigured consumer causing various crashes. M +1 -0 src/monitor/glwidget.cpp M +1 -1 src/monitor/glwidget.h https://invent.kde.org/multimedia/kdenlive/commit/11e5be5ea2c98fda76780aec9a9f796fe6ef14e2
New fix! Please try again…
Jean-Baptiste, I've applied new fix to version 20.12.3. At that point it is not crashed now. New crash: new crash: just after kdenlive is started -> "New" button click -> change nothing in ProjectSettings dialog -> "Ok"-> click to ClipMonitor ->crash 1 __GI_raise raise.c 49 0x7ffff48b4d21 2 __GI_abort abort.c 79 0x7ffff489e536 3 __gnu_cxx::__verbose_terminate_handler vterminate.cc 95 0x7ffff4c1d753 4 __cxxabiv1::__terminate eh_terminate.cc 48 0x7ffff4c4d7d6 5 std::terminate eh_terminate.cc 58 0x7ffff4c4d841 6 __cxxabiv1::__cxa_pure_virtual pure.cc 50 0x7ffff4c4e61f 7 QAbstractItemModel::beginRemoveRows qabstractitemmodel.cpp 2815 0x7ffff506d222 8 TimelineModel::<lambda()>::operator() timelinemodel.cpp 3624 0x555555a3ca41 9 std::_Function_handler<bool(), TimelineModel::deregisterTrack_lambda(int)::<lambda()>>::_M_invoke std_function.h 285 0x555555a3ca41 10 std::function<bool ()>::operator()() const std_function.h 688 0x555555a3ca41 11 TimelineModel::~TimelineModel timelinemodel.cpp 160 0x555555a3ca41 12 TimelineItemModel::~TimelineItemModel timelineitemmodel.hpp 48 0x5555559fa7c7 13 TimelineItemModel::~TimelineItemModel timelineitemmodel.hpp 48 0x5555559fa7c7 14 std::_Sp_counted_base<(__gnu_cxx::_Lock_policy)2>::_M_release shared_ptr_base.h 155 0x55555573960a 15 std::_Sp_counted_base<(__gnu_cxx::_Lock_policy)2>::_M_release shared_ptr_base.h 148 0x55555573960a 16 std::__shared_count<(__gnu_cxx::_Lock_policy)2>::operator= shared_ptr_base.h 749 0x55555573960a 17 std::__shared_ptr<TimelineItemModel, (__gnu_cxx::_Lock_policy)2>::operator= shared_ptr_base.h 1080 0x55555573960a 18 std::shared_ptr<TimelineItemModel>::operator= shared_ptr.h 103 0x55555573960a 19 MixerManager::setModel mixermanager.cpp 147 0x55555573960a 20 ProjectManager::newFile projectmanager.cpp 230 0x5555559a696b 21 ProjectManager::newFile projectmanager.cpp 142 0x5555559a721d 22 ProjectManager::qt_static_metacall moc_projectmanager.cpp 221 0x55555565c48a 23 doActivate<false> qobject.cpp 3898 0x7ffff50f6ea0 24 QMetaObject::activate qobject.cpp 3946 0x7ffff50eff1a 25 QAction::triggered moc_qaction.cpp 379 0x7ffff663fb02 26 QAction::activate qaction.cpp 1161 0x7ffff66427c2 27 QAbstractButtonPrivate::click qabstractbutton.cpp 398 0x7ffff674b75c 28 QAbstractButton::mouseReleaseEvent qabstractbutton.cpp 1044 0x7ffff674b9d1 29 QToolButton::mouseReleaseEvent qtoolbutton.cpp 622 0x7ffff685182a 30 QWidget::event qwidget.cpp 9019 0x7ffff668e4be 31 QAbstractButton::event qabstractbutton.cpp 1001 0x7ffff674cd43 32 QToolButton::event qtoolbutton.cpp 1012 0x7ffff68518d4 33 QApplicationPrivate::notify_helper qapplication.cpp 3632 0x7ffff6646f73 34 QApplication::notify qapplication.cpp 3076 0x7ffff664f9e7 35 QCoreApplication::notifyInternal2 qcoreapplication.cpp 1063 0x7ffff50bdccf 36 QApplicationPrivate::sendMouseEvent qapplication.cpp 2614 0x7ffff664ec6a 37 QWidgetWindow::handleMouseEvent qwidgetwindow.cpp 683 0x7ffff66aa95e 38 QWidgetWindow::event qwidgetwindow.cpp 300 0x7ffff66addec 39 QWidgetWindow::event qwidgetwindow.cpp 239 0x7ffff66addec 40 QApplicationPrivate::notify_helper qapplication.cpp 3632 0x7ffff6646f73 41 QApplication::notify qapplication.cpp 3156 0x7ffff664f800 42 QCoreApplication::notifyInternal2 qcoreapplication.cpp 1063 0x7ffff50bdccf 43 QGuiApplicationPrivate::processMouseEvent qguiapplication.cpp 2282 0x7ffff57a3480 44 QGuiApplicationPrivate::processWindowSystemEvent qguiapplication.cpp 2002 0x7ffff57a4b95 45 QWindowSystemInterface::sendWindowSystemEvents qwindowsysteminterface.cpp 1169 0x7ffff577d25b 46 xcbSourceDispatch qxcbeventdispatcher.cpp 105 0x7ffff0a464ea 47 g_main_context_dispatch 0x7ffff324dd9c 48 g_main_context_iterate.isra 0x7ffff324e038 49 g_main_context_iteration 0x7ffff324e0cf 50 QEventDispatcherGlib::processEvents qeventdispatcher_glib.cpp 423 0x7ffff511c030 51 QEventLoop::exec qflags.h 69 0x7ffff50bc56b 52 QCoreApplication::exec qflags.h 121 0x7ffff50c545d 53 QGuiApplication::exec qguiapplication.cpp 1867 0x7ffff5796ccc 54 QApplication::exec qapplication.cpp 2824 0x7ffff6646ee5 55 main main.cpp 262 0x55555563f057
It is assert on row Q_ASSERT(last < rowCount(parent)); Something is not consistent there.
If you need we can debug that on my machine or somehow else...
If you trigger Q_ASSERT, it's because you are running Debug build type, maybe even for Qt itself? I'm not sure which dev use RelWithDebInfo or Debug builds (should be on Debug, but I often forget personally)
Yes. I especially built Qt with debug information for this bug investigation. But that Q_ASSERT is shown that QModel is in inconsistent state there. It can cause random bugs and even crashes.
Yes I agree Thanks for running these investigations!
Git commit fcc17c068c2077c507f38578e007a97ef697336b by Jean-Baptiste Mardelle. Committed on 31/03/2021 at 13:50. Pushed by mardelle into branch 'release/21.04'. Properly release timelinemodel on document close. M +5 -0 src/audiomixer/mixermanager.cpp M +2 -0 src/audiomixer/mixermanager.hpp M +6 -1 src/bin/model/subtitlemodel.cpp M +2 -0 src/bin/model/subtitlemodel.hpp M +1 -1 src/dialogs/speechdialog.cpp M +3 -1 src/project/projectmanager.cpp M +10 -5 src/timeline2/model/timelinemodel.cpp M +1 -0 src/timeline2/view/timelinecontroller.cpp M +6 -0 src/timeline2/view/timelinewidget.cpp M +1 -0 src/timeline2/view/timelinewidget.h https://invent.kde.org/multimedia/kdenlive/commit/fcc17c068c2077c507f38578e007a97ef697336b
There was a problem with the shared_ptr being still referenced by other widgets, so it was deleted much later than wanted. I fixed this, but not sure it's the only issue. Would be great if you can test again with my last commit.
New assert: 1 __GI_raise raise.c 49 0x7ffff48b4d21 2 __GI_abort abort.c 79 0x7ffff489e536 3 __gnu_cxx::__verbose_terminate_handler vterminate.cc 95 0x7ffff4c1d753 4 __cxxabiv1::__terminate eh_terminate.cc 48 0x7ffff4c4d7d6 5 std::terminate eh_terminate.cc 58 0x7ffff4c4d841 6 __cxxabiv1::__cxa_pure_virtual pure.cc 50 0x7ffff4c4e61f 7 QAbstractItemModel::beginRemoveRows qabstractitemmodel.cpp 2815 0x7ffff506d222 8 TimelineModel::<lambda()>::operator() timelinemodel.cpp 3625 0x555555a3cb6e 9 std::_Function_handler<bool(), TimelineModel::deregisterTrack_lambda(int)::<lambda()>>::_M_invoke std_function.h 285 0x555555a3cb6e 10 std::function<bool ()>::operator()() const std_function.h 688 0x555555a3cb6e 11 TimelineModel::~TimelineModel timelinemodel.cpp 160 0x555555a3cb6e 12 TimelineItemModel::~TimelineItemModel timelineitemmodel.hpp 48 0x5555559fa937 13 TimelineItemModel::~TimelineItemModel timelineitemmodel.hpp 48 0x5555559fa937 14 std::_Sp_counted_base<(__gnu_cxx::_Lock_policy)2>::_M_release shared_ptr_base.h 148 0x5555559a2f2c 15 std::_Sp_counted_base<(__gnu_cxx::_Lock_policy)2>::_M_release shared_ptr_base.h 148 0x5555559a2f2c 16 std::__shared_count<(__gnu_cxx::_Lock_policy)2>::~__shared_count shared_ptr_base.h 730 0x5555559a2f2c 17 std::__shared_ptr<TimelineItemModel, (__gnu_cxx::_Lock_policy)2>::~__shared_ptr shared_ptr_base.h 1169 0x5555559a2f2c 18 std::__shared_ptr<TimelineItemModel, (__gnu_cxx::_Lock_policy)2>::reset shared_ptr_base.h 1287 0x5555559a2f2c 19 ProjectManager::closeCurrentDocument projectmanager.cpp 296 0x5555559a2f2c 20 ProjectManager::newFile projectmanager.cpp 183 0x5555559a6c2f ... <More> By this stack you need to execute TimelineModel::~TimelineModel() body before derived class (TimelineItemModel) is destructed because deregisterTrack_lambda calls beginRemoveRows which calls TimelineItemModel::rowCount(). Or may be move rowCount to TimelineModel?
It seems that you have some expertise on developing and you are already somehow (a bit) familiar with the Kdenlive source code? It would be really nice to see you contributing to the project! :) At least for this bug… https://invent.kde.org/multimedia/kdenlive
Yes. I'm developer. Main specialization is C++ and Qt. But never earlier participated in KDE. And I'm not familiar with that code and don't know kdenlive architecture and generic workflows. I've just spent a hour for debugging. However I can try to fix it, but in week, because I already have much work next week.
(In reply to d.pischenko from comment #21) > Yes. I'm developer. Main specialization is C++ and Qt. But never earlier > participated in KDE. And I'm not familiar with that code and don't know > kdenlive architecture and generic workflows. I've just spent a hour for > debugging. > > However I can try to fix it, but in week, because I already have much work > next week. Any update here? I know it's been a long while, but perhaps your workload has lightened a bit and you could lend a helping hand ...
🐛🧹 ⚠️ This bug has been in NEEDSINFO status with no change for at least 15 days. Please provide the requested information, then set the bug status to REPORTED. If there is no change for at least 30 days, it will be automatically closed as RESOLVED WORKSFORME. For more information about our bug triaging procedures, please read https://community.kde.org/Guidelines_and_HOWTOs/Bug_triaging. Thank you for helping us make KDE software even better for everyone!
🐛🧹 This bug has been in NEEDSINFO status with no change for at least 30 days. Closing as RESOLVED WORKSFORME.