Bug 493191 - Spectacle crashes in QCalendarBackend::dateTimeToString() when no time zone is configured (i.e. /etc/localtime is missing)
Summary: Spectacle crashes in QCalendarBackend::dateTimeToString() when no time zone i...
Status: RESOLVED FIXED
Alias: None
Product: Spectacle
Classification: Applications
Component: General (show other bugs)
Version: 24.08.1
Platform: Arch Linux Linux
: NOR crash
Target Milestone: ---
Assignee: Noah Davis
URL:
Keywords:
Depends on:
Blocks:
 
Reported: 2024-09-16 09:54 UTC by khaalid
Modified: 2024-10-04 17:03 UTC (History)
3 users (show)

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


Attachments
the backtrace (10.39 KB, text/plain)
2024-09-16 09:54 UTC, khaalid
Details

Note You need to log in before you can comment on or make changes to this bug.
Description khaalid 2024-09-16 09:54:13 UTC
Created attachment 173719 [details]
the backtrace

SUMMARY
spectacle 24.08.1 crashing with segfault my platform is arch somehow the crash backtrace results are random so i included all debugging samples may not be enabled

STEPS TO REPRODUCE
1. make sure latest update 24.081
2. launch it normally adjust your window if you like
3.  click 'save' or 'save as' it should crash with segfault

OBSERVED RESULT


EXPECTED RESULT


SOFTWARE/OS VERSIONS
Windows: 
macOS: 
(available in the Info Center app, or by running `kinfo` in a terminal window)
Linux/KDE Plasma: 
KDE Plasma Version: 
KDE Frameworks Version: 
Qt Version: 

ADDITIONAL INFORMATION
Comment 1 Nicolas Fella 2024-09-23 09:54:18 UTC
#0  __memcpy_avx_unaligned_erms () at ../sysdeps/x86_64/multiarch/memmove-vec-unaligned-erms.S:265
#1  0x00007ffff22e652c in ?? () from /usr/lib/libQt6Core.so.6
#2  0x00007ffff240b987 in QCalendarBackend::dateTimeToString(QStringView, QDateTime const&, QDate, QTime, QLocale const&) const () from /usr/lib/libQt6Core.so.6
#3  0x00007ffff243eff9 in QCalendar::dateTimeToString(QStringView, QDateTime const&, QDate, QTime, QLocale const&) const () from /usr/lib/libQt6Core.so.6
#4  0x00007ffff23fddb1 in QLocale::toString(QDateTime const&, QStringView) const () from /usr/lib/libQt6Core.so.6
#5  0x00005555555bec48 in QLocale::toString (this=0x7fffffffa0c0, dateTime=..., format=...) at /usr/include/qt6/QtCore/qlocale.h:999
#6  ExportManager::formattedFilename (nameTemplate=..., timestamp=..., windowTitle=..., saveLocation=...) at /usr/src/debug/spectacle/spectacle-24.08.1/src/ExportManager.cpp:279
#7  0x00005555555b9c59 in ExportManager::getAutosaveFilename (this=0x5555557d4f60 <ExportManager::instance()::instance>) at /usr/include/qt6/QtCore/qarraydata.h:59
#8  0x00005555555c2136 in ExportManager::exportImage (this=0x5555557d4f60 <ExportManager::instance()::instance>, actions=..., url=...)
    at /usr/src/debug/spectacle/spectacle-24.08.1/src/ExportManager.cpp:649
#9  0x00005555555e35e7 in SpectacleWindow::save (this=<optimized out>) at /usr/src/debug/spectacle/spectacle-24.08.1/src/Gui/SpectacleWindow.cpp:235
#10 0x00005555555e961f in SpectacleWindow::qt_metacall (this=this@entry=0x555555c53600, _c=_c@entry=QMetaObject::InvokeMetaMethod, _id=3, _a=_a@entry=0x7fffffffa960)
    at /usr/src/debug/spectacle/build/src/spectacle_autogen/include/moc_SpectacleWindow.cpp:292
#11 0x00005555555e964e in ViewerWindow::qt_metacall (this=0x555555c53600, _c=QMetaObject::InvokeMetaMethod, _id=<optimized out>, _a=0x7fffffffa960)
    at /usr/src/debug/spectacle/build/src/spectacle_autogen/include/moc_ViewerWindow.cpp:147
#12 0x00007ffff2cf0a8b in QQmlObjectOrGadget::metacall (this=0x7fffffffabe0, type=QMetaObject::InvokeMetaMethod, index=<optimized out>, argv=<optimized out>)
    at /usr/src/debug/qt6-declarative/qtdeclarative/src/qml/qml/qqmlobjectorgadget.cpp:14
