2018-04-07 08:44:39 +00:00
|
|
|
#include "logbrowserdialog.h"
|
|
|
|
// Modified from https://wiki.qt.io/Browser_for_QDebug_output
|
|
|
|
#include <QVBoxLayout>
|
|
|
|
#include <QHBoxLayout>
|
|
|
|
#include <QTextBrowser>
|
|
|
|
#include <QPushButton>
|
|
|
|
#include <QFileDialog>
|
|
|
|
#include <QDir>
|
|
|
|
#include <QFile>
|
|
|
|
#include <QMessageBox>
|
|
|
|
#include <QTextStream>
|
|
|
|
#include <QCloseEvent>
|
|
|
|
#include <QKeyEvent>
|
2018-09-14 09:45:05 +00:00
|
|
|
#include "version.h"
|
2018-04-07 08:44:39 +00:00
|
|
|
|
|
|
|
LogBrowserDialog::LogBrowserDialog(QWidget *parent) :
|
|
|
|
QDialog(parent)
|
|
|
|
{
|
|
|
|
QVBoxLayout *layout = new QVBoxLayout;
|
|
|
|
setLayout(layout);
|
|
|
|
|
|
|
|
m_browser = new QTextBrowser(this);
|
|
|
|
layout->addWidget(m_browser);
|
|
|
|
|
|
|
|
QHBoxLayout *buttonLayout = new QHBoxLayout;
|
|
|
|
buttonLayout->setContentsMargins(0, 0, 0, 0);
|
|
|
|
layout->addLayout(buttonLayout);
|
|
|
|
|
|
|
|
buttonLayout->addStretch(10);
|
|
|
|
|
|
|
|
m_clearButton = new QPushButton(this);
|
|
|
|
m_clearButton->setText("Clear");
|
|
|
|
buttonLayout->addWidget(m_clearButton);
|
|
|
|
connect(m_clearButton, SIGNAL(clicked()), m_browser, SLOT(clear()));
|
|
|
|
|
|
|
|
m_saveButton = new QPushButton(this);
|
|
|
|
m_saveButton->setText("Save Output");
|
|
|
|
buttonLayout->addWidget(m_saveButton);
|
|
|
|
connect(m_saveButton, SIGNAL(clicked()), this, SLOT(save()));
|
|
|
|
|
|
|
|
resize(400, 300);
|
2018-04-10 07:59:20 +00:00
|
|
|
|
2018-09-14 09:45:05 +00:00
|
|
|
setWindowTitle(tr("Debug") + tr(" - ") + APP_NAME);
|
|
|
|
|
2018-04-10 07:59:20 +00:00
|
|
|
hide();
|
2018-04-07 08:44:39 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
LogBrowserDialog::~LogBrowserDialog()
|
|
|
|
{
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
2018-05-12 10:07:46 +00:00
|
|
|
void LogBrowserDialog::outputMessage(QtMsgType type, const QString &msg, const QString &source, int line)
|
2018-04-07 08:44:39 +00:00
|
|
|
{
|
|
|
|
switch (type) {
|
|
|
|
case QtDebugMsg:
|
2018-05-12 10:07:46 +00:00
|
|
|
m_browser->append(tr("— DEBUG: %1 - %2:%3").arg(msg).arg(source).arg(QString::number(line)));
|
2018-04-07 08:44:39 +00:00
|
|
|
break;
|
|
|
|
|
|
|
|
case QtWarningMsg:
|
2018-05-12 10:07:46 +00:00
|
|
|
m_browser->append(tr("— WARNING: %1 - %2:%3").arg(msg).arg(source).arg(QString::number(line)));
|
2018-04-07 08:44:39 +00:00
|
|
|
break;
|
|
|
|
|
|
|
|
case QtCriticalMsg:
|
2018-05-12 10:07:46 +00:00
|
|
|
m_browser->append(tr("— CRITICAL: %1 - %2:%3").arg(msg).arg(source).arg(QString::number(line)));
|
2018-04-07 08:44:39 +00:00
|
|
|
break;
|
|
|
|
|
|
|
|
case QtInfoMsg:
|
2018-05-12 10:07:46 +00:00
|
|
|
m_browser->append(tr("— INFO: %1 - %2:%3").arg(msg).arg(source).arg(QString::number(line)));
|
2018-04-07 08:44:39 +00:00
|
|
|
break;
|
|
|
|
|
|
|
|
case QtFatalMsg:
|
2018-05-12 10:07:46 +00:00
|
|
|
m_browser->append(tr("— FATAL: %1 - %2:%3").arg(msg).arg(source).arg(QString::number(line)));
|
2018-04-07 08:44:39 +00:00
|
|
|
break;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
void LogBrowserDialog::save()
|
|
|
|
{
|
|
|
|
QString saveFileName = QFileDialog::getSaveFileName(this,
|
|
|
|
tr("Save Log Output"),
|
|
|
|
tr("%1/logfile.txt").arg(QDir::homePath()),
|
|
|
|
tr("Text Files (*.txt);;All Files (*)"));
|
|
|
|
|
|
|
|
if (saveFileName.isEmpty())
|
|
|
|
return;
|
|
|
|
|
|
|
|
QFile file(saveFileName);
|
|
|
|
if (!file.open(QIODevice::WriteOnly)) {
|
|
|
|
QMessageBox::warning(this,
|
|
|
|
tr("Error"),
|
|
|
|
QString(tr("<nobr>File '%1'<br/>cannot be opened for writing.<br/><br/>"
|
|
|
|
"The log output could <b>not</b> be saved!</nobr>"))
|
|
|
|
.arg(saveFileName));
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
|
|
|
QTextStream stream(&file);
|
|
|
|
stream << m_browser->toPlainText();
|
|
|
|
file.close();
|
|
|
|
}
|
|
|
|
|
|
|
|
void LogBrowserDialog::closeEvent(QCloseEvent *e)
|
|
|
|
{
|
2018-04-10 07:59:20 +00:00
|
|
|
e->ignore();
|
|
|
|
hide();
|
2018-04-07 08:44:39 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
void LogBrowserDialog::keyPressEvent(QKeyEvent *e)
|
|
|
|
{
|
|
|
|
// ignore all keyboard events
|
|
|
|
// protects against accidentally closing of the dialog
|
|
|
|
// without asking the user
|
|
|
|
e->ignore();
|
|
|
|
}
|