#include <config.h>
#include "GuiErrorList.h"
+
+#include "GuiView.h"
#include "qt_helpers.h"
+#include "Buffer.h"
+#include "BufferView.h"
+#include "FuncRequest.h"
+#include "FuncStatus.h"
+#include "BufferList.h"
+#include "LyX.h"
+#include "ParIterator.h"
+#include "Text.h"
+
+#include "support/debug.h"
+#include "support/gettext.h"
+#include "support/lstrings.h"
+
#include <QListWidget>
-#include <QTextBrowser>
#include <QPushButton>
-#include <QCloseEvent>
+#include <QShowEvent>
+#include <QTextBrowser>
+
+using namespace std;
+using namespace lyx::support;
+
+namespace {
+
+string const guiErrorType(string const & s)
+{
+ if (s == "docbook")
+ return N_("DocBook");
+ else if (s == "literate")
+ return N_("Literate");
+ else if (s == "platex")
+ return N_("pLaTeX");
+ else if (s == "latex")
+ return N_("LaTeX");
+ return s;
+}
+
+} // namespace anon
namespace lyx {
namespace frontend {
-/////////////////////////////////////////////////////////////////////
-//
-// GuiErrorListDialog
-//
-/////////////////////////////////////////////////////////////////////
-
-GuiErrorListDialog::GuiErrorListDialog(GuiErrorList * form)
- : form_(form)
+GuiErrorList::GuiErrorList(GuiView & lv)
+ : GuiDialog(lv, "errorlist", qt_("Error List"))
{
setupUi(this);
+
connect(closePB, SIGNAL(clicked()),
- form, SLOT(slotClose()));
- connect(errorsLW, SIGNAL( itemActivated(QListWidgetItem *)),
- form, SLOT(slotClose()));
- connect( errorsLW, SIGNAL( itemClicked(QListWidgetItem *)),
- this, SLOT(select_adaptor(QListWidgetItem *)));
+ this, SLOT(slotClose()));
+ connect(viewLogPB, SIGNAL(clicked()),
+ this, SLOT(viewLog()));
+ connect(showAnywayPB, SIGNAL(clicked()),
+ this, SLOT(showAnyway()));
+ connect(errorsLW, SIGNAL(currentRowChanged(int)),
+ this, SLOT(select()));
+
+ bc().setPolicy(ButtonPolicy::OkCancelPolicy);
+ bc().setCancel(closePB);
}
-void GuiErrorListDialog::select_adaptor(QListWidgetItem * item)
+void GuiErrorList::showEvent(QShowEvent * e)
{
- form_->select(item);
+ select();
+ paramsToDialog();
+ e->accept();
}
-void GuiErrorListDialog::closeEvent(QCloseEvent * e)
+void GuiErrorList::select()
{
- form_->slotWMHide();
- e->accept();
+ int const item = errorsLW->row(errorsLW->currentItem());
+ if (item == -1)
+ return;
+ goTo(item);
+ descriptionTB->setPlainText(
+ toqstr(errorList()[item].description));
}
-void GuiErrorListDialog::showEvent(QShowEvent *e)
+void GuiErrorList::viewLog()
{
- errorsLW->setCurrentRow(0);
- form_->select(errorsLW->item(0));
- e->accept();
+ if (&buffer() != buf_) {
+ if (!theBufferList().isLoaded(buf_))
+ return;
+ FuncRequest fr(LFUN_BUFFER_SWITCH, buf_->absFileName());
+ dispatch(fr);
+ }
+ dispatch(FuncRequest(LFUN_DIALOG_SHOW, "latexlog"));
}
-/////////////////////////////////////////////////////////////////////
-//
-// GuiErrorList
-//
-/////////////////////////////////////////////////////////////////////
+void GuiErrorList::showAnyway()
+{
+ dispatch(FuncRequest(LFUN_BUFFER_VIEW_CACHE));
+}
-GuiErrorList::GuiErrorList(GuiDialog & parent)
- : GuiView<GuiErrorListDialog>(parent, docstring())
-{}
+void GuiErrorList::paramsToDialog()
+{
+ setTitle(toqstr(name_));
+ errorsLW->clear();
+ descriptionTB->setPlainText(QString());
+
+ ErrorList const & el = errorList();
+ ErrorList::const_iterator it = el.begin();
+ ErrorList::const_iterator const en = el.end();
+ for (; it != en; ++it)
+ errorsLW->addItem(toqstr(it->error));
+ errorsLW->setCurrentRow(0);
+ showAnywayPB->setEnabled(
+ lyx::getStatus(FuncRequest(LFUN_BUFFER_VIEW_CACHE)).enabled());
+}
-void GuiErrorList::build_dialog()
+ErrorList const & GuiErrorList::errorList() const
{
- dialog_.reset(new GuiErrorListDialog(this));
- bc().setCancel(dialog_->closePB);
+ Buffer const * buffer = from_master_
+ ? bufferview()->buffer().masterBuffer()
+ : &bufferview()->buffer();
+ if (buffer == buf_)
+ error_list_ = buffer->errorList(error_type_);
+
+ return error_list_;
}
-void GuiErrorList::select(QListWidgetItem * wi)
+bool GuiErrorList::initialiseParams(string const & data)
{
- int const item = dialog_->errorsLW->row(wi);
- controller().goTo(item);
- dialog_->descriptionTB->setPlainText(toqstr(controller().errorList()[item].description));
+ from_master_ = prefixIs(data, "from_master|");
+ string error_type = data;
+ if (from_master_)
+ error_type = split(data, '|');
+ error_type_ = error_type;
+ buf_ = from_master_ ?
+ bufferview()->buffer().masterBuffer()
+ : &bufferview()->buffer();
+ name_ = bformat(_("%1$s Errors (%2$s)"),
+ _(guiErrorType(error_type)),
+ from_utf8(buf_->absFileName()));
+ paramsToDialog();
+ return true;
}
-void GuiErrorList::update_contents()
+bool GuiErrorList::goTo(int item)
{
- setTitle(from_utf8(controller().name()));
- dialog_->errorsLW->clear();
- dialog_->descriptionTB->setPlainText(QString());
-
- ErrorList::const_iterator it = controller().errorList().begin();
- ErrorList::const_iterator end = controller().errorList().end();
- for(; it != end; ++it) {
- dialog_->errorsLW->addItem(toqstr(it->error));
+ ErrorItem const & err = errorList()[item];
+
+ if (err.par_id == -1)
+ return false;
+
+ Buffer const * errbuf = err.buffer ? err.buffer : buf_;
+
+ if (&buffer() != errbuf) {
+ if (!theBufferList().isLoaded(errbuf))
+ return false;
+ FuncRequest fr(LFUN_BUFFER_SWITCH, errbuf->absFileName());
+ dispatch(fr);
}
+
+ DocIterator dit = errbuf->getParFromID(err.par_id);
+
+ if (dit == doc_iterator_end(errbuf)) {
+ // FIXME: Happens when loading a read-only doc with
+ // unknown layout. Should this be the case?
+ LYXERR0("par id " << err.par_id << " not found");
+ return false;
+ }
+
+ // Don't try to highlight the content of non-editable insets
+ while (!dit.inset().editable())
+ dit.backwardPos();
+
+ // Now make the selection.
+ BufferView * bv = const_cast<BufferView *>(bufferview());
+ if (bv->selectIfEmpty(dit)) {
+ // The paragraph is empty but can be selected
+ bv->processUpdateFlags(Update::Force | Update::FitCursor);
+ return true;
+ }
+ if (dit.empty()) {
+ // The paragraph is empty and cannot be selected
+ return false;
+ }
+ // if pos_end is 0, this means it is end-of-paragraph
+ pos_type const s = dit.lastpos();
+ pos_type const end = err.pos_end ? min(err.pos_end, s) : s;
+ pos_type const start = min(err.pos_start, end);
+ pos_type const range = end == start ? s - start : end - start;
+ // end-of-paragraph cannot be highlighted, so highlight the last thing
+ dit.pos() = range ? start : end - 1;
+ // FIXME LFUN
+ // If we used an LFUN, we would not need these lines:
+ bv->putSelectionAt(dit, max(range, pos_type(1)), false);
+ bv->processUpdateFlags(Update::Force | Update::FitCursor);
+ return true;
}
+
+Dialog * createGuiErrorList(GuiView & lv) { return new GuiErrorList(lv); }
+
} // namespace frontend
} // namespace lyx
-#include "GuiErrorList_moc.cpp"
+#include "moc_GuiErrorList.cpp"