-/* This file is part of
- * ======================================================
- *
- * LyX, The Document Processor
- *
- * Copyright 1998 The LyX Team.
+/**
+ * \file insetminipage.C
+ * This file is part of LyX, the document processor.
+ * Licence details can be found in the file COPYING.
*
- *======================================================*/
+ * \author Jürgen Vigna
+ * \author Lars Gullik Bjønnes
+ *
+ * Full author contact details are available in file CREDITS
+ */
#include <config.h>
-#ifdef __GNUG__
-#pragma implementation
-#endif
-
#include "insetminipage.h"
+#include "insettext.h"
+
+#include "BufferView.h"
+#include "debug.h"
+#include "dimension.h"
+#include "funcrequest.h"
#include "gettext.h"
+#include "Lsstream.h"
#include "lyxfont.h"
-#include "BufferView.h"
-#include "LyXView.h"
-#include "frontends/Dialogs.h"
+#include "lyxlex.h"
#include "lyxtext.h"
-#include "insets/insettext.h"
+#include "Lsstream.h"
+#include "metricsinfo.h"
+
+#include "frontends/LyXView.h"
+#include "frontends/Dialogs.h"
+
#include "support/LOstream.h"
-#include "support/lstrings.h"
-#include "debug.h"
-#include "gettext.h"
using std::ostream;
using std::endl;
+using std::auto_ptr;
// Some information about Minipages in LaTeX:
// have to output "" for minipages.
// (Lgb)
-InsetMinipage::InsetMinipage()
- : InsetCollapsable(), pos_(center),
- inner_pos_(inner_center)
+InsetMinipage::InsetMinipage(BufferParams const & bp)
+ : InsetCollapsable(bp)
{
setLabel(_("minipage"));
LyXFont font(LyXFont::ALL_SANE);
font.decSize();
font.decSize();
- font.setColor(LColor::footnote);
+ font.setColor(LColor::collapsable);
setLabelFont(font);
+#if 0
setAutoCollapse(false);
+#endif
+
+#if 0
+#ifdef WITH_WARNINGS
+#warning Remove this color definitions before 1.2.0 final!
+#endif
+ // just for experimentation :)
+ setBackgroundColor(LColor::green);
+#endif
+
+ inset.setFrameColor(0, LColor::blue);
setInsetName("Minipage");
- width_ = "100%"; // set default to 100% of column_width
}
-InsetMinipage::~InsetMinipage()
+InsetMinipage::InsetMinipage(InsetMinipage const & in)
+ : InsetCollapsable(in), params_(in.params_)
+{}
+
+
+auto_ptr<InsetBase> InsetMinipage::clone() const
{
- hideDialog();
+ return auto_ptr<InsetBase>(new InsetMinipage(*this));
}
-void InsetMinipage::Write(Buffer const * buf, ostream & os) const
+InsetMinipage::~InsetMinipage()
{
- os << getInsetName() << "\n"
- << "position " << pos_ << "\n"
- << "inner_position " << inner_pos_ << "\n"
- << "height \"" << height_ << "\"\n"
- << "width \"" << width_ << "\"\n";
- InsetCollapsable::Write(buf, os);
+ InsetMinipageMailer mailer(*this);
+ mailer.hideDialog();
}
-void InsetMinipage::Read(Buffer const * buf, LyXLex & lex)
+dispatch_result InsetMinipage::localDispatch(FuncRequest const & cmd)
{
- string token;
-
- if (lex.IsOK()) {
- lex.next();
- token = lex.GetString();
- if (token == "position") {
- lex.next();
- pos_ = static_cast<Position>(lex.GetInteger());
- token = string();
- } else {
- lyxerr << "InsetMinipage::Read: Missing 'position'-tag!"
- << endl;
- }
- }
- if (lex.IsOK()) {
- if (token.empty()) {
- lex.next();
- token = lex.GetString();
+ switch (cmd.action) {
+ case LFUN_INSET_MODIFY: {
+ InsetMinipage::Params params;
+ InsetMinipageMailer::string2params(cmd.argument, params);
+
+ params_.pos = params.pos;
+ params_.width = params.width;
+
+ /* FIXME: I refuse to believe we have to live
+ * with ugliness like this ... */
+ inset.getLyXText(cmd.view())->fullRebreak();
+ cmd.view()->updateInset(this);
+ return DISPATCHED;
}
- if (token == "inner_position") {
- lex.next();
- inner_pos_ = static_cast<InnerPosition>(lex.GetInteger());
- token = string();
- } else {
- lyxerr << "InsetMinipage::Read: Missing 'inner_position'-tag!"
- << endl;
- }
- }
- if (lex.IsOK()) {
- if (token.empty()) {
- lex.next();
- token = lex.GetString();
- }
- if (token == "height") {
- lex.next();
- height_ = lex.GetString();
- token = string();
- } else {
- lyxerr << "InsetMinipage::Read: Missing 'height'-tag!"
- << endl;
+
+ case LFUN_INSET_DIALOG_UPDATE:
+ InsetMinipageMailer(*this).updateDialog(cmd.view());
+ return DISPATCHED;
+
+ default:
+ return InsetCollapsable::localDispatch(cmd);
}
- }
- if (lex.IsOK()) {
- if (token.empty()) {
- lex.next();
- token = lex.GetString();
+}
+
+
+void InsetMinipage::Params::write(ostream & os) const
+{
+ os << "Minipage" << '\n'
+ << "position " << pos << '\n'
+ << "inner_position " << inner_pos << '\n'
+ << "height \"" << height.asString() << "\"\n"
+ << "width \"" << width.asString() << "\"\n";
+}
+
+
+void InsetMinipage::Params::read(LyXLex & lex)
+{
+ if (lex.isOK()) {
+ lex.next();
+ string const token = lex.getString();
+ if (token == "position") {
+ lex.next();
+ pos = static_cast<Position>(lex.getInteger());
+ } else {
+ lyxerr << "InsetMinipage::Read: Missing 'position'-tag!"
+ << endl;
+ // take countermeasures
+ lex.pushToken(token);
+ }
}
- if (token == "width") {
- lex.next();
- width_ = lex.GetString();
- token = string();
- } else {
- lyxerr << "InsetMinipage::Read: Missing 'width'-tag!"
- << endl;
+ if (lex.isOK()) {
+ lex.next();
+ string const token = lex.getString();
+ if (token == "inner_position") {
+ lex.next();
+ inner_pos = static_cast<InnerPosition>(lex.getInteger());
+ } else {
+ lyxerr << "InsetMinipage::Read: Missing 'inner_position'-tag!"
+ << endl;
+ // take countermeasures
+ lex.pushToken(token);
+ }
}
- }
-#warning Remove me before final 1.2.0 (Jug)
- // this is only for compatibility to the intermediate format and should
- // vanish till the final 1.2.0!
- if (lex.IsOK()) {
- if (token.empty()) {
- lex.next();
- token = lex.GetString();
+ if (lex.isOK()) {
+ lex.next();
+ string const token = lex.getString();
+ if (token == "height") {
+ lex.next();
+ height = LyXLength(lex.getString());
+ } else {
+ lyxerr << "InsetMinipage::Read: Missing 'height'-tag!"
+ << endl;
+ // take countermeasures
+ lex.pushToken(token);
+ }
}
- if (token == "widthp") {
- lex.next();
- // only do this if the width_-string was not already set!
- if (width_.empty())
- width_ = lex.GetString() + "%";
- token = string();
- } else {
- lyxerr << "InsetMinipage::Read: Missing 'widthp_'-tag!"
- << endl;
+ if (lex.isOK()) {
+ lex.next();
+ string const token = lex.getString();
+ if (token == "width") {
+ lex.next();
+ width = LyXLength(lex.getString());
+ } else {
+ lyxerr << "InsetMinipage::Read: Missing 'width'-tag!"
+ << endl;
+ // take countermeasures
+ lex.pushToken(token);
+ }
}
- }
- if (!token.empty())
- lex.pushToken(token);
- InsetCollapsable::Read(buf, lex);
}
-Inset * InsetMinipage::Clone(Buffer const &) const
+void InsetMinipage::write(Buffer const * buf, ostream & os) const
{
- InsetMinipage * result = new InsetMinipage;
- result->inset.init(&inset);
-
- result->collapsed = collapsed;
- result->pos_ = pos_;
- result->inner_pos_ = inner_pos_;
- result->height_ = height_;
- result->width_ = width_;
- return result;
+ params_.write(os);
+ InsetCollapsable::write(buf, os);
}
-int InsetMinipage::ascent(BufferView * bv, LyXFont const & font) const
+void InsetMinipage::read(Buffer const * buf, LyXLex & lex)
{
- if (collapsed)
- return ascent_collapsed(bv->painter(), font);
- else {
- // Take placement into account.
- int i = 0;
- switch (pos_) {
- case top:
- i = InsetCollapsable::ascent(bv, font);
- break;
- case center:
- i = (InsetCollapsable::ascent(bv, font)
- + InsetCollapsable::descent(bv, font)) / 2;
- break;
- case bottom:
- i = InsetCollapsable::descent(bv, font);
- break;
- }
- return i;
- }
+ params_.read(lex);
+ InsetCollapsable::read(buf, lex);
}
-int InsetMinipage::descent(BufferView * bv, LyXFont const & font) const
+void InsetMinipage::metrics(MetricsInfo & mi, Dimension & dim) const
{
- if (collapsed)
- return descent_collapsed(bv->painter(), font);
+ if (collapsed_)
+ dimension_collapsed(dim);
else {
- // Take placement into account.
- int i = 0;
- switch (pos_) {
+ Dimension d;
+ MetricsInfo m = mi;
+ m.base.textwidth = params_.width.inPixels(mi.base.textwidth);
+ InsetCollapsable::metrics(m, d);
+ switch (params_.pos) {
case top:
- i = InsetCollapsable::descent(bv, font);
+ dim.asc = d.asc;
+ dim.des = d.des;
break;
case center:
- i = (InsetCollapsable::ascent(bv, font)
- + InsetCollapsable::descent(bv, font)) / 2;
+ dim.asc = d.ascent() + d.descent() / 2;
+ dim.des = dim.asc;
break;
case bottom:
- i = InsetCollapsable::ascent(bv, font);
+ dim.asc = d.des;
+ dim.des = d.asc;
break;
}
- return i;
+ dim.wid = d.wid;
}
+ dim_ = dim;
}
-string const InsetMinipage::EditMessage() const
+string const InsetMinipage::editMessage() const
{
return _("Opened Minipage Inset");
}
-int InsetMinipage::Latex(Buffer const * buf,
- ostream & os, bool fragile, bool fp) const
+int InsetMinipage::latex(Buffer const * buf, ostream & os,
+ LatexRunParams const & runparams) const
{
string s_pos;
- switch (pos_) {
+ switch (params_.pos) {
case top:
- s_pos += "t";
+ s_pos += 't';
break;
case center:
- s_pos += "c";
+ s_pos += 'c';
break;
case bottom:
- s_pos += "b";
+ s_pos += 'b';
break;
}
os << "\\begin{minipage}[" << s_pos << "]{"
- << LyXLength(width_).asLatexString() << "}%\n";
-
- int i = inset.Latex(buf, os, fragile, fp);
+ << params_.width.asLatexString() << "}%\n";
+
+ int i = inset.latex(buf, os, runparams);
os << "\\end{minipage}%\n";
return i + 2;
}
-bool InsetMinipage::InsertInsetAllowed(Inset * in) const
+bool InsetMinipage::insetAllowed(InsetOld::Code code) const
{
- if ((in->LyxCode() == Inset::FLOAT_CODE) ||
- (in->LyxCode() == Inset::MARGIN_CODE)) {
+ if (code == InsetOld::FLOAT_CODE || code == InsetOld::MARGIN_CODE)
return false;
- }
- return true;
-}
-
-InsetMinipage::Position InsetMinipage::pos() const
-{
- return pos_;
+ return InsetCollapsable::insetAllowed(code);
}
-void InsetMinipage::pos(InsetMinipage::Position p)
+bool InsetMinipage::showInsetDialog(BufferView * bv) const
{
- pos_ = p;
-}
-
+ if (!inset.showInsetDialog(bv)) {
+ InsetMinipage * tmp = const_cast<InsetMinipage *>(this);
+ InsetMinipageMailer mailer(*tmp);
+ mailer.showDialog(bv);
+ }
-InsetMinipage::InnerPosition InsetMinipage::innerPos() const
-{
- return inner_pos_;
+ return true;
}
-void InsetMinipage::innerPos(InsetMinipage::InnerPosition ip)
+int InsetMinipage::latexTextWidth(BufferView * bv) const
{
- inner_pos_ = ip;
+ return params_.width.inPixels(InsetCollapsable::latexTextWidth(bv));
}
-string const & InsetMinipage::height() const
-{
- return height_;
-}
+InsetMinipage::Params::Params()
+ : pos(center),
+ inner_pos(inner_center),
+ width(100, LyXLength::PCW)
+{}
-void InsetMinipage::height(string const & ll)
-{
- height_ = ll;
-}
+string const InsetMinipageMailer:: name_("minipage");
+InsetMinipageMailer::InsetMinipageMailer(InsetMinipage & inset)
+ : inset_(inset)
+{}
-string const & InsetMinipage::width() const
+
+string const InsetMinipageMailer::inset2string(Buffer const &) const
{
- return width_;
+ return params2string(inset_.params());
}
-void InsetMinipage::width(string const & ll)
+void InsetMinipageMailer::string2params(string const & in,
+ InsetMinipage::Params & params)
{
- width_ = ll;
-}
+ params = InsetMinipage::Params();
+ if (in.empty())
+ return;
-bool InsetMinipage::ShowInsetDialog(BufferView * bv) const
-{
- if (!inset.ShowInsetDialog(bv))
- bv->owner()->getDialogs()->showMinipage(const_cast<InsetMinipage *>(this));
- return true;
-}
+ istringstream data(STRCONV(in));
+ LyXLex lex(0, 0);
+ lex.setStream(data);
+ if (lex.isOK()) {
+ lex.next();
+ string const token = lex.getString();
+ if (token != "minipage")
+ return;
+ }
-void InsetMinipage::InsetButtonRelease(BufferView * bv, int x, int y,
- int button)
-{
- if (button == 3) {
- ShowInsetDialog(bv);
- return;
- }
- InsetCollapsable::InsetButtonRelease(bv, x, y, button);
+ // This is part of the inset proper that is usually swallowed
+ // by Buffer::readInset
+ if (lex.isOK()) {
+ lex.next();
+ string const token = lex.getString();
+ if (token != "Minipage")
+ return;
+ }
+
+ if (lex.isOK()) {
+ params.read(lex);
+ }
}
-int InsetMinipage::getMaxWidth(BufferView * bv, UpdatableInset const * inset)
- const
+string const
+InsetMinipageMailer::params2string(InsetMinipage::Params const & params)
{
- if (!width_.empty())
- return VSpace(width_).inPixels(bv);
- // this should not happen!
- return InsetCollapsable::getMaxWidth(bv, inset);
+ ostringstream data;
+ data << name_ << ' ';
+ params.write(data);
+ return STRCONV(data.str());
}