-/* This file is part of
- * ======================================================
- *
- * LyX, The Document Processor
- *
- * Copyright 1995 Matthias Ettrich
- * Copyright 1995-1999 The LyX Team.
+/**
+ * \file inseterror.C
+ * This file is part of LyX, the document processor.
+ * Licence details can be found in the file COPYING.
*
- * ====================================================== */
+ * \author Lars Gullik Bjønnes
+ *
+ * Full author contact details are available in file CREDITS
+ */
#include <config.h>
-#ifdef __GNUG__
-#pragma implementation
-#endif
-
#include "inseterror.h"
-#ifndef USE_PAINTER
-#include "lyxdraw.h"
-#endif
+
+#include "BufferView.h"
+#include "funcrequest.h"
#include "gettext.h"
-#include "lyx_gui_misc.h" // CancelCloseBoxCB
-#include "Painter.h"
+#include "lyxfont.h"
-/* Error, used for the LaTeX-Error Messages */
+#include "frontends/Dialogs.h"
+#include "frontends/font_metrics.h"
+#include "frontends/LyXView.h"
+#include "frontends/Painter.h"
-InsetError::InsetError()
-{
- form = 0;
-}
+#include "support/LAssert.h"
+
+using std::ostream;
+/* Error, used for the LaTeX-Error Messages */
-InsetError::InsetError(string const & str)
+InsetError::InsetError(string const & str, bool)
: contents(str)
-{
- form = 0;
-}
+{}
InsetError::~InsetError()
{
- if (form) {
- fl_hide_form(form);
- fl_free_form(form);
- form = 0;
- }
+ Dialogs::hide("error", this);
}
-#ifdef USE_PAINTER
-int InsetError::ascent(Painter &, LyXFont const & font) const
-{
- LyXFont efont;
- efont.setSize(font.size()).decSize();
- return efont.maxAscent() + 1;
-}
-#else
-int InsetError::Ascent(LyXFont const & font) const
+dispatch_result InsetError::localDispatch(FuncRequest const & cmd)
{
- LyXFont efont;
- efont.setSize(font.size()).decSize();
- return efont.maxAscent()+1;
-}
-#endif
+ dispatch_result result = UNDISPATCHED;
+ switch (cmd.action) {
+ case LFUN_MOUSE_RELEASE:
+ edit(cmd.view(), cmd.x, cmd.y, cmd.button());
+ break;
-#ifdef USE_PAINTER
-int InsetError::descent(Painter &, LyXFont const & font) const
-{
- LyXFont efont;
- efont.setSize(font.size()).decSize();
- return efont.maxDescent() + 1;
+ default:
+ break;
+ }
+
+ return result;
}
-#else
-int InsetError::Descent(LyXFont const & font) const
+
+
+int InsetError::ascent(BufferView *, LyXFont const & font) const
{
LyXFont efont;
efont.setSize(font.size()).decSize();
- return efont.maxDescent()+1;
+ return font_metrics::maxAscent(efont) + 1;
}
-#endif
-#ifdef USE_PAINTER
-int InsetError::width(Painter &, LyXFont const & font) const
+int InsetError::descent(BufferView *, LyXFont const & font) const
{
LyXFont efont;
efont.setSize(font.size()).decSize();
- return 6 + efont.textWidth(_("Error"), strlen(_("Error")));
+ return font_metrics::maxDescent(efont) + 1;
}
-#else
-int InsetError::Width(LyXFont const & font) const
+
+
+int InsetError::width(BufferView *, LyXFont const & font) const
{
LyXFont efont;
efont.setSize(font.size()).decSize();
- return 6 + efont.textWidth(_("Error"), strlen(_("Error")));
+ return 6 + font_metrics::width(_("Error"), efont);
}
-#endif
-#ifdef USE_PAINTER
-void InsetError::draw(Painter & pain, LyXFont const & font,
+void InsetError::draw(BufferView * bv, LyXFont const & font,
int baseline, float & x) const
{
+ lyx::Assert(bv);
+ cache(bv);
+
+ Painter & pain = bv->painter();
LyXFont efont;
efont.setSize(font.size()).decSize();
efont.setColor(LColor::error);
-
+
// Draw as "Error" in a framed box
x += 1;
- pain.fillRectangle(int(x), baseline - ascent(pain, font) + 1,
- width(pain, font) - 2,
- ascent(pain, font) + descent(pain, font) - 2,
+ pain.fillRectangle(int(x), baseline - ascent(bv, font) + 1,
+ width(bv, font) - 2,
+ ascent(bv, font) + descent(bv, font) - 2,
LColor::insetbg);
- pain.rectangle(int(x), baseline - ascent(pain, font) + 1,
- width(pain, font) - 2,
- ascent(pain, font) + descent(pain, font) - 2,
+ pain.rectangle(int(x), baseline - ascent(bv, font) + 1,
+ width(bv, font) - 2,
+ ascent(bv, font) + descent(bv, font) - 2,
LColor::error);
pain.text(int(x + 2), baseline, _("Error"), efont);
- x += width(pain, font) - 1;
+ x += width(bv, font) - 1;
}
-#else
-void InsetError::Draw(LyXFont font, LyXScreen & scr,
- int baseline, float & x)
-{
- LyXFont efont;
- efont.setSize(font.size()).decSize();
- efont.setLatex(LyXFont::ON);
-
- // Draw as "Error" in a framed box
- x += 1;
- scr.fillRectangle(gc_lighted,
- int(x), baseline - Ascent(font)+1,
- Width(font)-2, Ascent(font)+ Descent(font)-2);
- scr.drawRectangle(gc_foot,
- int(x), baseline-Ascent(font)+1,
- Width(font)-2, Ascent(font)+Descent(font)-2);
- scr.drawString(efont, _("Error"), baseline, int(x+2));
-
- x += Width(font) - 1;
-}
-#endif
-void InsetError::Write(ostream &)
-{
-}
-
-void InsetError::Read(LyXLex &)
-{
-}
-
-
-int InsetError::Latex(ostream &, signed char /*fragile*/)
-{
- return 0;
-}
-
-
-int InsetError::Latex(string &, signed char /*fragile*/)
-{
- return 0;
-}
-
-
-int InsetError::Linuxdoc(string &)
-{
- return 0;
-}
-
-
-int InsetError::DocBook(string &)
-{
- return 0;
-}
-
-
-bool InsetError::AutoDelete() const
-{
- return true;
-}
-
-
-unsigned char InsetError::Editable() const
-{
- return 1;
-}
-
-
-void InsetError::CloseErrorCB(FL_OBJECT * ob, long)
+string const InsetError::editMessage() const
{
- InsetError * inset = static_cast<InsetError*>(ob->u_vdata);
- if (inset->form) {
- fl_hide_form(inset->form);
- fl_free_form(inset->form);
- inset->form = 0;
- }
+ return _("Opened error");
}
-// A C wrapper
-extern "C" void C_InsetError_CloseErrorCB(FL_OBJECT * ob, long data)
+void InsetError::edit(BufferView * bv, int, int, mouse_button::state)
{
- InsetError::CloseErrorCB(ob , data);
-}
-
-
-void InsetError::Edit(int, int)
-{
- static int ow = 400, oh = 240;
-
- if (!form) {
- FL_OBJECT * obj;
- form = fl_bgn_form(FL_UP_BOX, ow, oh);
- strobj = fl_add_box(FL_FRAME_BOX, 10, 10, 380, 180, "");
- fl_set_object_color(strobj, FL_MCOL, FL_MCOL);
- fl_set_object_gravity(strobj, FL_NorthWest, FL_SouthEast);
- obj = fl_add_button(FL_RETURN_BUTTON, 140, 200, 120, 30,
- _("Close"));
- fl_set_object_callback(obj, C_InsetError_CloseErrorCB, 0);
- obj->u_vdata = this;
- fl_set_object_gravity(obj, FL_SouthEast, FL_SouthEast);
- fl_set_object_resize(obj, FL_RESIZE_NONE);
- fl_end_form();
- fl_set_form_atclose(form, CancelCloseBoxCB, 0);
- }
- fl_set_object_label(strobj, contents.c_str());
- if (form->visible) {
- fl_raise_form(form);
- } else {
- fl_show_form(form, FL_PLACE_MOUSE | FL_FREE_SIZE,
- FL_FULLBORDER, _("LaTeX Error"));
- fl_set_form_minsize(form, ow, oh);
- }
+ bv->owner()->getDialogs().show("error", getContents(), this);
}
-Inset * InsetError::Clone() const
+void InsetError::edit(BufferView * bv, bool)
{
- return new InsetError(contents);
+ edit(bv, 0, 0, mouse_button::none);
}