1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64
|
// Copyright (C) 2017 The Qt Company Ltd.
// SPDX-License-Identifier: LicenseRef-Qt-Commercial OR GPL-3.0-only WITH Qt-GPL-exception-1.0
#ifndef LOGWIDGET_H
#define LOGWIDGET_H
#include <QPlainTextEdit>
// Instantiate as follows: LogFunctionGuard guard(Q_FUNC_INFO)
class LogFunctionGuard {
Q_DISABLE_COPY(LogFunctionGuard)
public:
explicit LogFunctionGuard(const char *name);
~LogFunctionGuard();
private:
const char *m_name;
};
class LogWidget : public QPlainTextEdit
{
Q_OBJECT
public:
explicit LogWidget(QWidget *parent = nullptr);
~LogWidget();
static LogWidget *instance() { return m_instance; }
static QString startupMessage();
static void install();
static void uninstall();
static int indent() { return m_indent; }
static void setIndent(int i) { m_indent = i; }
static bool lineNumberingEnabled() { return m_lineNumberingEnabled; }
static void setLineNumberingEnabled(bool l) { m_lineNumberingEnabled = l; }
static bool showMessageType() { return m_showMessageType; }
static void setShowMessageType(bool s) { m_showMessageType = s; }
public slots:
void appendText(const QString &);
private:
static int m_indent;
static bool m_lineNumberingEnabled;
static bool m_showMessageType;
static LogWidget *m_instance;
};
inline LogFunctionGuard::LogFunctionGuard(const char *name) : m_name(name)
{
qDebug(">%s", m_name);
LogWidget::setIndent(LogWidget::indent() + 2);
}
inline LogFunctionGuard::~LogFunctionGuard()
{
LogWidget::setIndent(LogWidget::indent() - 2);
qDebug("<%s", m_name);
}
#endif // LOGWIDGET_H
|