#include "math_colorinset.h"
#include "math_data.h"
#include "math_extern.h"
+#include "math_factory.h"
#include "math_hullinset.h"
#include "math_mathmlstream.h"
#include "math_streamstr.h"
//lyxerr << "sizeof MetricsInfo: " << sizeof(MetricsInfo) << endl;
//lyxerr << "sizeof MathCharInset: " << sizeof(MathCharInset) << endl;
//lyxerr << "sizeof LyXFont: " << sizeof(LyXFont) << endl;
+ initMath();
setDefaults();
}
: MathGridInset(getCols(type), 1), type_(type), nonum_(1), label_(1),
preview_(new RenderPreview(this))
{
+ initMath();
setDefaults();
}
InsetBase * MathHullInset::editXY(LCursor & cur, int x, int y)
{
- if (RenderPreview::status() == LyXRC::PREVIEW_ON) {
+ if (use_preview_) {
edit(cur, true);
return this;
}
char const * MathHullInset::standardFont() const
{
- if (type_ == "none")
- return "lyxnochange";
- return "mathnormal";
+ return type_ == "none" ? "lyxnochange" : "mathnormal";
}
-void MathHullInset::metrics(MetricsInfo & mi, Dimension & dim) const
+bool MathHullInset::previewState(BufferView * bv) const
{
- BOOST_ASSERT(mi.base.bv && mi.base.bv->buffer());
-
- bool use_preview = false;
- if (!editing(mi.base.bv) &&
- RenderPreview::status() == LyXRC::PREVIEW_ON) {
+ if (!editing(bv) && RenderPreview::status() == LyXRC::PREVIEW_ON) {
lyx::graphics::PreviewImage const * pimage =
- preview_->getPreviewImage(*mi.base.bv->buffer());
- use_preview = pimage && pimage->image();
+ preview_->getPreviewImage(*bv->buffer());
+ return pimage && pimage->image();
}
+ return false;
+}
- if (use_preview) {
+
+void MathHullInset::metrics(MetricsInfo & mi, Dimension & dim) const
+{
+ if (previewState(mi.base.bv)) {
preview_->metrics(mi, dim);
// insert a one pixel gap in front of the formula
dim.wid += 1;
void MathHullInset::draw(PainterInfo & pi, int x, int y) const
{
- BOOST_ASSERT(pi.base.bv && pi.base.bv->buffer());
-
- bool use_preview = false;
- if (!editing(pi.base.bv) &&
- RenderPreview::status() == LyXRC::PREVIEW_ON) {
- lyx::graphics::PreviewImage const * pimage =
- preview_->getPreviewImage(*pi.base.bv->buffer());
- use_preview = pimage && pimage->image();
- }
+ use_preview_ = previewState(pi.base.bv);
- if (use_preview) {
+ if (use_preview_) {
// one pixel gap in front
preview_->draw(pi, x + 1, y);
setPosCache(pi, x, y);
if (nrows() <= 1 || !rowChangeOK())
return;
MathGridInset::delRow(row);
+ // The last dummy row has no number info nor a label.
+ // Test nrows() + 1 because we have already erased the row.
+ if (row == nrows() + 1)
+ row--;
nonum_.erase(nonum_.begin() + row);
label_.erase(label_.begin() + row);
}
}
-string MathHullInset::eolString(row_type row, bool fragile) const
+string MathHullInset::eolString(row_type row, bool emptyline, bool fragile) const
{
string res;
if (numberedType()) {
if (nonum_[row] && (type_ != "multline"))
res += "\\nonumber ";
}
- return res + MathGridInset::eolString(row, fragile);
+ return res + MathGridInset::eolString(row, emptyline, fragile);
}
void MathHullInset::doDispatch(LCursor & cur, FuncRequest & cmd)
{
+ //lyxerr << "action: " << cmd.action << endl;
switch (cmd.action) {
case LFUN_FINISHED_LEFT:
case LFUN_FINISHED_RIGHT:
case LFUN_FINISHED_UP:
case LFUN_FINISHED_DOWN:
+ //lyxerr << "action: " << cmd.action << endl;
MathGridInset::doDispatch(cur, cmd);
notifyCursorLeaves(cur);
+ cur.undispatched();
break;
case LFUN_BREAKPARAGRAPH:
string old_label = label(r);
string const default_label =
(lyxrc.label_init_length >= 0) ? "eq:" : "";
+ if (old_label.empty())
+ old_label = default_label;
string const contents = cmd.argument.empty() ?
- label(r) : cmd.argument;
+ old_label : cmd.argument;
InsetCommandParams p("label", contents);
string const data = InsetCommandMailer::params2string("label", p);
//lyxerr << "arg: " << cmd.argument << endl;
string const name = cmd.getArg(0);
if (name == "label") {
- InsetCommandParams icp;
- InsetCommandMailer::string2params(name, cmd.argument, icp);
- string str = icp.getContents();
+ InsetCommandParams p;
+ InsetCommandMailer::string2params(name, cmd.argument, p);
+ string str = p.getContents();
recordUndoInset(cur);
row_type const r = (type_ == "multline") ? nrows() - 1 : cur.row();
str = lyx::support::trim(str);
if (!str.empty())
numbered(r, true);
- label(r, str);
+ string old = label(r);
+ if (str != old) {
+ cur.bv().buffer()->changeRefsIfUnique(old, str);
+ label(r, str);
+ }
+ break;
}
+ MathArray ar;
+ if (createMathInset_fromDialogStr(cmd.argument, ar)) {
+ recordUndo(cur);
+ cur.insert(ar);
+ } else
+ cur.undispatched();
break;
}
bool MathHullInset::getStatus(LCursor & cur, FuncRequest const & cmd,
- FuncStatus & flag) const
+ FuncStatus & status) const
{
switch (cmd.action) {
+ case LFUN_FINISHED_LEFT:
+ case LFUN_FINISHED_RIGHT:
+ case LFUN_FINISHED_UP:
+ case LFUN_FINISHED_DOWN:
+ status.enabled(true);
+ return true;
case LFUN_BREAKLINE:
case LFUN_MATH_NUMBER:
case LFUN_MATH_NONUMBER:
case LFUN_MATH_MUTATE:
case LFUN_MATH_DISPLAY:
// we handle these
- flag.enabled(true);
+ status.enabled(true);
return true;
case LFUN_INSERT_LABEL:
- flag.enabled(type_ != "simple");
+ status.enabled(type_ != "simple");
return true;
+ case LFUN_INSET_INSERT: {
+ // Don't test createMathInset_fromDialogStr(), since
+ // getStatus is not called with a valid reference and the
+ // dialog would not be applyable.
+ string const name = cmd.getArg(0);
+ status.enabled(name == "ref" ||
+ (name == "label" && type_ != "simple"));
+ break;
+ }
case LFUN_TABULAR_FEATURE: {
istringstream is(cmd.argument);
string s;
&& (s == "append-row"
|| s == "delete-row"
|| s == "copy-row")) {
- flag.message(bformat(
+ status.message(bformat(
N_("Can't change number of rows in '%1$s'"),
type_));
- flag.enabled(false);
+ status.enabled(false);
return true;
}
if (!colChangeOK()
&& (s == "append-column"
|| s == "delete-column"
|| s == "copy-column")) {
- flag.message(bformat(
+ status.message(bformat(
N_("Can't change number of columns in '%1$s'"),
type_));
- flag.enabled(false);
+ status.enabled(false);
return true;
}
if ((type_ == "simple"
|| type_ == "equation"
|| type_ == "none") &&
(s == "add-hline-above" || s == "add-hline-below")) {
- flag.message(bformat(
+ status.message(bformat(
N_("Can't add horizontal grid lines in '%1$s'"),
type_));
- flag.enabled(false);
+ status.enabled(false);
return true;
}
if (s == "add-vline-left" || s == "add-vline-right") {
- flag.message(bformat(
+ status.message(bformat(
N_("Can't add vertical grid lines in '%1$s'"),
type_));
- flag.enabled(false);
+ status.enabled(false);
return true;
}
if (s == "valign-top" || s == "valign-middle"
|| s == "valign-bottom" || s == "align-left"
|| s == "align-center" || s == "align-right") {
- flag.enabled(false);
+ status.enabled(false);
return true;
}
- return MathGridInset::getStatus(cur, cmd, flag);
+ return MathGridInset::getStatus(cur, cmd, status);
}
default:
- return MathGridInset::getStatus(cur, cmd, flag);
+ return MathGridInset::getStatus(cur, cmd, status);
}
+
+ // This cannot really happen, but inserted to shut-up gcc
+ return MathGridInset::getStatus(cur, cmd, status);
}
ms << "<graphic fileref=\"eqn/";
if ( !label(0).empty())
ms << sgml::cleanID(buf, runparams, label(0));
- else {
+ else
ms << sgml::uniqueID("anon");
- }
+
if (runparams.flavor == OutputParams::XML)
ms << "\"/>";
else
ms << ETag(name.c_str());
return ms.line() + res;
}
+
+
+int MathHullInset::textString(Buffer const & buf, ostream & os,
+ OutputParams const & op) const
+{
+ return plaintext(buf, os, op);
+}