X-Git-Url: https://git.lyx.org/gitweb/?a=blobdiff_plain;f=src%2Ffrontends%2Fqt4%2FGuiProgress.cpp;h=0735265384532e891035c4346f3fecb3a128d498;hb=425d092204118ea6c24c28e85fdf03fcf2bb51a4;hp=d9109b1c50c394917f6eff2ff99eacc900ddc8d3;hpb=41681e71850d9efde66182b552a28fb9dfff6873;p=lyx.git diff --git a/src/frontends/qt4/GuiProgress.cpp b/src/frontends/qt4/GuiProgress.cpp index d9109b1c50..0735265384 100644 --- a/src/frontends/qt4/GuiProgress.cpp +++ b/src/frontends/qt4/GuiProgress.cpp @@ -4,7 +4,8 @@ * This file is part of LyX, the document processor. * Licence details can be found in the file COPYING. * - * \author Peter Kümmel + * \author Peter Kümmel + * \author Pavel Sanda * * Full author contact details are available in file CREDITS. */ @@ -12,55 +13,159 @@ #include #include "GuiProgress.h" +#include "ui_ToggleWarningUi.h" #include "qt_helpers.h" +#include "support/debug.h" #include "support/Systemcall.h" #include +#include +#include +#include namespace lyx { namespace frontend { -GuiProgress::GuiProgress(GuiView & parent, Qt::DockWidgetArea area, - Qt::WindowFlags flags) : DockView(parent, "latex-progress", area, flags) +class GuiToggleWarningDialog : public QDialog, public Ui::ToggleWarningUi { - setWindowTitle(qt_("LaTeX Progress")); - setWidget(&text_edit); - support::Systemcall::registerProgressInterface(this); +public: + GuiToggleWarningDialog(QWidget * parent) : QDialog(parent) + { + Ui::ToggleWarningUi::setupUi(this); + QDialog::setModal(true); + } +}; + + +GuiProgress::GuiProgress(GuiView * view) : view_(view) +{ + connect(this, SIGNAL(processStarted(QString const &)), SLOT(doProcessStarted(QString const &))); + connect(this, SIGNAL(processFinished(QString const &)), SLOT(doProcessFinished(QString const &))); + connect(this, SIGNAL(appendMessage(QString const &)), SLOT(doAppendMessage(QString const &))); + connect(this, SIGNAL(appendError(QString const &)), SLOT(doAppendError(QString const &))); + connect(this, SIGNAL(clearMessages()), SLOT(doClearMessages())); + + // Alert interface + connect(this, SIGNAL(warning(QString const &, QString const &)), + SLOT(doWarning(QString const &, QString const &))); + connect(this, SIGNAL(toggleWarning(QString const &, QString const &, QString const &)), + SLOT(doToggleWarning(QString const &, QString const &, QString const &))); + connect(this, SIGNAL(error(QString const &, QString const &)), + SLOT(doError(QString const &, QString const &))); + connect(this, SIGNAL(information(QString const &, QString const &)), + SLOT(doInformation(QString const &, QString const &))); + + support::ProgressInterface::setInstance(this); +} + + +void GuiProgress::doProcessStarted(QString const & cmd) +{ + QString time = QTime::currentTime().toString(); + appendText(time + ": <" + cmd + "> started"); +} + + +void GuiProgress::doProcessFinished(QString const & cmd) +{ + QString time = QTime::currentTime().toString(); + appendText(time + ": <" + cmd + "> done"); +} + + +void GuiProgress::doAppendMessage(QString const & msg) +{ + appendText(msg); +} + + +void GuiProgress::doAppendError(QString const & msg) +{ + appendText(msg); +} + + +void GuiProgress::doClearMessages() +{ + view_->message(docstring()); +} + + +void GuiProgress::lyxerrFlush() +{ + appendLyXErrMessage(toqstr(lyxerr_stream_.str())); + lyxerr_stream_.str(""); +} + + +void GuiProgress::lyxerrConnect() +{ + lyxerr.setSecond(&lyxerr_stream_); +} + + +void GuiProgress::lyxerrDisconnect() +{ + lyxerr.setSecond(0); +} + + +GuiProgress::~GuiProgress() +{ + lyxerrDisconnect(); } -void GuiProgress::appendMessage(QString const & msg) +void GuiProgress::appendText(QString const & text) { - text_edit.append(msg); - // QEventLoop::ExcludeUserInputEvents: - // don't allow user inputs while processing a document - // if we allow it, we open will Pandora's Box of multithreading - QApplication::processEvents(QEventLoop::ExcludeUserInputEvents); + if (!text.isEmpty()) + view_->updateMessage(text); } -void GuiProgress::clearMessages() +void GuiProgress::doWarning(QString const & title, QString const & message) { - text_edit.clear(); + QMessageBox::warning(qApp->focusWidget(), title, message); } -Dialog * createGuiProgress(GuiView & lv) +void GuiProgress::doToggleWarning(QString const & title, QString const & msg, QString const & formatted) { - GuiView & guiview = static_cast(lv); -#ifdef Q_WS_MACX - // TODO where to show up on the Mac? - //return new GuiProgress(guiview, Qt::RightDockWidgetArea, Qt::Drawer); -#else - return new GuiProgress(guiview, Qt::BottomDockWidgetArea); -#endif + QSettings settings; + if (settings.value("hidden_warnings/" + msg, false).toBool()) + return; + + GuiToggleWarningDialog * dlg = + new GuiToggleWarningDialog(qApp->focusWidget()); + + dlg->setWindowTitle(title); + dlg->messageLA->setText(formatted); + dlg->dontShowAgainCB->setChecked(false); + + if (dlg->exec() == QDialog::Accepted) + if (dlg->dontShowAgainCB->isChecked()) + settings.setValue("hidden_warnings/" + + msg, true); +} + + +void GuiProgress::doError(QString const & title, QString const & message) +{ + QMessageBox::critical(qApp->focusWidget(), title, message); } + +void GuiProgress::doInformation(QString const & title, QString const & message) +{ + QMessageBox::information(qApp->focusWidget(), title, message); +} + + } // namespace frontend } // namespace lyx - +#include "moc_GuiProgress.cpp"