mirror of
https://git.lyx.org/repos/lyx.git
synced 2025-01-21 23:09:40 +00:00
MathML: don't let the processor stretch operators when they are single characters for LyX.
The main goal is to match TeX' behaviour. If you want stretchy operators, use InsetMathDelim / \left & \right. This patch will change the output in many files, but making the rendering much closer to that of TeX (which users should expect, due to LyX' roots in TeX).
This commit is contained in:
parent
8f820d7ccb
commit
7e6597a5b4
@ -230,6 +230,8 @@ void InsetMathChar::octave(OctaveStream & os) const
|
||||
// mathalpha, then we'll treat it as an identifier, otherwise as an
|
||||
// operator.
|
||||
// Worst case: We get bad spacing, or bad italics.
|
||||
// In any case, never let MathML stretch a single character when it
|
||||
// is recognised as an operator, to match TeX' behaviour.
|
||||
void InsetMathChar::mathmlize(MathMLStream & ms) const
|
||||
{
|
||||
std::string entity;
|
||||
@ -253,7 +255,7 @@ void InsetMathChar::mathmlize(MathMLStream & ms) const
|
||||
}
|
||||
|
||||
if (!entity.empty()) {
|
||||
ms << MTagInline("mo")
|
||||
ms << MTagInline("mo", "stretchy='false'")
|
||||
<< from_ascii(entity)
|
||||
<< ETagInline("mo");
|
||||
return;
|
||||
@ -262,7 +264,7 @@ void InsetMathChar::mathmlize(MathMLStream & ms) const
|
||||
char const * type =
|
||||
(isAlphaASCII(char_) || Encodings::isMathAlpha(char_))
|
||||
? "mi" : "mo";
|
||||
ms << MTagInline(type)
|
||||
ms << MTagInline(type, std::string(type) == "mo" ? "stretchy='false'" : "")
|
||||
<< char_type(char_)
|
||||
<< ETagInline(type);
|
||||
}
|
||||
|
Loading…
x
Reference in New Issue
Block a user