#include "MathSupport.h"
#include "InsetMathRef.h"
-#include "bufferview_funcs.h"
-#include "Text.h"
-
#include "Buffer.h"
+#include "buffer_funcs.h"
#include "BufferParams.h"
#include "BufferView.h"
#include "CutAndPaste.h"
#include "FuncStatus.h"
-#include "Color.h"
#include "LaTeXFeatures.h"
#include "Cursor.h"
-#include "debug.h"
#include "DispatchResult.h"
#include "FuncRequest.h"
-#include "gettext.h"
#include "LyXRC.h"
#include "OutputParams.h"
+#include "ParIterator.h"
#include "sgml.h"
+#include "Text.h"
#include "TextPainter.h"
-#include "Undo.h"
+#include "TocBackend.h"
#include "insets/RenderPreview.h"
#include "insets/InsetLabel.h"
#include "graphics/PreviewImage.h"
#include "graphics/PreviewLoader.h"
-#include "support/lyxlib.h"
-#include "support/lstrings.h"
+#include "frontends/Painter.h"
-#include <boost/bind.hpp>
+#include "support/debug.h"
+#include "support/gettext.h"
+#include "support/lstrings.h"
#include <sstream>
+using namespace std;
+using namespace lyx::support;
namespace lyx {
using cap::grabAndEraseSelection;
-using support::bformat;
-using support::subst;
-
-using std::endl;
-using std::max;
-using std::ostream;
-using std::auto_ptr;
-using std::istringstream;
-using std::ostringstream;
-using std::pair;
-using std::swap;
-using std::vector;
-
namespace {
}
}
+static InsetLabel * dummy_pointer = 0;
InsetMathHull::InsetMathHull()
- : InsetMathGrid(1, 1), type_(hullNone), nonum_(1), label_(1),
+ : InsetMathGrid(1, 1), type_(hullNone), nonum_(1, false), label_(1, dummy_pointer),
preview_(new RenderPreview(this))
{
//lyxerr << "sizeof InsetMath: " << sizeof(InsetMath) << endl;
//lyxerr << "sizeof MetricsInfo: " << sizeof(MetricsInfo) << endl;
//lyxerr << "sizeof InsetMathChar: " << sizeof(InsetMathChar) << endl;
- //lyxerr << "sizeof Font: " << sizeof(Font) << endl;
+ //lyxerr << "sizeof FontInfo: " << sizeof(FontInfo) << endl;
initMath();
setDefaults();
}
InsetMathHull::InsetMathHull(HullType type)
- : InsetMathGrid(getCols(type), 1), type_(type), nonum_(1), label_(1),
+ : InsetMathGrid(getCols(type), 1), type_(type), nonum_(1, false), label_(1, dummy_pointer),
preview_(new RenderPreview(this))
{
initMath();
InsetMathHull::InsetMathHull(InsetMathHull const & other)
- : InsetMathGrid(other),
- type_(other.type_), nonum_(other.nonum_), label_(other.label_),
- preview_(new RenderPreview(this))
-{}
+{
+ operator=(other);
+}
InsetMathHull::~InsetMathHull()
-{}
+{
+ for (size_t i = 0; i < label_.size(); ++i)
+ delete label_[i];
+}
-auto_ptr<Inset> InsetMathHull::doClone() const
+Inset * InsetMathHull::clone() const
{
- return auto_ptr<Inset>(new InsetMathHull(*this));
+ return new InsetMathHull(*this);
}
{
if (this == &other)
return *this;
- *static_cast<InsetMathGrid*>(this) = InsetMathGrid(other);
+ InsetMathGrid::operator=(other);
type_ = other.type_;
nonum_ = other.nonum_;
+ for (size_t i = 0; i < label_.size(); ++i)
+ delete label_[i];
label_ = other.label_;
+ for (size_t i = 0; i != label_.size(); ++i) {
+ if (label_[i])
+ label_[i] = new InsetLabel(*label_[i]);
+ }
preview_.reset(new RenderPreview(*other.preview_, this));
return *this;
}
+void InsetMathHull::setBuffer(Buffer & buffer)
+{
+ buffer_ = &buffer;
+ for (idx_type i = 0, n = nargs(); i != n; ++i) {
+ MathData & data = cell(i);
+ for (size_t j = 0; j != data.size(); ++j)
+ data[j].nucleus()->setBuffer(buffer);
+ }
+
+ for (size_t i = 0; i != label_.size(); ++i) {
+ if (label_[i])
+ label_[i]->setBuffer(buffer);
+ }
+}
+
+
+void InsetMathHull::updateLabels(ParIterator const & it)
+{
+ if (!buffer_) {
+ //FIXME: buffer_ should be set at creation for this inset! Problem is
+ // This inset is created at too many places (see Parser::parse1() in
+ // MathParser.cpp).
+ return;
+ }
+ for (size_t i = 0; i != label_.size(); ++i) {
+ if (label_[i])
+ label_[i]->updateLabels(it);
+ }
+}
+
+
+void InsetMathHull::addToToc(ParConstIterator const & pit) const
+{
+ if (!buffer_) {
+ //FIXME: buffer_ should be set at creation for this inset! Problem is
+ // This inset is created at too many places (see Parser::parse1() in
+ // MathParser.cpp).
+ return;
+ }
+
+ // FIXME: it would be way better to directly use InsetLabel instead of this
+ // label list. But it should be possible to copy&paste the code in
+ // InsetLabel::addToToc() anyway.
+
+ Toc & toc = buffer().tocBackend().toc("equation");
+
+ for (row_type row = 0; row != nrows(); ++row) {
+ if (nonum_[row])
+ continue;
+ if (label_[row])
+ label_[row]->addToToc(pit);
+ toc.push_back(TocItem(pit, 0, nicelabel(row)));
+ }
+}
+
+
Inset * InsetMathHull::editXY(Cursor & cur, int x, int y)
{
if (use_preview_) {
{
if (type_ == hullEqnArray)
return "rcl"[col];
+ if (type_ == hullGather)
+ return 'c';
if (type_ >= hullAlign)
return "rl"[col & 1];
return 'c';
{
if (!editing(bv) && RenderPreview::status() == LyXRC::PREVIEW_ON) {
graphics::PreviewImage const * pimage =
- preview_->getPreviewImage(*bv->buffer());
+ preview_->getPreviewImage(bv->buffer());
return pimage && pimage->image();
}
return false;
}
-bool InsetMathHull::metrics(MetricsInfo & mi, Dimension & dim) const
+void InsetMathHull::metrics(MetricsInfo & mi, Dimension & dim) const
{
if (previewState(mi.base.bv)) {
preview_->metrics(mi, dim);
dim.wid += 1;
if (display())
dim.des += displayMargin();
- if (dim_ == dim)
- return false;
- dim_ = dim;
- return true;
+ // Cache the inset dimension.
+ setDimCache(mi, dim);
+ return;
}
FontSetChanger dummy1(mi.base, standardFont());
math_font_max_dim(mi.base.font, asc, des);
dim.asc = max(dim.asc, asc);
dim.des = max(dim.des, des);
-
- if (dim_ == dim)
- return false;
- dim_ = dim;
- return true;
+ // Cache the inset dimension.
+ // FIXME: This will overwrite InsetMathGrid dimension, is that OK?
+ setDimCache(mi, dim);
}
void InsetMathHull::draw(PainterInfo & pi, int x, int y) const
{
use_preview_ = previewState(pi.base.bv);
+ Dimension const dim = dimension(*pi.base.bv);
+
+ // background of mathed under focus is not painted because
+ // selection at the top level of nested inset is difficult to handle.
+ if (!editing(pi.base.bv))
+ pi.pain.fillRectangle(x + 1, y - dim.asc + 1, dim.wid - 2,
+ dim.asc + dim.des - 1, Color_mathbg);
if (use_preview_) {
// one pixel gap in front
}
-namespace {
-
-docstring const latex_string(InsetMathHull const & inset)
+static docstring latexString(InsetMathHull const & inset)
{
odocstringstream ls;
WriteStream wi(ls, false, false);
return ls.str();
}
-} // namespace anon
-
void InsetMathHull::addPreview(graphics::PreviewLoader & ploader) const
{
if (RenderPreview::status() == LyXRC::PREVIEW_ON) {
- docstring const snippet = latex_string(*this);
+ docstring const snippet = latexString(*this);
preview_->addPreview(snippet, ploader);
}
}
-bool InsetMathHull::notifyCursorLeaves(Cursor & cur)
+bool InsetMathHull::notifyCursorLeaves(Cursor const & /*old*/, Cursor & cur)
{
if (RenderPreview::status() == LyXRC::PREVIEW_ON) {
Buffer const & buffer = cur.buffer();
- docstring const snippet = latex_string(*this);
+ docstring const snippet = latexString(*this);
preview_->addPreview(snippet, buffer);
preview_->startLoading(buffer);
cur.updateFlags(Update::Force);
docstring InsetMathHull::label(row_type row) const
{
BOOST_ASSERT(row < nrows());
- return label_[row];
+ if (InsetLabel * il = label_[row])
+ return il->screenLabel();
+ return docstring();
}
void InsetMathHull::label(row_type row, docstring const & label)
{
//lyxerr << "setting label '" << label << "' for row " << row << endl;
- label_[row] = label;
+ if (label_[row]) {
+ if (label.empty()) {
+ delete label_[row];
+ label_[row] = dummy_pointer;
+ } else
+ label_[row]->updateCommand(label);
+ return;
+ }
+ InsetCommandParams p(LABEL_CODE);
+ p["name"] = label;
+ label_[row] = new InsetLabel(p);
+ if (buffer_)
+ label_[row]->setBuffer(buffer());
}
void InsetMathHull::numbered(row_type row, bool num)
{
nonum_[row] = !num;
- if (nonum_[row])
- label_[row].clear();
+ if (nonum_[row] && label_[row]) {
+ delete label_[row];
+ label_[row] = 0;
+ }
}
}
-bool InsetMathHull::display() const
-{
- return type_ != hullSimple && type_ != hullNone;
-}
-
-
-void InsetMathHull::getLabelList(Buffer const &, vector<docstring> & labels) const
+Inset::DisplayType InsetMathHull::display() const
{
- for (row_type row = 0; row < nrows(); ++row)
- if (!label_[row].empty() && nonum_[row] != 1)
- labels.push_back(label_[row]);
+ return (type_ != hullSimple && type_ != hullNone) ? AlignCenter : Inline;
}
//if (features.amsstyle)
// return;
- features.require("boldsymbol");
//features.binom = true;
InsetMathGrid::validate(features);
{
if (!rowChangeOK())
return;
- nonum_.insert(nonum_.begin() + row + 1, !numberedType());
- label_.insert(label_.begin() + row + 1, docstring());
+
+ bool numbered = numberedType();
+ if (type_ == hullMultline) {
+ if (row + 1 == nrows())
+ nonum_[row] = true;
+ else
+ numbered = false;
+ }
+
+ nonum_.insert(nonum_.begin() + row + 1, !numbered);
+ label_.insert(label_.begin() + row + 1, dummy_pointer);
InsetMathGrid::addRow(row);
}
return;
if (row + 1 == nrows())
--row;
- swap(nonum_[row], nonum_[row + 1]);
+ // gcc implements the standard std::vector<bool> which is *not* a container:
+ // http://www.gotw.ca/publications/N1185.pdf
+ // As a results, it doesn't like this:
+ // swap(nonum_[row], nonum_[row + 1]);
+ // so we do it manually:
+ bool const b = nonum_[row];
+ nonum_[row] = nonum_[row + 1];
+ nonum_[row + 1] = b;
swap(label_[row], label_[row + 1]);
InsetMathGrid::swapRow(row);
}
if (row == nrows() + 1)
row--;
nonum_.erase(nonum_.begin() + row);
+ delete label_[row];
label_.erase(label_.begin() + row);
}
{
if (nonum_[row])
return docstring();
- if (label_[row].empty())
+ if (!label_[row])
return from_ascii("(#)");
- return '(' + label_[row] + ')';
+ return '(' + label_[row]->screenLabel() + from_ascii(", #)");
}
BOOST_ASSERT(ncols() < 3);
if (ncols() < 2)
splitTo2Cols();
- InsetMathGrid::addCol(1);
+ InsetMathGrid::addCol(2);
for (row_type row = 0; row < nrows(); ++row) {
idx_type const i = 3 * row + 1;
if (cell(i).size()) {
else {
splitTo3Cols();
while (ncols() < cols)
- InsetMathGrid::addCol(ncols() - 1);
+ InsetMathGrid::addCol(ncols());
}
return;
}
else if (type_ == hullEqnArray) {
if (newtype < type_) {
// set correct (no)numbering
- bool allnonum = true;
- for (row_type row = 0; row < nrows(); ++row)
- if (!nonum_[row])
- allnonum = false;
+ nonum_[0] = true;
+ for (row_type row = 0; row < nrows(); ++row) {
+ if (!nonum_[row]) {
+ nonum_[0] = false;
+ break;
+ }
+ }
// set first non-empty label
- docstring label;
for (row_type row = 0; row < nrows(); ++row) {
- if (!label_[row].empty()) {
- label = label_[row];
+ if (label_[row]) {
+ label_[0] = label_[row];
break;
}
}
glueall();
- nonum_[0] = allnonum;
- label_[0] = label;
mutate(newtype);
} else { // align & Co.
changeCols(2);
{
docstring res;
if (numberedType()) {
- if (!label_[row].empty() && !nonum_[row])
- res += "\\label{" + label_[row] + '}';
+ if (label_[row] && !nonum_[row])
+ res += "\\label{" + label_[row]->getParam("name") + '}';
if (nonum_[row] && (type_ != hullMultline))
res += "\\nonumber ";
}
iss >> dlang >> extra;
if (extra.empty())
extra = from_ascii("noextra");
- std::string const lang = to_ascii(dlang);
+ string const lang = to_ascii(dlang);
-#ifdef WITH_WARNINGS
-#warning temporarily disabled
+ // FIXME: temporarily disabled
//if (cur.selection()) {
// MathData ar;
// selGet(cur.ar);
// insert(pipeThroughExtern(lang, extra, ar));
// return;
//}
-#endif
MathData eq;
eq.push_back(MathAtom(new InsetMathChar('=')));
cur.pos() = 0;
MathData ar = cur.cell();
lyxerr << "use cell: " << ar << endl;
-#ifdef WITH_WARNINGS
-#warning temporarily disabled
-#endif
+ // FIXME: temporarily disabled
addRow(cur.row());
++cur.idx();
++cur.idx();
//lyxerr << "action: " << cmd.action << endl;
switch (cmd.action) {
- case LFUN_FINISHED_LEFT:
+ case LFUN_FINISHED_BACKWARD:
+ case LFUN_FINISHED_FORWARD:
case LFUN_FINISHED_RIGHT:
- case LFUN_FINISHED_UP:
- case LFUN_FINISHED_DOWN:
+ case LFUN_FINISHED_LEFT:
//lyxerr << "action: " << cmd.action << endl;
InsetMathGrid::doDispatch(cur, cmd);
- notifyCursorLeaves(cur);
cur.undispatched();
break;
// just swallow this
break;
- case LFUN_BREAK_LINE:
+ case LFUN_NEWLINE_INSERT:
// some magic for the common case
if (type_ == hullSimple || type_ == hullEquation) {
- recordUndoInset(cur);
+ cur.recordUndoInset();
bool const align =
- cur.bv().buffer()->params().use_amsmath == BufferParams::package_on;
+ cur.bv().buffer().params().use_amsmath == BufferParams::package_on;
mutate(align ? hullAlign : hullEqnArray);
- cur.idx() = 0;
+ cur.idx() = nrows() * ncols() - 1;
cur.pos() = cur.lastpos();
}
InsetMathGrid::doDispatch(cur, cmd);
break;
- case LFUN_MATH_NUMBER:
+ case LFUN_MATH_NUMBER_TOGGLE: {
//lyxerr << "toggling all numbers" << endl;
- if (display()) {
- recordUndoInset(cur);
- bool old = numberedType();
- if (type_ == hullMultline)
- numbered(nrows() - 1, !old);
- else
- for (row_type row = 0; row < nrows(); ++row)
- numbered(row, !old);
-
- cur.message(old ? _("No number") : _("Number"));
- }
+ cur.recordUndoInset();
+ bool old = numberedType();
+ if (type_ == hullMultline)
+ numbered(nrows() - 1, !old);
+ else
+ for (row_type row = 0; row < nrows(); ++row)
+ numbered(row, !old);
+
+ cur.message(old ? _("No number") : _("Number"));
break;
+ }
- case LFUN_MATH_NONUMBER:
- if (display()) {
- recordUndoInset(cur);
- row_type r = (type_ == hullMultline) ? nrows() - 1 : cur.row();
- bool old = numbered(r);
- cur.message(old ? _("No number") : _("Number"));
- numbered(r, !old);
- }
+ case LFUN_MATH_NUMBER_LINE_TOGGLE: {
+ cur.recordUndoInset();
+ row_type r = (type_ == hullMultline) ? nrows() - 1 : cur.row();
+ bool old = numbered(r);
+ cur.message(old ? _("No number") : _("Number"));
+ numbered(r, !old);
break;
+ }
case LFUN_LABEL_INSERT: {
- recordUndoInset(cur);
+ cur.recordUndoInset();
row_type r = (type_ == hullMultline) ? nrows() - 1 : cur.row();
docstring old_label = label(r);
docstring const default_label = from_ascii(
if (old_label.empty())
old_label = default_label;
- InsetCommandParams p("label");
+ InsetCommandParams p(LABEL_CODE);
p["name"] = cmd.argument().empty() ? old_label : cmd.argument();
- std::string const data = InsetCommandMailer::params2string("label", p);
+ string const data = InsetCommand::params2string("label", p);
if (cmd.argument().empty())
- cur.bv().showInsetDialog("label", data, 0);
+ cur.bv().showDialog("label", data);
else {
FuncRequest fr(LFUN_INSET_INSERT, data);
dispatch(cur, fr);
break;
}
+ case LFUN_WORD_DELETE_FORWARD:
+ case LFUN_CHAR_DELETE_FORWARD:
+ if (col(cur.idx()) + 1 == ncols()
+ && cur.pos() == cur.lastpos()) {
+ if (!label(row(cur.idx())).empty()) {
+ cur.recordUndoInset();
+ label(row(cur.idx()), docstring());
+ } else if (numbered(row(cur.idx()))) {
+ cur.recordUndoInset();
+ numbered(row(cur.idx()), false);
+ } else {
+ InsetMathGrid::doDispatch(cur, cmd);
+ return;
+ }
+ } else {
+ InsetMathGrid::doDispatch(cur, cmd);
+ return;
+ }
+ break;
+
case LFUN_INSET_INSERT: {
//lyxerr << "arg: " << to_utf8(cmd.argument()) << endl;
- std::string const name = cmd.getArg(0);
+ // FIXME: this should be cleaned up to use InsetLabel methods directly.
+ string const name = cmd.getArg(0);
if (name == "label") {
- InsetCommandParams p("label");
- InsetCommandMailer::string2params(name, to_utf8(cmd.argument()), p);
+ InsetCommandParams p(LABEL_CODE);
+ InsetCommand::string2params(name, to_utf8(cmd.argument()), p);
docstring str = p["name"];
- recordUndoInset(cur);
+ cur.recordUndoInset();
row_type const r = (type_ == hullMultline) ? nrows() - 1 : cur.row();
- str = support::trim(str);
+ str = trim(str);
if (!str.empty())
numbered(r, true);
docstring old = label(r);
if (str != old) {
- cur.bv().buffer()->changeRefsIfUnique(old, str,
- Inset::REF_CODE);
- label(r, str);
+ if (label_[r])
+ // The label will take care of the reference update.
+ label(r, str);
+ else {
+ label(r, str);
+ // Newly created inset so initialize it.
+ label_[r]->initView();
+ }
}
break;
}
}
case LFUN_MATH_EXTERN:
- recordUndoInset(cur);
+ cur.recordUndoInset();
doExtern(cur, cmd);
break;
case LFUN_MATH_MUTATE: {
- recordUndoInset(cur);
+ cur.recordUndoInset();
row_type row = cur.row();
col_type col = cur.col();
mutate(hullType(cmd.argument()));
}
if (cur.pos() > cur.lastpos())
cur.pos() = cur.lastpos();
+
+ // FIXME: find some more clever handling of the selection,
+ // i.e. preserve it.
+ cur.clearSelection();
//cur.dispatched(FINISHED);
break;
}
case LFUN_MATH_DISPLAY: {
- recordUndoInset(cur);
+ cur.recordUndoInset();
mutate(type_ == hullSimple ? hullEquation : hullSimple);
cur.idx() = 0;
cur.pos() = cur.lastpos();
FuncStatus & status) const
{
switch (cmd.action) {
- case LFUN_FINISHED_LEFT:
+ case LFUN_FINISHED_BACKWARD:
+ case LFUN_FINISHED_FORWARD:
case LFUN_FINISHED_RIGHT:
- case LFUN_FINISHED_UP:
- case LFUN_FINISHED_DOWN:
- status.enabled(true);
- return true;
- case LFUN_BREAK_LINE:
- case LFUN_MATH_NUMBER:
- case LFUN_MATH_NONUMBER:
+ case LFUN_FINISHED_LEFT:
+ case LFUN_UP:
+ case LFUN_DOWN:
+ case LFUN_NEWLINE_INSERT:
case LFUN_MATH_EXTERN:
case LFUN_MATH_MUTATE:
case LFUN_MATH_DISPLAY:
// we handle these
status.enabled(true);
return true;
+ case LFUN_MATH_NUMBER_TOGGLE:
+ // FIXME: what is the right test, this or the one of
+ // LABEL_INSERT?
+ status.enabled(display());
+ status.setOnOff(numberedType());
+ return true;
+ case LFUN_MATH_NUMBER_LINE_TOGGLE: {
+ // FIXME: what is the right test, this or the one of
+ // LABEL_INSERT?
+ status.enabled(display());
+ row_type const r = (type_ == hullMultline) ? nrows() - 1 : cur.row();
+ status.setOnOff(numbered(r));
+ return true;
+ }
case LFUN_LABEL_INSERT:
status.enabled(type_ != hullSimple);
return true;
return InsetMathGrid::getStatus(cur, cmd, status);
case LFUN_TABULAR_FEATURE: {
istringstream is(to_utf8(cmd.argument()));
- std::string s;
+ string s;
is >> s;
if (!rowChangeOK()
&& (s == "append-row"
{
// this whole function is a hack and won't work for incremental font
// changes...
- recordUndo(cur);
+ cur.recordUndo();
if (cur.inset().asInsetMath()->name() == font)
cur.handleFont(to_utf8(font));
else {
void InsetMathHull::handleFont2(Cursor & cur, docstring const & arg)
{
- recordUndo(cur);
+ cur.recordUndo();
Font font;
bool b;
- bv_funcs::string2font(to_utf8(arg), font, b);
- if (font.color() != Color::inherit) {
- MathAtom at = MathAtom(new InsetMathColor(true, font.color()));
+ font.fromString(to_utf8(arg), b);
+ if (font.fontInfo().color() != Color_inherit) {
+ MathAtom at = MathAtom(new InsetMathColor(true, font.fontInfo().color()));
cur.handleNest(at, 0);
}
}
-void InsetMathHull::edit(Cursor & cur, bool left)
+void InsetMathHull::edit(Cursor & cur, bool front, EntryDirection entry_from)
{
cur.push(*this);
- left ? idxFirst(cur) : idxLast(cur);
+ bool enter_front = (entry_from == Inset::ENTRY_DIRECTION_LEFT ||
+ (entry_from == Inset::ENTRY_DIRECTION_IGNORE && front));
+ enter_front ? idxFirst(cur) : idxLast(cur);
// The inset formula dimension is not necessarily the same as the
// one of the instant preview image, so we have to indicate to the
- // BufferView that a metrics update is needed.
+ // BufferView that a metrics update is needed.
cur.updateFlags(Update::Force);
}
-docstring const InsetMathHull::editMessage() const
+docstring InsetMathHull::editMessage() const
{
return _("Math editor mode");
}
}
-Inset::Code InsetMathHull::lyxCode() const
+InsetCode InsetMathHull::lyxCode() const
{
return MATH_CODE;
}
bool InsetMathHull::searchForward(BufferView * bv, string const & str,
bool, bool)
{
-#ifdef WITH_WARNINGS
-#warning completely broken
-#endif
+ // FIXME: completely broken
static InsetMathHull * lastformula = 0;
static CursorBase current = DocIterator(ibegin(nucleus()));
static MathData ar;
#endif
-void InsetMathHull::write(Buffer const &, std::ostream & os) const
+void InsetMathHull::write(ostream & os) const
{
odocstringstream oss;
WriteStream wi(oss, false, false);
}
-void InsetMathHull::read(Buffer const &, Lexer & lex)
+void InsetMathHull::read(Lexer & lex)
{
MathAtom at;
mathed_parse_normal(at, lex);
}
-int InsetMathHull::plaintext(Buffer const &, odocstream & os,
- OutputParams const &) const
+int InsetMathHull::plaintext(odocstream & os, OutputParams const &) const
{
if (0 && display()) {
Dimension dim;
}
-int InsetMathHull::docbook(Buffer const & buf, odocstream & os,
- OutputParams const & runparams) const
+int InsetMathHull::docbook(odocstream & os, OutputParams const & runparams) const
{
MathStream ms(os);
int res = 0;
docstring bname = name;
if (!label(0).empty())
- bname += " id='" + sgml::cleanID(buf, runparams, label(0)) + "'";
- ms << MTag(bname);
+ bname += " id='" + sgml::cleanID(buffer(), runparams, label(0)) + "'";
+
+ ++ms.tab(); ms.cr(); ms.os() << '<' << bname << '>';
odocstringstream ls;
if (runparams.flavor == OutputParams::XML) {
- ms << MTag(from_ascii("alt role='tex' "));
+ ms << MTag("alt role='tex' ");
// Workaround for db2latex: db2latex always includes equations with
// \ensuremath{} or \begin{display}\end{display}
// so we strip LyX' math environment
WriteStream wi(ls, false, false);
InsetMathGrid::write(wi);
ms << from_utf8(subst(subst(to_utf8(ls.str()), "&", "&"), "<", "<"));
- ms << ETag(from_ascii("alt"));
- ms << MTag(from_ascii("math"));
- ms << ETag(from_ascii("alt"));
- ms << MTag(from_ascii("math"));
+ ms << ETag("alt");
+ ms << MTag("math");
+ ms << ETag("alt");
+ ms << MTag("math");
InsetMathGrid::mathmlize(ms);
- ms << ETag(from_ascii("math"));
+ ms << ETag("math");
} else {
- ms << MTag(from_ascii("alt role='tex'"));
- res = latex(buf, ls, runparams);
+ ms << MTag("alt role='tex'");
+ res = latex(ls, runparams);
ms << from_utf8(subst(subst(to_utf8(ls.str()), "&", "&"), "<", "<"));
- ms << ETag(from_ascii("alt"));
+ ms << ETag("alt");
}
ms << from_ascii("<graphic fileref=\"eqn/");
if (!label(0).empty())
- ms << sgml::cleanID(buf, runparams, label(0));
+ ms << sgml::cleanID(buffer(), runparams, label(0));
else
ms << sgml::uniqueID(from_ascii("anon"));
else
ms << from_ascii("\">");
- ms << ETag(name);
+ ms.cr(); --ms.tab(); ms.os() << "</" << name << '>';
+
return ms.line() + res;
}
-void InsetMathHull::textString(Buffer const & buf, odocstream & os) const
+void InsetMathHull::textString(odocstream & os) const
+{
+ plaintext(os, OutputParams(0));
+}
+
+
+docstring InsetMathHull::contextMenu(BufferView const &, int, int) const
{
- plaintext(buf, os, OutputParams(0));
+ return from_ascii("context-math");
}