mirror of
https://git.lyx.org/repos/lyx.git
synced 2025-01-25 01:26:51 +00:00
Skip drawing of markers in non-editable math data
There is no reason to reserve pixel space in macros replacement text, which is not editable. This makes macros more compact and eases the writing of lib/symbols. * introduce new InsetMath::drawMarkers and friends that do nothing when nested inside a macro. This required to move macro_nesting inside MetricsBase, and to pass MetricsInfo & to metricsMarkers. * keep track of nesting when drawing rows or macros.
This commit is contained in:
parent
f3f9b083d1
commit
9a9a6a8c8f
@ -38,8 +38,8 @@ namespace lyx {
|
|||||||
|
|
||||||
MetricsBase::MetricsBase(BufferView * b, FontInfo f, int w)
|
MetricsBase::MetricsBase(BufferView * b, FontInfo f, int w)
|
||||||
: bv(b), font(move(f)), style(LM_ST_TEXT), fontname("mathnormal"),
|
: bv(b), font(move(f)), style(LM_ST_TEXT), fontname("mathnormal"),
|
||||||
textwidth(w), solid_line_thickness_(1), solid_line_offset_(1),
|
textwidth(w), macro_nesting(0),
|
||||||
dotted_line_thickness_(1)
|
solid_line_thickness_(1), solid_line_offset_(1), dotted_line_thickness_(1)
|
||||||
{
|
{
|
||||||
if (lyxrc.zoom >= 200) {
|
if (lyxrc.zoom >= 200) {
|
||||||
// derive the line thickness from zoom factor
|
// derive the line thickness from zoom factor
|
||||||
@ -88,7 +88,7 @@ Changer MetricsBase::changeFontSet(string const & name, bool cond)
|
|||||||
|
|
||||||
MetricsInfo::MetricsInfo(BufferView * bv, FontInfo font, int textwidth,
|
MetricsInfo::MetricsInfo(BufferView * bv, FontInfo font, int textwidth,
|
||||||
MacroContext const & mc)
|
MacroContext const & mc)
|
||||||
: base(bv, font, textwidth), macro_nesting(0), macrocontext(mc)
|
: base(bv, font, textwidth), macrocontext(mc)
|
||||||
{}
|
{}
|
||||||
|
|
||||||
|
|
||||||
|
@ -65,6 +65,8 @@ public:
|
|||||||
std::string fontname;
|
std::string fontname;
|
||||||
/// This is the width available in pixels
|
/// This is the width available in pixels
|
||||||
int textwidth;
|
int textwidth;
|
||||||
|
/// count wether the current mathdata is nested in macro(s)
|
||||||
|
int macro_nesting;
|
||||||
|
|
||||||
/// Temporarily change a full font.
|
/// Temporarily change a full font.
|
||||||
Changer changeFontSet(std::string const & font, bool cond = true);
|
Changer changeFontSet(std::string const & font, bool cond = true);
|
||||||
@ -101,8 +103,6 @@ public:
|
|||||||
|
|
||||||
///
|
///
|
||||||
MetricsBase base;
|
MetricsBase base;
|
||||||
/// count wether the current mathdata is nested in macro(s)
|
|
||||||
int macro_nesting;
|
|
||||||
/// The context to resolve macros
|
/// The context to resolve macros
|
||||||
MacroContext const & macrocontext;
|
MacroContext const & macrocontext;
|
||||||
};
|
};
|
||||||
|
@ -16,13 +16,15 @@
|
|||||||
#include "MathRow.h"
|
#include "MathRow.h"
|
||||||
#include "MathStream.h"
|
#include "MathStream.h"
|
||||||
|
|
||||||
|
#include "MetricsInfo.h"
|
||||||
|
|
||||||
#include "support/debug.h"
|
#include "support/debug.h"
|
||||||
#include "support/docstream.h"
|
#include "support/docstream.h"
|
||||||
#include "support/gettext.h"
|
#include "support/gettext.h"
|
||||||
|
#include "support/lassert.h"
|
||||||
#include "support/lstrings.h"
|
#include "support/lstrings.h"
|
||||||
#include "support/textutils.h"
|
#include "support/textutils.h"
|
||||||
|
|
||||||
#include "support/lassert.h"
|
|
||||||
|
|
||||||
using namespace std;
|
using namespace std;
|
||||||
|
|
||||||
@ -65,6 +67,36 @@ bool InsetMath::addToMathRow(MathRow & mrow, MetricsInfo & mi) const
|
|||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void InsetMath::metricsMarkers(MetricsInfo & mi, Dimension & dim,
|
||||||
|
int framesize) const
|
||||||
|
{
|
||||||
|
if (!mi.base.macro_nesting)
|
||||||
|
Inset::metricsMarkers(dim, framesize);
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
void InsetMath::metricsMarkers2(MetricsInfo & mi, Dimension & dim,
|
||||||
|
int framesize) const
|
||||||
|
{
|
||||||
|
if (!mi.base.macro_nesting)
|
||||||
|
Inset::metricsMarkers2(dim, framesize);
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
void InsetMath::drawMarkers(PainterInfo & pi, int x, int y) const
|
||||||
|
{
|
||||||
|
if (!pi.base.macro_nesting)
|
||||||
|
Inset::drawMarkers(pi, x, y);
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
void InsetMath::drawMarkers2(PainterInfo & pi, int x, int y) const
|
||||||
|
{
|
||||||
|
if (!pi.base.macro_nesting)
|
||||||
|
Inset::drawMarkers2(pi, x, y);
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
void InsetMath::dump() const
|
void InsetMath::dump() const
|
||||||
{
|
{
|
||||||
|
@ -169,6 +169,15 @@ public:
|
|||||||
/// Add this inset to a math row. Return true if contents got added
|
/// Add this inset to a math row. Return true if contents got added
|
||||||
virtual bool addToMathRow(MathRow &, MetricsInfo & mi) const;
|
virtual bool addToMathRow(MathRow &, MetricsInfo & mi) const;
|
||||||
|
|
||||||
|
/// draw four angular markers
|
||||||
|
void drawMarkers(PainterInfo & pi, int x, int y) const;
|
||||||
|
/// draw two angular markers
|
||||||
|
void drawMarkers2(PainterInfo & pi, int x, int y) const;
|
||||||
|
/// add space for markers
|
||||||
|
void metricsMarkers(MetricsInfo & mi, Dimension & dim, int framesize = 1) const;
|
||||||
|
/// add space for markers
|
||||||
|
void metricsMarkers2(MetricsInfo & mi, Dimension & dim, int framesize = 1) const;
|
||||||
|
|
||||||
/// identifies things that can get scripts
|
/// identifies things that can get scripts
|
||||||
virtual bool isScriptable() const { return false; }
|
virtual bool isScriptable() const { return false; }
|
||||||
/// will this get written as a single block in {..}
|
/// will this get written as a single block in {..}
|
||||||
|
@ -51,7 +51,7 @@ void InsetMathBoldSymbol::metrics(MetricsInfo & mi, Dimension & dim) const
|
|||||||
{
|
{
|
||||||
//Changer dummy = mi.base.changeFontSet("mathbf");
|
//Changer dummy = mi.base.changeFontSet("mathbf");
|
||||||
cell(0).metrics(mi, dim);
|
cell(0).metrics(mi, dim);
|
||||||
metricsMarkers(dim);
|
metricsMarkers(mi, dim);
|
||||||
++dim.wid; // for 'double stroke'
|
++dim.wid; // for 'double stroke'
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -83,7 +83,7 @@ void InsetMathBox::metrics(MetricsInfo & mi, Dimension & dim) const
|
|||||||
{
|
{
|
||||||
Changer dummy = mi.base.changeFontSet("textnormal");
|
Changer dummy = mi.base.changeFontSet("textnormal");
|
||||||
cell(0).metrics(mi, dim);
|
cell(0).metrics(mi, dim);
|
||||||
metricsMarkers(dim);
|
metricsMarkers(mi, dim);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
@ -135,7 +135,7 @@ void InsetMathFBox::metrics(MetricsInfo & mi, Dimension & dim) const
|
|||||||
{
|
{
|
||||||
Changer dummy = mi.base.changeFontSet("textnormal");
|
Changer dummy = mi.base.changeFontSet("textnormal");
|
||||||
cell(0).metrics(mi, dim);
|
cell(0).metrics(mi, dim);
|
||||||
metricsMarkers2(dim, 3); // 1 pixel space, 1 frame, 1 space
|
metricsMarkers2(mi, dim, 3); // 1 pixel space, 1 frame, 1 space
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
@ -246,7 +246,7 @@ void InsetMathMakebox::metrics(MetricsInfo & mi, Dimension & dim) const
|
|||||||
dim.des += 1;
|
dim.des += 1;
|
||||||
}
|
}
|
||||||
|
|
||||||
metricsMarkers(dim);
|
metricsMarkers(mi, dim);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
@ -360,7 +360,7 @@ InsetMathBoxed::InsetMathBoxed(Buffer * buf)
|
|||||||
void InsetMathBoxed::metrics(MetricsInfo & mi, Dimension & dim) const
|
void InsetMathBoxed::metrics(MetricsInfo & mi, Dimension & dim) const
|
||||||
{
|
{
|
||||||
cell(0).metrics(mi, dim);
|
cell(0).metrics(mi, dim);
|
||||||
metricsMarkers2(dim, 3); // 1 pixel space, 1 frame, 1 space
|
metricsMarkers2(mi, dim, 3); // 1 pixel space, 1 frame, 1 space
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
@ -55,7 +55,7 @@ void InsetMathBrace::metrics(MetricsInfo & mi, Dimension & dim) const
|
|||||||
dim.asc = max(dim0.asc, t.asc);
|
dim.asc = max(dim0.asc, t.asc);
|
||||||
dim.des = max(dim0.des, t.des);
|
dim.des = max(dim0.des, t.des);
|
||||||
dim.wid = dim0.width() + 2 * t.wid;
|
dim.wid = dim0.width() + 2 * t.wid;
|
||||||
metricsMarkers(dim);
|
metricsMarkers(mi, dim);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
@ -38,7 +38,7 @@ Inset * InsetMathCancel::clone() const
|
|||||||
void InsetMathCancel::metrics(MetricsInfo & mi, Dimension & dim) const
|
void InsetMathCancel::metrics(MetricsInfo & mi, Dimension & dim) const
|
||||||
{
|
{
|
||||||
cell(0).metrics(mi, dim);
|
cell(0).metrics(mi, dim);
|
||||||
metricsMarkers(dim);
|
metricsMarkers(mi, dim);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
@ -47,7 +47,7 @@ void InsetMathCancelto::metrics(MetricsInfo & mi, Dimension & dim) const
|
|||||||
dim.asc = max(dim0.ascent() + 2, dim0.ascent() + dim1.ascent()) + 2 + 8;
|
dim.asc = max(dim0.ascent() + 2, dim0.ascent() + dim1.ascent()) + 2 + 8;
|
||||||
dim.des = max(dim0.descent() - 2, dim1.descent()) + 2;
|
dim.des = max(dim0.descent() - 2, dim1.descent()) + 2;
|
||||||
dim.wid = dim0.width() + dim1.width() + 10;
|
dim.wid = dim0.width() + dim1.width() + 10;
|
||||||
metricsMarkers(dim);
|
metricsMarkers(mi, dim);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
@ -31,7 +31,7 @@ Inset * InsetMathClass::clone() const
|
|||||||
void InsetMathClass::metrics(MetricsInfo & mi, Dimension & dim) const
|
void InsetMathClass::metrics(MetricsInfo & mi, Dimension & dim) const
|
||||||
{
|
{
|
||||||
cell(0).metrics(mi, dim);
|
cell(0).metrics(mi, dim);
|
||||||
metricsMarkers(dim);
|
metricsMarkers(mi, dim);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
@ -49,7 +49,7 @@ Inset * InsetMathColor::clone() const
|
|||||||
void InsetMathColor::metrics(MetricsInfo & mi, Dimension & dim) const
|
void InsetMathColor::metrics(MetricsInfo & mi, Dimension & dim) const
|
||||||
{
|
{
|
||||||
cell(0).metrics(mi, dim);
|
cell(0).metrics(mi, dim);
|
||||||
metricsMarkers(dim);
|
metricsMarkers(mi, dim);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
@ -50,7 +50,7 @@ Inset * InsetMathComment::clone() const
|
|||||||
void InsetMathComment::metrics(MetricsInfo & mi, Dimension & dim) const
|
void InsetMathComment::metrics(MetricsInfo & mi, Dimension & dim) const
|
||||||
{
|
{
|
||||||
cell(0).metrics(mi, dim);
|
cell(0).metrics(mi, dim);
|
||||||
metricsMarkers(dim);
|
metricsMarkers(mi, dim);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
@ -122,7 +122,7 @@ void InsetMathDecoration::metrics(MetricsInfo & mi, Dimension & dim) const
|
|||||||
dim.des += dh_ + 2;
|
dim.des += dh_ + 2;
|
||||||
}
|
}
|
||||||
|
|
||||||
metricsMarkers(dim);
|
metricsMarkers(mi, dim);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
@ -41,7 +41,7 @@ void InsetMathEnsureMath::metrics(MetricsInfo & mi, Dimension & dim) const
|
|||||||
bool really_change_font = isTextFont(mi.base.fontname);
|
bool really_change_font = isTextFont(mi.base.fontname);
|
||||||
Changer dummy = mi.base.changeFontSet("mathnormal", really_change_font);
|
Changer dummy = mi.base.changeFontSet("mathnormal", really_change_font);
|
||||||
cell(0).metrics(mi, dim);
|
cell(0).metrics(mi, dim);
|
||||||
metricsMarkers(dim);
|
metricsMarkers(mi, dim);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
@ -39,7 +39,7 @@ Inset * InsetMathEnv::clone() const
|
|||||||
void InsetMathEnv::metrics(MetricsInfo & mi, Dimension & dim) const
|
void InsetMathEnv::metrics(MetricsInfo & mi, Dimension & dim) const
|
||||||
{
|
{
|
||||||
cell(0).metrics(mi, dim);
|
cell(0).metrics(mi, dim);
|
||||||
metricsMarkers(dim);
|
metricsMarkers(mi, dim);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
@ -86,7 +86,7 @@ void InsetMathFont::metrics(MetricsInfo & mi, Dimension & dim) const
|
|||||||
{
|
{
|
||||||
Changer dummy = mi.base.changeFontSet(font());
|
Changer dummy = mi.base.changeFontSet(font());
|
||||||
cell(0).metrics(mi, dim);
|
cell(0).metrics(mi, dim);
|
||||||
metricsMarkers(dim);
|
metricsMarkers(mi, dim);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
@ -61,7 +61,7 @@ void InsetMathFontOld::metrics(MetricsInfo & mi, Dimension & dim) const
|
|||||||
|
|
||||||
Changer dummy = mi.base.changeFontSet(fontname, really_change_font);
|
Changer dummy = mi.base.changeFontSet(fontname, really_change_font);
|
||||||
cell(0).metrics(mi, dim);
|
cell(0).metrics(mi, dim);
|
||||||
metricsMarkers(dim);
|
metricsMarkers(mi, dim);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
@ -207,7 +207,7 @@ void InsetMathFrac::metrics(MetricsInfo & mi, Dimension & dim) const
|
|||||||
dim.des = dim1.height() + 2 - 5;
|
dim.des = dim1.height() + 2 - 5;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
metricsMarkers(dim);
|
metricsMarkers(mi, dim);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
@ -582,7 +582,7 @@ void InsetMathBinom::metrics(MetricsInfo & mi, Dimension & dim) const
|
|||||||
dim.asc = dim0.height() + 4 + 5;
|
dim.asc = dim0.height() + 4 + 5;
|
||||||
dim.des = dim1.height() + 4 - 5;
|
dim.des = dim1.height() + 4 - 5;
|
||||||
dim.wid = max(dim0.wid, dim1.wid) + 2 * dw(dim.height()) + 4;
|
dim.wid = max(dim0.wid, dim1.wid) + 2 * dw(dim.height()) + 4;
|
||||||
metricsMarkers2(dim);
|
metricsMarkers2(mi, dim);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
@ -588,7 +588,7 @@ void InsetMathGrid::metrics(MetricsInfo & mi, Dimension & dim) const
|
|||||||
}
|
}
|
||||||
*/
|
*/
|
||||||
dim.wid += leftMargin() + rightMargin();
|
dim.wid += leftMargin() + rightMargin();
|
||||||
metricsMarkers2(dim);
|
metricsMarkers2(mi, dim);
|
||||||
// Cache the inset dimension.
|
// Cache the inset dimension.
|
||||||
setDimCache(mi, dim);
|
setDimCache(mi, dim);
|
||||||
}
|
}
|
||||||
|
@ -34,7 +34,7 @@ void InsetMathLefteqn::metrics(MetricsInfo & mi, Dimension & dim) const
|
|||||||
dim.asc += 2;
|
dim.asc += 2;
|
||||||
dim.des += 2;
|
dim.des += 2;
|
||||||
dim.wid = 4;
|
dim.wid = 4;
|
||||||
metricsMarkers(dim);
|
metricsMarkers(mi, dim);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
@ -39,7 +39,7 @@ void InsetMathOverset::metrics(MetricsInfo & mi, Dimension & dim) const
|
|||||||
dim.wid = max(dim0.width(), dim1.wid) + 4;
|
dim.wid = max(dim0.width(), dim1.wid) + 4;
|
||||||
dim.asc = dim1.asc + dim0.height() + 4;
|
dim.asc = dim1.asc + dim0.height() + 4;
|
||||||
dim.des = dim1.des;
|
dim.des = dim1.des;
|
||||||
metricsMarkers(dim);
|
metricsMarkers(mi, dim);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
@ -39,7 +39,7 @@ Inset * InsetMathPhantom::clone() const
|
|||||||
void InsetMathPhantom::metrics(MetricsInfo & mi, Dimension & dim) const
|
void InsetMathPhantom::metrics(MetricsInfo & mi, Dimension & dim) const
|
||||||
{
|
{
|
||||||
cell(0).metrics(mi, dim);
|
cell(0).metrics(mi, dim);
|
||||||
metricsMarkers(dim);
|
metricsMarkers(mi, dim);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
@ -47,7 +47,7 @@ void InsetMathRoot::metrics(MetricsInfo & mi, Dimension & dim) const
|
|||||||
dim.asc = max(dim0.ascent() + 5, dim1.ascent()) + 2;
|
dim.asc = max(dim0.ascent() + 5, dim1.ascent()) + 2;
|
||||||
dim.des = max(dim0.descent() - 5, dim1.descent()) + 2;
|
dim.des = max(dim0.descent() - 5, dim1.descent()) + 2;
|
||||||
dim.wid = dim0.width() + dim1.width() + 10;
|
dim.wid = dim0.width() + dim1.width() + 10;
|
||||||
metricsMarkers(dim);
|
metricsMarkers(mi, dim);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
@ -333,7 +333,7 @@ void InsetMathScript::metrics(MetricsInfo & mi, Dimension & dim) const
|
|||||||
dim.des = max(nd, des);
|
dim.des = max(nd, des);
|
||||||
} else
|
} else
|
||||||
dim.des = nd;
|
dim.des = nd;
|
||||||
metricsMarkers(dim);
|
metricsMarkers(mi, dim);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
@ -221,7 +221,7 @@ void InsetMathSideset::metrics(MetricsInfo & mi, Dimension & dim) const
|
|||||||
int nd = ndes(bv);
|
int nd = ndes(bv);
|
||||||
int des = dyb(bv) + max(dimbl.descent(), dimbr.descent());
|
int des = dyb(bv) + max(dimbl.descent(), dimbr.descent());
|
||||||
dim.des = max(nd, des);
|
dim.des = max(nd, des);
|
||||||
metricsMarkers(dim);
|
metricsMarkers(mi, dim);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
@ -45,7 +45,7 @@ void InsetMathSize::metrics(MetricsInfo & mi, Dimension & dim) const
|
|||||||
{
|
{
|
||||||
Changer dummy = mi.base.changeStyle(style_);
|
Changer dummy = mi.base.changeStyle(style_);
|
||||||
cell(0).metrics(mi, dim);
|
cell(0).metrics(mi, dim);
|
||||||
metricsMarkers(dim);
|
metricsMarkers(mi, dim);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
@ -41,7 +41,7 @@ void InsetMathSqrt::metrics(MetricsInfo & mi, Dimension & dim) const
|
|||||||
dim.asc += 4;
|
dim.asc += 4;
|
||||||
dim.des += 2;
|
dim.des += 2;
|
||||||
dim.wid += 12;
|
dim.wid += 12;
|
||||||
metricsMarkers(dim);
|
metricsMarkers(mi, dim);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
@ -77,7 +77,7 @@ void InsetMathStackrel::metrics(MetricsInfo & mi, Dimension & dim) const
|
|||||||
dim.asc = dim1.ascent() + dim0.height() + 4;
|
dim.asc = dim1.ascent() + dim0.height() + 4;
|
||||||
dim.des = dim1.descent();
|
dim.des = dim1.descent();
|
||||||
}
|
}
|
||||||
metricsMarkers(dim);
|
metricsMarkers(mi, dim);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
@ -40,7 +40,7 @@ void InsetMathUnderset::metrics(MetricsInfo & mi, Dimension & dim) const
|
|||||||
dim.wid = max(dim0.width(), dim1.width()) + 4;
|
dim.wid = max(dim0.width(), dim1.width()) + 4;
|
||||||
dim.asc = dim1.ascent();
|
dim.asc = dim1.ascent();
|
||||||
dim.des = dim1.descent() + dim0.height() + 4;
|
dim.des = dim1.descent() + dim0.height() + 4;
|
||||||
metricsMarkers(dim);
|
metricsMarkers(mi, dim);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
@ -51,7 +51,7 @@ void InsetMathXArrow::metrics(MetricsInfo & mi, Dimension & dim) const
|
|||||||
dim.wid = max(dim0.width(), dim1.width()) + 10;
|
dim.wid = max(dim0.width(), dim1.width()) + 10;
|
||||||
dim.asc = dim0.height() + 10;
|
dim.asc = dim0.height() + 10;
|
||||||
dim.des = dim1.height();
|
dim.des = dim1.height();
|
||||||
metricsMarkers(dim);
|
metricsMarkers(mi, dim);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
@ -71,9 +71,9 @@ public:
|
|||||||
bool addToMathRow(MathRow & mrow, MetricsInfo & mi) const
|
bool addToMathRow(MathRow & mrow, MetricsInfo & mi) const
|
||||||
{
|
{
|
||||||
// macro arguments are in macros
|
// macro arguments are in macros
|
||||||
LATTEST(mi.macro_nesting > 0);
|
LATTEST(mi.base.macro_nesting > 0);
|
||||||
if (mi.macro_nesting == 1)
|
if (mi.base.macro_nesting == 1)
|
||||||
mi.macro_nesting = 0;
|
mi.base.macro_nesting = 0;
|
||||||
|
|
||||||
MathRow::Element e_beg(MathRow::BEG_ARG, mi);
|
MathRow::Element e_beg(MathRow::BEG_ARG, mi);
|
||||||
e_beg.macro = mathMacro_;
|
e_beg.macro = mathMacro_;
|
||||||
@ -86,15 +86,15 @@ public:
|
|||||||
|
|
||||||
// if there was no contents, and the contents is editable,
|
// if there was no contents, and the contents is editable,
|
||||||
// then we insert a box instead.
|
// then we insert a box instead.
|
||||||
if (!has_contents && mi.macro_nesting == 0) {
|
if (!has_contents && mi.base.macro_nesting == 0) {
|
||||||
MathRow::Element e(MathRow::BOX, mi);
|
MathRow::Element e(MathRow::BOX, mi);
|
||||||
e.color = Color_mathline;
|
e.color = Color_mathline;
|
||||||
mrow.push_back(e);
|
mrow.push_back(e);
|
||||||
has_contents = true;
|
has_contents = true;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (mi.macro_nesting == 0)
|
if (mi.base.macro_nesting == 0)
|
||||||
mi.macro_nesting = 1;
|
mi.base.macro_nesting = 1;
|
||||||
|
|
||||||
MathRow::Element e_end(MathRow::END_ARG, mi);
|
MathRow::Element e_end(MathRow::END_ARG, mi);
|
||||||
e_end.macro = mathMacro_;
|
e_end.macro = mathMacro_;
|
||||||
@ -107,9 +107,9 @@ public:
|
|||||||
///
|
///
|
||||||
void metrics(MetricsInfo & mi, Dimension & dim) const {
|
void metrics(MetricsInfo & mi, Dimension & dim) const {
|
||||||
// macro arguments are in macros
|
// macro arguments are in macros
|
||||||
LATTEST(mi.macro_nesting > 0);
|
LATTEST(mi.base.macro_nesting > 0);
|
||||||
if (mi.macro_nesting == 1)
|
if (mi.base.macro_nesting == 1)
|
||||||
mi.macro_nesting = 0;
|
mi.base.macro_nesting = 0;
|
||||||
|
|
||||||
mathMacro_->macro()->unlock();
|
mathMacro_->macro()->unlock();
|
||||||
mathMacro_->cell(idx_).metrics(mi, dim);
|
mathMacro_->cell(idx_).metrics(mi, dim);
|
||||||
@ -119,8 +119,8 @@ public:
|
|||||||
def_.metrics(mi, dim);
|
def_.metrics(mi, dim);
|
||||||
|
|
||||||
mathMacro_->macro()->lock();
|
mathMacro_->macro()->lock();
|
||||||
if (mi.macro_nesting == 0)
|
if (mi.base.macro_nesting == 0)
|
||||||
mi.macro_nesting = 1;
|
mi.base.macro_nesting = 1;
|
||||||
}
|
}
|
||||||
// write(), normalize(), infoize() and infoize2() are not needed since
|
// write(), normalize(), infoize() and infoize2() are not needed since
|
||||||
// MathMacro uses the definition and not the expanded cells.
|
// MathMacro uses the definition and not the expanded cells.
|
||||||
@ -138,6 +138,10 @@ public:
|
|||||||
void octave(OctaveStream & os) const { os << mathMacro_->cell(idx_); }
|
void octave(OctaveStream & os) const { os << mathMacro_->cell(idx_); }
|
||||||
///
|
///
|
||||||
void draw(PainterInfo & pi, int x, int y) const {
|
void draw(PainterInfo & pi, int x, int y) const {
|
||||||
|
LATTEST(pi.base.macro_nesting > 0);
|
||||||
|
if (pi.base.macro_nesting == 1)
|
||||||
|
pi.base.macro_nesting = 0;
|
||||||
|
|
||||||
if (mathMacro_->editMetrics(pi.base.bv)) {
|
if (mathMacro_->editMetrics(pi.base.bv)) {
|
||||||
// The only way a ArgumentProxy can appear is in a cell of the
|
// The only way a ArgumentProxy can appear is in a cell of the
|
||||||
// MathMacro. Moreover the cells are only drawn in the DISPLAY_FOLDED
|
// MathMacro. Moreover the cells are only drawn in the DISPLAY_FOLDED
|
||||||
@ -155,6 +159,9 @@ public:
|
|||||||
def_.draw(pi, x, y);
|
def_.draw(pi, x, y);
|
||||||
} else
|
} else
|
||||||
mathMacro_->cell(idx_).draw(pi, x, y);
|
mathMacro_->cell(idx_).draw(pi, x, y);
|
||||||
|
|
||||||
|
if (pi.base.macro_nesting == 0)
|
||||||
|
pi.base.macro_nesting = 1;
|
||||||
}
|
}
|
||||||
///
|
///
|
||||||
size_t idx() const { return idx_; }
|
size_t idx() const { return idx_; }
|
||||||
@ -324,7 +331,7 @@ bool MathMacro::addToMathRow(MathRow & mrow, MetricsInfo & mi) const
|
|||||||
e_beg.macro = this;
|
e_beg.macro = this;
|
||||||
mrow.push_back(e_beg);
|
mrow.push_back(e_beg);
|
||||||
|
|
||||||
++mi.macro_nesting;
|
++mi.base.macro_nesting;
|
||||||
|
|
||||||
d->macro_->lock();
|
d->macro_->lock();
|
||||||
bool has_contents = d->expanded_.addToMathRow(mrow, mi);
|
bool has_contents = d->expanded_.addToMathRow(mrow, mi);
|
||||||
@ -332,14 +339,14 @@ bool MathMacro::addToMathRow(MathRow & mrow, MetricsInfo & mi) const
|
|||||||
|
|
||||||
// if there was no contents and the array is editable, then we
|
// if there was no contents and the array is editable, then we
|
||||||
// insert a grey box instead.
|
// insert a grey box instead.
|
||||||
if (!has_contents && mi.macro_nesting == 1) {
|
if (!has_contents && mi.base.macro_nesting == 1) {
|
||||||
MathRow::Element e(MathRow::BOX, mi);
|
MathRow::Element e(MathRow::BOX, mi);
|
||||||
e.color = Color_mathmacroblend;
|
e.color = Color_mathmacroblend;
|
||||||
mrow.push_back(e);
|
mrow.push_back(e);
|
||||||
has_contents = true;
|
has_contents = true;
|
||||||
}
|
}
|
||||||
|
|
||||||
--mi.macro_nesting;
|
--mi.base.macro_nesting;
|
||||||
|
|
||||||
MathRow::Element e_end(MathRow::END_MACRO, mi);
|
MathRow::Element e_end(MathRow::END_MACRO, mi);
|
||||||
e_end.macro = this;
|
e_end.macro = this;
|
||||||
@ -442,7 +449,7 @@ bool MathMacro::editMetrics(BufferView const * bv) const
|
|||||||
void MathMacro::metrics(MetricsInfo & mi, Dimension & dim) const
|
void MathMacro::metrics(MetricsInfo & mi, Dimension & dim) const
|
||||||
{
|
{
|
||||||
// the macro contents is not editable (except the arguments)
|
// the macro contents is not editable (except the arguments)
|
||||||
++mi.macro_nesting;
|
++mi.base.macro_nesting;
|
||||||
|
|
||||||
// set edit mode for which we will have calculated metrics. But only
|
// set edit mode for which we will have calculated metrics. But only
|
||||||
d->editing_[mi.base.bv] = editMode(mi.base.bv);
|
d->editing_[mi.base.bv] = editMode(mi.base.bv);
|
||||||
@ -457,7 +464,7 @@ void MathMacro::metrics(MetricsInfo & mi, Dimension & dim) const
|
|||||||
dim.wid += bsdim.width() + 1;
|
dim.wid += bsdim.width() + 1;
|
||||||
dim.asc = max(bsdim.ascent(), dim.ascent());
|
dim.asc = max(bsdim.ascent(), dim.ascent());
|
||||||
dim.des = max(bsdim.descent(), dim.descent());
|
dim.des = max(bsdim.descent(), dim.descent());
|
||||||
metricsMarkers(dim);
|
metricsMarkers(mi, dim);
|
||||||
} else if (lyxrc.macro_edit_style == LyXRC::MACRO_EDIT_LIST
|
} else if (lyxrc.macro_edit_style == LyXRC::MACRO_EDIT_LIST
|
||||||
&& d->editing_[mi.base.bv]) {
|
&& d->editing_[mi.base.bv]) {
|
||||||
// Macro will be edited in a old-style list mode here:
|
// Macro will be edited in a old-style list mode here:
|
||||||
@ -497,7 +504,7 @@ void MathMacro::metrics(MetricsInfo & mi, Dimension & dim) const
|
|||||||
dim.asc += 1;
|
dim.asc += 1;
|
||||||
dim.des += 1;
|
dim.des += 1;
|
||||||
dim.wid += 2;
|
dim.wid += 2;
|
||||||
metricsMarkers2(dim);
|
metricsMarkers2(mi, dim);
|
||||||
} else {
|
} else {
|
||||||
LBUFERR(d->macro_);
|
LBUFERR(d->macro_);
|
||||||
|
|
||||||
@ -534,7 +541,7 @@ void MathMacro::metrics(MetricsInfo & mi, Dimension & dim) const
|
|||||||
}
|
}
|
||||||
|
|
||||||
// restore macro nesting
|
// restore macro nesting
|
||||||
--mi.macro_nesting;
|
--mi.base.macro_nesting;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
@ -703,6 +710,9 @@ void MathMacro::draw(PainterInfo & pi, int x, int y) const
|
|||||||
dim.height() - 2, Color_mathmacroframe);
|
dim.height() - 2, Color_mathmacroframe);
|
||||||
drawMarkers2(pi, expx, expy);
|
drawMarkers2(pi, expx, expy);
|
||||||
} else {
|
} else {
|
||||||
|
// the macro contents is not editable (except the arguments)
|
||||||
|
++pi.base.macro_nesting;
|
||||||
|
|
||||||
bool drawBox = lyxrc.macro_edit_style == LyXRC::MACRO_EDIT_INLINE_BOX;
|
bool drawBox = lyxrc.macro_edit_style == LyXRC::MACRO_EDIT_INLINE_BOX;
|
||||||
bool upshape = currentMode() == TEXT_MODE;
|
bool upshape = currentMode() == TEXT_MODE;
|
||||||
Changer dummy = pi.base.font.changeShape(upshape ? UP_SHAPE
|
Changer dummy = pi.base.font.changeShape(upshape ? UP_SHAPE
|
||||||
@ -737,8 +747,11 @@ void MathMacro::draw(PainterInfo & pi, int x, int y) const
|
|||||||
} else
|
} else
|
||||||
d->expanded_.draw(pi, expx, expy);
|
d->expanded_.draw(pi, expx, expy);
|
||||||
|
|
||||||
|
--pi.base.macro_nesting;
|
||||||
|
|
||||||
if (!drawBox)
|
if (!drawBox)
|
||||||
drawMarkers(pi, x, y);
|
drawMarkers(pi, x, y);
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
// edit mode changed?
|
// edit mode changed?
|
||||||
|
@ -269,7 +269,7 @@ Inset * InsetMathWrapper::clone() const
|
|||||||
void InsetMathWrapper::metrics(MetricsInfo & mi, Dimension & dim) const
|
void InsetMathWrapper::metrics(MetricsInfo & mi, Dimension & dim) const
|
||||||
{
|
{
|
||||||
value_->metrics(mi, dim);
|
value_->metrics(mi, dim);
|
||||||
//metricsMarkers2(dim);
|
//metricsMarkers2(mi, dim);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
@ -37,7 +37,7 @@ namespace lyx {
|
|||||||
|
|
||||||
|
|
||||||
MathRow::Element::Element(Type t, MetricsInfo &mi)
|
MathRow::Element::Element(Type t, MetricsInfo &mi)
|
||||||
: type(t), macro_nesting(mi.macro_nesting),
|
: type(t), macro_nesting(mi.base.macro_nesting),
|
||||||
inset(0), mclass(MC_ORD), before(0), after(0), compl_unique_to(0),
|
inset(0), mclass(MC_ORD), before(0), after(0), compl_unique_to(0),
|
||||||
macro(0), color(Color_red)
|
macro(0), color(Color_red)
|
||||||
{}
|
{}
|
||||||
@ -130,7 +130,7 @@ void MathRow::metrics(MetricsInfo & mi, Dimension & dim) const
|
|||||||
CoordCache & coords = mi.base.bv->coordCache();
|
CoordCache & coords = mi.base.bv->coordCache();
|
||||||
for (Element const & e : elements_) {
|
for (Element const & e : elements_) {
|
||||||
Dimension d;
|
Dimension d;
|
||||||
mi.macro_nesting = e.macro_nesting;
|
mi.base.macro_nesting = e.macro_nesting;
|
||||||
switch (e.type) {
|
switch (e.type) {
|
||||||
case BEGIN:
|
case BEGIN:
|
||||||
case END:
|
case END:
|
||||||
@ -195,6 +195,7 @@ void MathRow::draw(PainterInfo & pi, int x, int const y) const
|
|||||||
{
|
{
|
||||||
CoordCache & coords = pi.base.bv->coordCache();
|
CoordCache & coords = pi.base.bv->coordCache();
|
||||||
for (Element const & e : elements_) {
|
for (Element const & e : elements_) {
|
||||||
|
pi.base.macro_nesting = e.macro_nesting;
|
||||||
switch (e.type) {
|
switch (e.type) {
|
||||||
case INSET: {
|
case INSET: {
|
||||||
// This is hackish: the math inset does not know that space
|
// This is hackish: the math inset does not know that space
|
||||||
|
Loading…
x
Reference in New Issue
Block a user