QLogging: attempt to free memory in qt_message() before abort()
Just so memory leak checkers won't complain. Pick-to: 6.6 Change-Id: I2b24e1d3cad44897906efffd177fb9ddf0eb0a2a Reviewed-by: Edward Welbourne <edward.welbourne@qt.io>
This commit is contained in:
parent
62b53011d3
commit
b24630ce02
@ -162,10 +162,11 @@ Q_TRACE_POINT(qtcore, qt_message_print, int type, const char *category, const ch
|
||||
\snippet code/src_corelib_global_qglobal.cpp 4
|
||||
*/
|
||||
|
||||
template <typename String>
|
||||
#if !defined(Q_CC_MSVC_ONLY)
|
||||
Q_NORETURN
|
||||
#endif
|
||||
static void qt_message_fatal(QtMsgType, const QMessageLogContext &context, const QString &message);
|
||||
static void qt_message_fatal(QtMsgType, const QMessageLogContext &context, String &&message);
|
||||
static void qt_message_print(QtMsgType, const QMessageLogContext &context, const QString &message);
|
||||
static void qt_message_print(const QString &message);
|
||||
|
||||
@ -1996,7 +1997,8 @@ static void qt_message_print(const QString &message)
|
||||
fflush(stderr);
|
||||
}
|
||||
|
||||
static void qt_message_fatal(QtMsgType, const QMessageLogContext &context, const QString &message)
|
||||
template <typename String>
|
||||
static void qt_message_fatal(QtMsgType, const QMessageLogContext &context, String &&message)
|
||||
{
|
||||
#if defined(Q_CC_MSVC_ONLY) && defined(QT_DEBUG) && defined(_DEBUG) && defined(_CRT_ERROR)
|
||||
wchar_t contextFileL[256];
|
||||
@ -2017,13 +2019,15 @@ static void qt_message_fatal(QtMsgType, const QMessageLogContext &context, const
|
||||
_CrtDbgBreak();
|
||||
#else
|
||||
Q_UNUSED(context);
|
||||
Q_UNUSED(message);
|
||||
#endif
|
||||
|
||||
if constexpr (std::is_class_v<String> && !std::is_const_v<String>)
|
||||
message.clear();
|
||||
else
|
||||
Q_UNUSED(message);
|
||||
qAbort();
|
||||
}
|
||||
|
||||
|
||||
/*!
|
||||
\internal
|
||||
*/
|
||||
|
Loading…
Reference in New Issue
Block a user