3 * \file GuiProgress.cpp
4 * This file is part of LyX, the document processor.
5 * Licence details can be found in the file COPYING.
10 * Full author contact details are available in file CREDITS.
15 #include "GuiProgress.h"
16 #include "ui_ToggleWarningUi.h"
18 #include "qt_helpers.h"
20 #include "support/debug.h"
21 #include "support/Systemcall.h"
23 #include <QApplication>
25 #include <QMessageBox>
33 class GuiToggleWarningDialog : public QDialog, public Ui::ToggleWarningUi
36 GuiToggleWarningDialog(QWidget * parent) : QDialog(parent)
38 Ui::ToggleWarningUi::setupUi(this);
39 QDialog::setModal(true);
44 GuiProgress::GuiProgress()
46 connect(this, SIGNAL(processStarted(QString const &)), SLOT(doProcessStarted(QString const &)));
47 connect(this, SIGNAL(processFinished(QString const &)), SLOT(doProcessFinished(QString const &)));
48 connect(this, SIGNAL(appendMessage(QString const &)), SLOT(doAppendMessage(QString const &)));
49 connect(this, SIGNAL(appendError(QString const &)), SLOT(doAppendError(QString const &)));
50 connect(this, SIGNAL(clearMessages()), SLOT(doClearMessages()));
53 connect(this, SIGNAL(warning(QString const &, QString const &)),
54 SLOT(doWarning(QString const &, QString const &)));
55 connect(this, SIGNAL(toggleWarning(QString const &, QString const &, QString const &)),
56 SLOT(doToggleWarning(QString const &, QString const &, QString const &)));
57 connect(this, SIGNAL(error(QString const &, QString const &)),
58 SLOT(doError(QString const &, QString const &)));
59 connect(this, SIGNAL(information(QString const &, QString const &)),
60 SLOT(doInformation(QString const &, QString const &)));
61 connect(this, SIGNAL(triggerFlush()),
62 SLOT(startFlushing()));
64 flushDelay_.setInterval(200);
65 flushDelay_.setSingleShot(true);
66 connect(&flushDelay_, SIGNAL(timeout()), this, SLOT(updateWithLyXErr()));
70 QString GuiProgress::currentTime()
72 return QTime::currentTime().toString("hh:mm:ss.zzz");
76 void GuiProgress::doProcessStarted(QString const & cmd)
78 appendText(currentTime() + ": <" + cmd + "> started");
82 void GuiProgress::doProcessFinished(QString const & cmd)
84 appendText(currentTime() + ": <" + cmd + "> done");
88 void GuiProgress::doAppendMessage(QString const & msg)
94 void GuiProgress::doAppendError(QString const & msg)
100 void GuiProgress::doClearMessages()
106 void GuiProgress::startFlushing()
112 void GuiProgress::lyxerrFlush()
118 void GuiProgress::updateWithLyXErr()
120 appendLyXErrMessage(toqstr(lyxerr_stream_.str()));
121 lyxerr_stream_.str("");
125 void GuiProgress::lyxerrConnect()
127 lyxerr.setSecondStream(&lyxerr_stream_);
131 void GuiProgress::lyxerrDisconnect()
133 lyxerr.setSecondStream(0);
137 GuiProgress::~GuiProgress()
143 void GuiProgress::appendText(QString const & text)
146 updateStatusBarMessage(text);
150 void GuiProgress::doWarning(QString const & title, QString const & message)
152 QMessageBox::warning(qApp->focusWidget(), title, message);
156 void GuiProgress::doToggleWarning(QString const & title, QString const & msg, QString const & formatted)
159 if (settings.value("hidden_warnings/" + msg, false).toBool())
162 GuiToggleWarningDialog * dlg =
163 new GuiToggleWarningDialog(qApp->focusWidget());
165 dlg->setWindowTitle(title);
166 dlg->messageLA->setText(formatted);
167 dlg->dontShowAgainCB->setChecked(false);
169 if (dlg->exec() == QDialog::Accepted)
170 if (dlg->dontShowAgainCB->isChecked())
171 settings.setValue("hidden_warnings/"
176 void GuiProgress::doError(QString const & title, QString const & message)
178 QMessageBox::critical(qApp->focusWidget(), title, message);
182 void GuiProgress::doInformation(QString const & title, QString const & message)
184 QMessageBox::information(qApp->focusWidget(), title, message);
188 } // namespace frontend
191 #include "moc_GuiProgress.cpp"