mirror of
https://git.lyx.org/repos/lyx.git
synced 2024-11-16 07:55:41 +00:00
b2b8733096
This requires to change many docstrings into std::strings. The logic behind that is that they represent a fixed set of math fonts, and therefore “string” means here “poor man's enum” rather than text (this is consistent with MetricsBase). Profiling of scrolling inside a document over macro-instensive areas: Before the patch: 44,1% BufferView::updateMetrics() -> 34,8% InsetMathHull::metrics() -> 9,8% FontSetChanger::FontSetChanger() 28,4% BufferView::draw() After the patch: 35,3% BufferView::updateMetrics() -> 27,2% InsetMathHull::metrics -> 0,4% FontSetChanger::FontSetChanger() 47,5% BufferView::draw() FontSetChanger::FontSetChanger() is made 41x less expensive (with reference BV::draw()) just by removing this conversion. The remaining 0,4% could be squished by replacing the strings with a proper enum, but this is premature. Of course, this only treats the symptoms: there is no good reason that this function is called 45500 times over the time of 40 repaints.
114 lines
2.5 KiB
C++
114 lines
2.5 KiB
C++
/**
|
|
* \file InsetMathEnsureMath.cpp
|
|
* This file is part of LyX, the document processor.
|
|
* Licence details can be found in the file COPYING.
|
|
*
|
|
* \author André Pönitz
|
|
* \author Enrico Forestieri
|
|
*
|
|
* Full author contact details are available in file CREDITS.
|
|
*/
|
|
|
|
#include <config.h>
|
|
|
|
#include "InsetMathEnsureMath.h"
|
|
|
|
#include "MathData.h"
|
|
#include "MathStream.h"
|
|
#include "MathSupport.h"
|
|
|
|
#include "LaTeXFeatures.h"
|
|
#include "MetricsInfo.h"
|
|
|
|
#include <ostream>
|
|
|
|
|
|
namespace lyx {
|
|
|
|
InsetMathEnsureMath::InsetMathEnsureMath(Buffer * buf)
|
|
: InsetMathNest(buf, 1)
|
|
{}
|
|
|
|
|
|
Inset * InsetMathEnsureMath::clone() const
|
|
{
|
|
return new InsetMathEnsureMath(*this);
|
|
}
|
|
|
|
|
|
void InsetMathEnsureMath::metrics(MetricsInfo & mi, Dimension & dim) const
|
|
{
|
|
bool really_change_font = isTextFont(mi.base.fontname);
|
|
Changer dummy = mi.base.changeFontSet("mathnormal", really_change_font);
|
|
cell(0).metrics(mi, dim);
|
|
metricsMarkers(dim);
|
|
}
|
|
|
|
|
|
void InsetMathEnsureMath::draw(PainterInfo & pi, int x, int y) const
|
|
{
|
|
bool really_change_font = isTextFont(pi.base.fontname);
|
|
Changer dummy = pi.base.changeFontSet("mathnormal", really_change_font);
|
|
cell(0).draw(pi, x, y);
|
|
drawMarkers(pi, x, y);
|
|
}
|
|
|
|
|
|
void InsetMathEnsureMath::metricsT(TextMetricsInfo const & mi, Dimension & dim) const
|
|
{
|
|
cell(0).metricsT(mi, dim);
|
|
}
|
|
|
|
|
|
void InsetMathEnsureMath::drawT(TextPainter & pain, int x, int y) const
|
|
{
|
|
cell(0).drawT(pain, x, y);
|
|
}
|
|
|
|
|
|
void InsetMathEnsureMath::write(WriteStream & os) const
|
|
{
|
|
ModeSpecifier specifier(os, MATH_MODE);
|
|
os << "\\ensuremath{" << cell(0) << "}";
|
|
}
|
|
|
|
|
|
void InsetMathEnsureMath::mathmlize(MathStream & os) const
|
|
{
|
|
SetMode mathmode(os, false);
|
|
os << MTag("mstyle", "class='math'")
|
|
<< cell(0)
|
|
<< ETag("mstyle");
|
|
}
|
|
|
|
|
|
void InsetMathEnsureMath::htmlize(HtmlStream & os) const
|
|
{
|
|
SetHTMLMode mathmode(os, false);
|
|
os << MTag("span", "class='math'")
|
|
<< cell(0)
|
|
<< ETag("span");
|
|
}
|
|
|
|
|
|
void InsetMathEnsureMath::infoize(odocstream & os) const
|
|
{
|
|
os << "EnsureMath";
|
|
}
|
|
|
|
|
|
void InsetMathEnsureMath::validate(LaTeXFeatures & features) const
|
|
{
|
|
// FIXME XHTML
|
|
// It'd be better to be able to get this from an InsetLayout, but at present
|
|
// InsetLayouts do not seem really to work for things that aren't InsetTexts.
|
|
if (features.runparams().math_flavor == OutputParams::MathAsMathML)
|
|
features.addCSSSnippet("mstyle.math { font-style: italic; }");
|
|
else if (features.runparams().math_flavor == OutputParams::MathAsHTML)
|
|
features.addCSSSnippet("span.mathbox { font-style: italic; }");
|
|
|
|
InsetMathNest::validate(features);
|
|
}
|
|
|
|
} // namespace lyx
|