#13 0x00007ffff2bcc4f2 in QV4::CallMethod (object=..., index=<optimized out>, returnType=..., argCount=0, argTypes=0x0, engine=0x555555971750, callArgs=<optimized out>, 
    callType=QMetaObject::InvokeMetaMethod) at /usr/src/debug/qt6-declarative/qtdeclarative/src/qml/jsruntime/qv4qobjectwrapper.cpp:1663
#14 QV4::CallPrecise (object=..., data=..., engine=<optimized out>, engine@entry=0x555555971750, callArgs=<optimized out>, callArgs@entry=0x7fffc41bf578, 
    callType=callType@entry=QMetaObject::InvokeMetaMethod) at /usr/src/debug/qt6-declarative/qtdeclarative/src/qml/jsruntime/qv4qobjectwrapper.cpp:1956
#15 0x00007ffff2bcfe29 in operator() (__closure=<optimized out>) at /usr/src/debug/qt6-declarative/qtdeclarative/src/qml/jsruntime/qv4qobjectwrapper.cpp:2924
#16 operator()<QV4::QObjectMethod::callInternal(const QV4::Value*, const QV4::Value*, int) const::<lambda()> > (__closure=<synthetic pointer>, call=...)
    at /usr/src/debug/qt6-declarative/qtdeclarative/src/qml/jsruntime/qv4qobjectwrapper.cpp:2901
#17 QV4::QObjectMethod::callInternal (this=0x7fffffffad00, thisObject=<optimized out>, argv=0x7fffc41bf4f8, argc=0)
    at /usr/src/debug/qt6-declarative/qtdeclarative/src/qml/jsruntime/qv4qobjectwrapper.cpp:2924
#18 0x00007ffff2c195fa in QV4::Moth::VME::interpret (frame=0x7fffffffb0b0, engine=0x555555971750, code=0x555555d73440 "\220\033\272\362\377\177")
    at /usr/src/debug/qt6-declarative/qtdeclarative/src/qml/jsruntime/qv4vme_moth.cpp:798
#19 0x00007ffff2c1d353 in QV4::Moth::VME::exec (frame=<optimized out>, engine=<optimized out>) at /usr/src/debug/qt6-declarative/qtdeclarative/src/qml/jsruntime/qv4vme_moth.cpp:487
#20 0x00007ffff2b84ab6 in QV4::doCall (self=<optimized out>, thisObject=thisObject@entry=0x7fffc41bf4f0, argv=<optimized out>, argc=argc@entry=0, context=<optimized out>)
    at /usr/src/debug/qt6-declarative/qtdeclarative/src/qml/jsruntime/qv4function.cpp:54
#21 0x00007ffff2b8795d in QV4::Function::call (this=this@entry=0x555555bec4d0, thisObject=0x7fffc41bf4f0, argv=argv@entry=0x7fffc41bf4f0, argc=argc@entry=0, 
    context=context@entry=0x7fffcf433218) at /usr/src/debug/qt6-declarative/qtdeclarative/src/qml/jsruntime/qv4function.cpp:79
#22 0x00007ffff2b87c51 in operator() (__closure=<synthetic pointer>, thisObject=<optimized out>, argv=0x7fffc41bf4f0, argc=0)
    at /usr/src/debug/qt6-declarative/qtdeclarative/src/qml/jsruntime/qv4function.cpp:30
#23 QV4::convertAndCall<QV4::Function::call(QObject*, void**, const QMetaType*, int, QV4::ExecutionContext*)::<lambda(const QV4::Value*, const QV4::Value*, int)> > (
    engine=<optimized out>, thisObject=0x555555c603a0, a=0x7fffffffb390, types=0x7fffffffb380, argc=0, call=...)
    at /usr/src/debug/qt6-declarative/qtdeclarative/src/qml/jsruntime/qv4jscall_p.h:202
#24 QV4::Function::call (this=0x555555bec4d0, thisObject=0x555555c603a0, a=0x7fffffffb390, types=0x7fffffffb380, argc=0, context=0x7fffcf433218)
    at /usr/src/debug/qt6-declarative/qtdeclarative/src/qml/jsruntime/qv4function.cpp:27
#25 0x00007ffff2cbafc4 in QQmlJavaScriptExpression::evaluate (this=<optimized out>, a=<optimized out>, types=<optimized out>, argc=<optimized out>)
    at /usr/src/debug/qt6-declarative/qtdeclarative/src/qml/qml/qqmljavascriptexpression_p.h:248
