| 1 | // Copyright (C) 2016 The Qt Company Ltd. |
| 2 | // SPDX-License-Identifier: LicenseRef-Qt-Commercial OR LGPL-3.0-only OR GPL-2.0-only OR GPL-3.0-only |
| 3 | |
| 4 | #ifndef QLOGGING_H |
| 5 | #define QLOGGING_H |
| 6 | |
| 7 | #include <QtCore/qtclasshelpermacros.h> |
| 8 | #include <QtCore/qtconfigmacros.h> |
| 9 | #include <QtCore/qtcoreexports.h> |
| 10 | #include <QtCore/qcontainerfwd.h> |
| 11 | |
| 12 | #if 0 |
| 13 | // header is automatically included in qglobal.h |
| 14 | #pragma qt_no_master_include |
| 15 | #pragma qt_class(QtLogging) |
| 16 | #endif |
| 17 | |
| 18 | QT_BEGIN_NAMESPACE |
| 19 | |
| 20 | /* |
| 21 | Forward declarations only. |
| 22 | |
| 23 | In order to use the qDebug() stream, you must #include<QDebug> |
| 24 | */ |
| 25 | class QDebug; |
| 26 | class QNoDebug; |
| 27 | |
| 28 | |
| 29 | enum QtMsgType { |
| 30 | QtDebugMsg, |
| 31 | QT7_ONLY(QtInfoMsg,) |
| 32 | QtWarningMsg, |
| 33 | QtCriticalMsg, |
| 34 | QtFatalMsg, |
| 35 | QT6_ONLY(QtInfoMsg,) |
| 36 | #if QT_DEPRECATED_SINCE(6, 7) |
| 37 | QtSystemMsg Q_DECL_ENUMERATOR_DEPRECATED_X("Use QtCriticalMsg instead." ) = QtCriticalMsg |
| 38 | #endif |
| 39 | }; |
| 40 | |
| 41 | class QInternalMessageLogContext; |
| 42 | class QMessageLogContext |
| 43 | { |
| 44 | Q_DISABLE_COPY(QMessageLogContext) |
| 45 | public: |
| 46 | static constexpr int CurrentVersion = 2; |
| 47 | constexpr QMessageLogContext() noexcept = default; |
| 48 | constexpr QMessageLogContext(const char *fileName, int lineNumber, const char *functionName, const char *categoryName) noexcept |
| 49 | : line(lineNumber), file(fileName), function(functionName), category(categoryName) {} |
| 50 | |
| 51 | int version = CurrentVersion; |
| 52 | int line = 0; |
| 53 | const char *file = nullptr; |
| 54 | const char *function = nullptr; |
| 55 | const char *category = nullptr; |
| 56 | |
| 57 | private: |
| 58 | QMessageLogContext ©ContextFrom(const QMessageLogContext &logContext) noexcept; |
| 59 | |
| 60 | friend class QInternalMessageLogContext; |
| 61 | friend class QMessageLogger; |
| 62 | }; |
| 63 | |
| 64 | class QLoggingCategory; |
| 65 | |
| 66 | #if defined(Q_CC_MSVC_ONLY) |
| 67 | # define QT_MESSAGE_LOGGER_NORETURN |
| 68 | #else |
| 69 | # define QT_MESSAGE_LOGGER_NORETURN Q_NORETURN |
| 70 | #endif |
| 71 | |
| 72 | class Q_CORE_EXPORT QMessageLogger |
| 73 | { |
| 74 | Q_DISABLE_COPY(QMessageLogger) |
| 75 | public: |
| 76 | constexpr QMessageLogger() : context() {} |
| 77 | constexpr QMessageLogger(const char *file, int line, const char *function) |
| 78 | : context(file, line, function, "default" ) {} |
| 79 | constexpr QMessageLogger(const char *file, int line, const char *function, const char *category) |
| 80 | : context(file, line, function, category) {} |
| 81 | |
| 82 | void debug(const char *msg, ...) const Q_ATTRIBUTE_FORMAT_PRINTF(2, 3); |
| 83 | void noDebug(const char *, ...) const Q_ATTRIBUTE_FORMAT_PRINTF(2, 3) |
| 84 | {} |
| 85 | void info(const char *msg, ...) const Q_ATTRIBUTE_FORMAT_PRINTF(2, 3); |
| 86 | Q_DECL_COLD_FUNCTION |
| 87 | void warning(const char *msg, ...) const Q_ATTRIBUTE_FORMAT_PRINTF(2, 3); |
| 88 | Q_DECL_COLD_FUNCTION |
| 89 | void critical(const char *msg, ...) const Q_ATTRIBUTE_FORMAT_PRINTF(2, 3); |
| 90 | QT_MESSAGE_LOGGER_NORETURN Q_DECL_COLD_FUNCTION |
| 91 | void fatal(const char *msg, ...) const noexcept Q_ATTRIBUTE_FORMAT_PRINTF(2, 3); |
| 92 | |
| 93 | typedef const QLoggingCategory &(*CategoryFunction)(); |
| 94 | |
| 95 | void debug(const QLoggingCategory &cat, const char *msg, ...) const Q_ATTRIBUTE_FORMAT_PRINTF(3, 4); |
| 96 | void debug(CategoryFunction catFunc, const char *msg, ...) const Q_ATTRIBUTE_FORMAT_PRINTF(3, 4); |
| 97 | void info(const QLoggingCategory &cat, const char *msg, ...) const Q_ATTRIBUTE_FORMAT_PRINTF(3, 4); |
| 98 | void info(CategoryFunction catFunc, const char *msg, ...) const Q_ATTRIBUTE_FORMAT_PRINTF(3, 4); |
| 99 | Q_DECL_COLD_FUNCTION |
| 100 | void warning(const QLoggingCategory &cat, const char *msg, ...) const Q_ATTRIBUTE_FORMAT_PRINTF(3, 4); |
| 101 | Q_DECL_COLD_FUNCTION |
| 102 | void warning(CategoryFunction catFunc, const char *msg, ...) const Q_ATTRIBUTE_FORMAT_PRINTF(3, 4); |
| 103 | Q_DECL_COLD_FUNCTION |
| 104 | void critical(const QLoggingCategory &cat, const char *msg, ...) const Q_ATTRIBUTE_FORMAT_PRINTF(3, 4); |
| 105 | Q_DECL_COLD_FUNCTION |
| 106 | void critical(CategoryFunction catFunc, const char *msg, ...) const Q_ATTRIBUTE_FORMAT_PRINTF(3, 4); |
| 107 | QT_MESSAGE_LOGGER_NORETURN Q_DECL_COLD_FUNCTION |
| 108 | void fatal(const QLoggingCategory &cat, const char *msg, ...) const noexcept Q_ATTRIBUTE_FORMAT_PRINTF(3, 4); |
| 109 | QT_MESSAGE_LOGGER_NORETURN Q_DECL_COLD_FUNCTION |
| 110 | void fatal(CategoryFunction catFunc, const char *msg, ...) const noexcept Q_ATTRIBUTE_FORMAT_PRINTF(3, 4); |
| 111 | |
| 112 | #ifndef QT_NO_DEBUG_STREAM |
| 113 | QDebug debug() const; |
| 114 | QDebug debug(const QLoggingCategory &cat) const; |
| 115 | QDebug debug(CategoryFunction catFunc) const; |
| 116 | QDebug info() const; |
| 117 | QDebug info(const QLoggingCategory &cat) const; |
| 118 | QDebug info(CategoryFunction catFunc) const; |
| 119 | Q_DECL_COLD_FUNCTION |
| 120 | QDebug warning() const; |
| 121 | Q_DECL_COLD_FUNCTION |
| 122 | QDebug warning(const QLoggingCategory &cat) const; |
| 123 | Q_DECL_COLD_FUNCTION |
| 124 | QDebug warning(CategoryFunction catFunc) const; |
| 125 | Q_DECL_COLD_FUNCTION |
| 126 | QDebug critical() const; |
| 127 | Q_DECL_COLD_FUNCTION |
| 128 | QDebug critical(const QLoggingCategory &cat) const; |
| 129 | Q_DECL_COLD_FUNCTION |
| 130 | QDebug critical(CategoryFunction catFunc) const; |
| 131 | Q_DECL_COLD_FUNCTION |
| 132 | QDebug fatal() const; |
| 133 | Q_DECL_COLD_FUNCTION |
| 134 | QDebug fatal(const QLoggingCategory &cat) const; |
| 135 | Q_DECL_COLD_FUNCTION |
| 136 | QDebug fatal(CategoryFunction catFunc) const; |
| 137 | |
| 138 | QNoDebug noDebug() const noexcept; |
| 139 | #endif // QT_NO_DEBUG_STREAM |
| 140 | |
| 141 | private: |
| 142 | QMessageLogContext context; |
| 143 | }; |
| 144 | |
| 145 | #undef QT_MESSAGE_LOGGER_NORETURN |
| 146 | |
| 147 | #if !defined(QT_MESSAGELOGCONTEXT) && !defined(QT_NO_MESSAGELOGCONTEXT) |
| 148 | # if defined(QT_NO_DEBUG) |
| 149 | # define QT_NO_MESSAGELOGCONTEXT |
| 150 | # else |
| 151 | # define QT_MESSAGELOGCONTEXT |
| 152 | # endif |
| 153 | #endif |
| 154 | |
| 155 | #ifdef QT_MESSAGELOGCONTEXT |
| 156 | #define QT_MESSAGELOG_FILE static_cast<const char *>(__FILE__) |
| 157 | #define QT_MESSAGELOG_LINE __LINE__ |
| 158 | #define QT_MESSAGELOG_FUNC static_cast<const char *>(Q_FUNC_INFO) |
| 159 | #else |
| 160 | #define QT_MESSAGELOG_FILE nullptr |
| 161 | #define QT_MESSAGELOG_LINE 0 |
| 162 | #define QT_MESSAGELOG_FUNC nullptr |
| 163 | #endif |
| 164 | |
| 165 | #define qDebug QMessageLogger(QT_MESSAGELOG_FILE, QT_MESSAGELOG_LINE, QT_MESSAGELOG_FUNC).debug |
| 166 | #define qInfo QMessageLogger(QT_MESSAGELOG_FILE, QT_MESSAGELOG_LINE, QT_MESSAGELOG_FUNC).info |
| 167 | #define qWarning QMessageLogger(QT_MESSAGELOG_FILE, QT_MESSAGELOG_LINE, QT_MESSAGELOG_FUNC).warning |
| 168 | #define qCritical QMessageLogger(QT_MESSAGELOG_FILE, QT_MESSAGELOG_LINE, QT_MESSAGELOG_FUNC).critical |
| 169 | #define qFatal QMessageLogger(QT_MESSAGELOG_FILE, QT_MESSAGELOG_LINE, QT_MESSAGELOG_FUNC).fatal |
| 170 | |
| 171 | #define QT_NO_QDEBUG_MACRO while (false) QMessageLogger().noDebug |
| 172 | |
| 173 | #if defined(QT_NO_DEBUG_OUTPUT) |
| 174 | # undef qDebug |
| 175 | # define qDebug QT_NO_QDEBUG_MACRO |
| 176 | #endif |
| 177 | #if defined(QT_NO_INFO_OUTPUT) |
| 178 | # undef qInfo |
| 179 | # define qInfo QT_NO_QDEBUG_MACRO |
| 180 | #endif |
| 181 | #if defined(QT_NO_WARNING_OUTPUT) |
| 182 | # undef qWarning |
| 183 | # define qWarning QT_NO_QDEBUG_MACRO |
| 184 | #endif |
| 185 | |
| 186 | Q_CORE_EXPORT void qt_message_output(QtMsgType, const QMessageLogContext &context, |
| 187 | const QString &message); |
| 188 | |
| 189 | Q_CORE_EXPORT Q_DECL_COLD_FUNCTION void qErrnoWarning(int code, const char *msg, ...); |
| 190 | Q_CORE_EXPORT Q_DECL_COLD_FUNCTION void qErrnoWarning(const char *msg, ...); |
| 191 | |
| 192 | typedef void (*QtMessageHandler)(QtMsgType, const QMessageLogContext &, const QString &); |
| 193 | Q_CORE_EXPORT QtMessageHandler qInstallMessageHandler(QtMessageHandler); |
| 194 | |
| 195 | Q_CORE_EXPORT void qSetMessagePattern(const QString &messagePattern); |
| 196 | Q_CORE_EXPORT QString qFormatLogMessage(QtMsgType type, const QMessageLogContext &context, |
| 197 | const QString &buf); |
| 198 | |
| 199 | Q_DECL_COLD_FUNCTION |
| 200 | Q_CORE_EXPORT QString qt_error_string(int errorCode = -1); |
| 201 | |
| 202 | QT_END_NAMESPACE |
| 203 | #endif // QLOGGING_H |
| 204 | |