diff options
Diffstat (limited to 'qt-models')
-rw-r--r-- | qt-models/CMakeLists.txt | 1 | ||||
-rw-r--r-- | qt-models/messagehandlermodel.cpp | 59 | ||||
-rw-r--r-- | qt-models/messagehandlermodel.h | 29 |
3 files changed, 89 insertions, 0 deletions
diff --git a/qt-models/CMakeLists.txt b/qt-models/CMakeLists.txt index cbdf47501..90b6da433 100644 --- a/qt-models/CMakeLists.txt +++ b/qt-models/CMakeLists.txt @@ -23,6 +23,7 @@ set(SUBSURFACE_MODELS_LIB_SRCS divelistmodel.cpp gpslistmodel.cpp diveimportedmodel.cpp + messagehandlermodel.cpp ) source_group("Subsurface Models" FILES ${SUBSURFACE_MODELS}) diff --git a/qt-models/messagehandlermodel.cpp b/qt-models/messagehandlermodel.cpp new file mode 100644 index 000000000..daedad897 --- /dev/null +++ b/qt-models/messagehandlermodel.cpp @@ -0,0 +1,59 @@ +#include "messagehandlermodel.h" + +void logMessageHandler(QtMsgType type, const QMessageLogContext &context, const QString &msg) +{ + MessageHandlerModel::self()->addLog(type, msg); +} + +MessageHandlerModel * MessageHandlerModel::self() +{ + static MessageHandlerModel *self = new MessageHandlerModel(); + return self; +} + +MessageHandlerModel::MessageHandlerModel(QObject *parent) +{ + // no more than one message handler. + qInstallMessageHandler(logMessageHandler); +} + +int MessageHandlerModel::rowCount(const QModelIndex& parent) const +{ + Q_UNUSED(parent); + return m_data.size(); +} + +#include <iostream> + +void MessageHandlerModel::addLog(QtMsgType type, const QString& message) +{ + beginInsertRows(QModelIndex(), rowCount(), rowCount()); + m_data.append({message, type}); + endInsertRows(); +} + +QVariant MessageHandlerModel::data(const QModelIndex& idx, int role) const +{ + switch(role) { + case Message: + case Qt::DisplayRole: + return m_data.at(idx.row()).message; + } + return QVariant(QString("Role: %1").arg(role)); +}; + +QHash<int, QByteArray> MessageHandlerModel::roleNames() const { + static QHash<int, QByteArray> roles = { + {Message, "message"}, + {Severity, "severity"} + }; + return roles; +}; + +void MessageHandlerModel::reset() +{ + beginRemoveRows(QModelIndex(), 0, m_data.size()-1); + m_data.clear(); + endRemoveRows(); + +} diff --git a/qt-models/messagehandlermodel.h b/qt-models/messagehandlermodel.h new file mode 100644 index 000000000..7fb5c6515 --- /dev/null +++ b/qt-models/messagehandlermodel.h @@ -0,0 +1,29 @@ +#ifndef MESSAGEHANDLERMODEL_H +#define MESSAGEHANDLERMODEL_H + +#include <QAbstractListModel> + + +class MessageHandlerModel : public QAbstractListModel { + Q_OBJECT +public: + static MessageHandlerModel *self(); + enum MsgTypes {Message = Qt::UserRole + 1, Severity}; + int rowCount(const QModelIndex& parent = QModelIndex()) const override; + QVariant data(const QModelIndex& idx, int role) const override; + QHash<int, QByteArray> roleNames() const override; + void addLog(QtMsgType type, const QString& message); + + /* call this to clear the debug data */ + Q_INVOKABLE void reset(); + +private: + MessageHandlerModel(QObject *parent = 0); + struct MessageData { + QString message; + QtMsgType type; + }; + QVector<MessageData> m_data; +}; + +#endif |