#26 0x00007ffff2c651a3 in QQmlBoundSignalExpression::evaluate (this=0x555555bf7a40, a=a@entry=0x0) at /usr/src/debug/qt6-declarative/qtdeclarative/src/qml/qml/qqmlboundsignal.cpp:199
#27 0x00007ffff2c6a0bf in QQmlBoundSignal_callback (e=0x555555bf79c0, a=0x0) at /usr/src/debug/qt6-declarative/qtdeclarative/src/qml/qml/ftw/qqmlrefcount_p.h:73
#28 QQmlBoundSignal_callback (e=0x555555bf79c0, a=0x0) at /usr/src/debug/qt6-declarative/qtdeclarative/src/qml/qml/qqmlboundsignal.cpp:293
#29 0x00007ffff2cdba4c in QQmlNotifier::emitNotify (endpoint=<optimized out>, a=0x0) at /usr/src/debug/qt6-declarative/qtdeclarative/src/qml/qml/qqmlnotifier.cpp:70
#30 0x00007ffff23a30ea in ?? () from /usr/lib/libQt6Core.so.6
#31 0x00007fffeb4adb3a in QQuickAbstractButtonPrivate::handleRelease(QPointF const&, unsigned long) () from /usr/lib/libQt6QuickTemplates2.so.6
#32 0x00007fffeb4c8b90 in QQuickControl::mouseReleaseEvent(QMouseEvent*) () from /usr/lib/libQt6QuickTemplates2.so.6
#33 0x00007ffff5197785 in QQuickItemPrivate::deliverPointerEvent (this=this@entry=0x555555bba140, event=event@entry=0x7fffffffdb00)
    at /usr/src/debug/qt6-declarative/qtdeclarative/src/quick/items/qquickitem.cpp:5618
--Type <RET> for more, q to quit, c to continue without paging--
#34 0x00007ffff5197a0b in QQuickItem::event (this=0x555555c603a0, ev=0x7fffffffdb00) at /usr/src/debug/qt6-declarative/qtdeclarative/src/quick/items/qquickitem.cpp:9019
#35 0x00007ffff48fc8cc in QApplicationPrivate::notify_helper (this=<optimized out>, receiver=0x555555c603a0, e=0x7fffffffdb00)
    at /usr/src/debug/qt6-base/qtbase/src/widgets/kernel/qapplication.cpp:3287
#36 0x00007ffff2345aa8 in QCoreApplication::notifyInternal2(QObject*, QEvent*) () from /usr/lib/libQt6Core.so.6
#37 0x00007ffff534c910 in QQuickDeliveryAgentPrivate::deliverMatchingPointsToItem (this=this@entry=0x555555b17a10, item=item@entry=0x555555c603a0, isGrabber=isGrabber@entry=true, 
    pointerEvent=pointerEvent@entry=0x7fffffffdb00, handlersOnly=handlersOnly@entry=false) at /usr/src/debug/qt6-declarative/qtdeclarative/src/quick/util/qquickdeliveryagent.cpp:2322
#38 0x00007ffff534cfc2 in QQuickDeliveryAgentPrivate::deliverUpdatedPoints (this=this@entry=0x555555b17a10, event=event@entry=0x7fffffffdb00)
    at /usr/src/debug/qt6-declarative/qtdeclarative/src/quick/util/qquickdeliveryagent.cpp:2107
#39 0x00007ffff534ebd3 in QQuickDeliveryAgentPrivate::deliverPointerEvent (this=this@entry=0x555555b17a10, event=event@entry=0x7fffffffdb00)
    at /usr/src/debug/qt6-declarative/qtdeclarative/src/quick/util/qquickdeliveryagent.cpp:1947
#40 0x00007ffff534fcc5 in QQuickDeliveryAgentPrivate::handleMouseEvent (this=this@entry=0x555555b17a10, event=event@entry=0x7fffffffdb00)
    at /usr/src/debug/qt6-declarative/qtdeclarative/src/quick/util/qquickdeliveryagent.cpp:1701
#41 0x00007ffff5350453 in QQuickDeliveryAgent::event (this=<optimized out>, ev=0x7fffffffdb00) at /usr/src/debug/qt6-declarative/qtdeclarative/src/quick/util/qquickdeliveryagent.cpp:746
#42 0x00007ffff524df28 in QQuickWindow::event (this=<optimized out>, event=<optimized out>) at /usr/src/debug/qt6-declarative/qtdeclarative/src/quick/items/qquickwindow.cpp:1564
#43 0x00007ffff48fc8cc in QApplicationPrivate::notify_helper (this=<optimized out>, receiver=0x555555c53600, e=0x7fffffffdb00)
    at /usr/src/debug/qt6-base/qtbase/src/widgets/kernel/qapplication.cpp:3287
