Bug 409667 - kdenlive crashes on startup with ASSERT failure in QCoreApplication::sendEvent: "Cannot send events to objects owned by a different thread"
Summary: kdenlive crashes on startup with ASSERT failure in QCoreApplication::sendEven...
Status: RESOLVED WORKSFORME
Alias: None
Product: kdenlive
Classification: Applications
Component: Setup & Installation (show other bugs)
Version: 20.12.3
Platform: Other Linux
: NOR crash
Target Milestone: ---
Assignee: Vincent PINON
URL:
Keywords: triaged
: 428632 (view as bug list)
Depends on:
Blocks:
 
Reported: 2019-07-10 07:57 UTC by David Faure
Modified: 2025-01-23 03:47 UTC (History)
8 users (show)

See Also:
Latest Commit:
Version Fixed In:
Sentry Crash Report:


Attachments

Note You need to log in before you can comment on or make changes to this bug.
Description David Faure 2019-07-10 07:57:52 UTC
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.
Comment 1 emohr 2019-08-04 15:23:36 UTC
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/
Comment 2 Jonathan Marten 2020-04-12 13:27:00 UTC
Confirmed with current Git master 4ce5e54f.
Comment 3 Christian Janoff 2020-11-15 09:45:48 UTC
Confirming this with

Linux: Gentoo
KDE Plasma Version: 5.19.5
KDE Frameworks Version: 5.74.0
Qt Version: 5.15.1
Comment 4 Julius Künzel 2021-03-15 16:23:25 UTC
*** Bug 428632 has been marked as a duplicate of this bug. ***
Comment 5 d.pischenko 2021-03-15 17:34:01 UTC
Please note my debug results: https://bugs.kde.org/show_bug.cgi?id=428632#c2
Comment 6 Julius Künzel 2021-03-28 10:44:47 UTC
Can you please test again? This has hopefully been fixed to day with https://invent.kde.org/multimedia/kdenlive/-/commit/5f712c9178170af239ad1db0b21caf130e350e3d
Comment 7 d.pischenko 2021-03-28 18:47:04 UTC
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        
....
Comment 8 Jean-Baptiste Mardelle 2021-03-30 13:34:42 UTC
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
Comment 9 Jean-Baptiste Mardelle 2021-03-30 13:35:11 UTC
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
Comment 10 Julius Künzel 2021-03-30 13:43:44 UTC
New fix! Please try again…
Comment 11 d.pischenko 2021-03-30 18:26:48 UTC
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
Comment 12 d.pischenko 2021-03-30 18:28:19 UTC
It is assert on row
Q_ASSERT(last < rowCount(parent));
Something is not consistent there.
Comment 13 d.pischenko 2021-03-30 18:29:15 UTC
If you need we can debug that on my machine or somehow else...
Comment 14 Vincent PINON 2021-03-31 06:38:33 UTC
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)
Comment 15 d.pischenko 2021-03-31 07:07:00 UTC
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.
Comment 16 Vincent PINON 2021-03-31 07:48:12 UTC
Yes I agree
Thanks for running these investigations!
Comment 17 Jean-Baptiste Mardelle 2021-03-31 13:50:20 UTC
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
Comment 18 Jean-Baptiste Mardelle 2021-03-31 13:59:55 UTC
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.
Comment 19 d.pischenko 2021-04-01 06:21:44 UTC
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?
Comment 20 Julius Künzel 2021-05-16 13:58:07 UTC
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
Comment 21 d.pischenko 2021-05-16 20:12:16 UTC
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.
Comment 22 Bernd 2024-12-24 01:21:04 UTC
(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 ...
Comment 23 Bug Janitor Service 2025-01-08 03:47:28 UTC
🐛🧹 ⚠️ 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!
Comment 24 Bug Janitor Service 2025-01-23 03:47:18 UTC
🐛🧹 This bug has been in NEEDSINFO status with no change for at least 30 days. Closing as RESOLVED WORKSFORME.