#44 0x00007ffff2345aa8 in QCoreApplication::notifyInternal2(QObject*, QEvent*) () from /usr/lib/libQt6Core.so.6
#45 0x00007ffff3f78140 in QGuiApplicationPrivate::processMouseEvent (e=0x7fffc0002150) at /usr/src/debug/qt6-base/qtbase/src/gui/kernel/qguiapplication.cpp:2327
#46 0x00007ffff3fe7724 in QWindowSystemInterface::sendWindowSystemEvents (flags=...) at /usr/src/debug/qt6-base/qtbase/src/gui/kernel/qwindowsysteminterface.cpp:1114
#47 0x00007ffff44041e4 in userEventSourceDispatch (source=<optimized out>) at /usr/src/debug/qt6-base/qtbase/src/gui/platform/unix/qeventdispatcher_glib.cpp:38
#48 0x00007fffee7cd299 in ?? () from /usr/lib/libglib-2.0.so.0
#49 0x00007fffee82fec7 in ?? () from /usr/lib/libglib-2.0.so.0
#50 0x00007fffee7cc795 in g_main_context_iteration () from /usr/lib/libglib-2.0.so.0
#51 0x00007ffff25a82bd in QEventDispatcherGlib::processEvents(QFlags<QEventLoop::ProcessEventsFlag>) () from /usr/lib/libQt6Core.so.6
#52 0x00007ffff234ff66 in QEventLoop::exec(QFlags<QEventLoop::ProcessEventsFlag>) () from /usr/lib/libQt6Core.so.6
#53 0x00007ffff234a11d in QCoreApplication::exec() () from /usr/lib/libQt6Core.so.6
#54 0x00007ffff48f86aa in QApplication::exec () at /usr/src/debug/qt6-base/qtbase/src/widgets/kernel/qapplication.cpp:2555
#55 0x000055555559d96d in main (argc=<optimized out>, argv=<optimized out>) at /usr/src/debug/spectacle/spectacle-24.08.1/src/Main.cpp:133
Comment 2 Antonio Rojas 2024-09-23 10:19:22 UTC
Per downstream report, this is caused by a user misconfiguration (no timezone configured)
Comment 3 Noah Davis 2024-09-23 21:17:10 UTC
This seems like a Qt bug. QLocale::system is supposed to fallback to the C locale, but QLocale::toString is crashing in Qt's backend code.

https://doc.qt.io/qt-6/qlocale.html#system

> The system locale may use system-specific sources for locale data, where available,
> otherwise falling back on QLocale's built-in database entry for the language, script and territory the system reports.
Comment 4 Antonio Rojas 2024-09-24 07:05:48 UTC
(In reply to Noah Davis from comment #3)
> This seems like a Qt bug. QLocale::system is supposed to fallback to the C
> locale, but QLocale::toString is crashing in Qt's backend code.

Note that the issue is misconfigured timezone (ie. missing /etc/localtime), not locale. Still, Qt should handle it gracefully.
Comment 5 Nate Graham 2024-09-30 14:46:25 UTC
Can confirm the issue.
Comment 6 Bug Janitor Service 2024-10-04 11:58:59 UTC
A possibly relevant merge request was started @ https://invent.kde.org/graphics/spectacle/-/merge_requests/406
Comment 7 Noah Davis 2024-10-04 12:36:55 UTC
https://bugreports.qt.io/browse/QTBUG-129696
Comment 8 Noah Davis 2024-10-04 16:58:58 UTC
Git commit 0751f195960e63b556baf5eedcb3ea36a59c8910 by Noah Davis.
Committed on 04/10/2024 at 12:38.
Pushed by ndavis into branch 'master'.

ExportManager: fix crash when saving while timezone is misconfigured

M  +12   -2    src/ExportManager.cpp

https://invent.kde.org/graphics/spectacle/-/commit/0751f195960e63b556baf5eedcb3ea36a59c8910
Comment 9 Noah Davis 2024-10-04 17:03:08 UTC
Git commit 50b12ed6a568ffc83e8d6432247d4a70ba91c0f3 by Noah Davis.
Committed on 04/10/2024 at 17:02.
Pushed by ndavis into branch 'release/24.08'.

ExportManager: fix crash when saving while timezone is misconfigured
(cherry picked from commit 0751f195960e63b556baf5eedcb3ea36a59c8910)

M  +12   -2    src/ExportManager.cpp

https://invent.kde.org/graphics/spectacle/-/commit/50b12ed6a568ffc83e8d6432247d4a70ba91c0f3