mirror of
https://git.lyx.org/repos/lyx.git
synced 2025-01-28 03:50:00 +00:00
740e89de17
simplifies it and hopefully does get it working. git-svn-id: svn://svn.lyx.org/lyx/lyx-devel/trunk@38195 a592a061-630c-0410-9148-cb99ea01b6c8
116 lines
2.6 KiB
C++
116 lines
2.6 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 "LaTeXFeatures.h"
|
|
#include "MathData.h"
|
|
#include "MathStream.h"
|
|
#include "MathSupport.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(from_ascii(mi.base.fontname));
|
|
FontSetChanger dummy(mi.base, "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(from_ascii(pi.base.fontname));
|
|
FontSetChanger dummy(pi.base, "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.addPreambleSnippet("<style type=\"text/css\">\n"
|
|
"mstyle.math { font-style: italic; }\n"
|
|
"</style>");
|
|
else if (features.runparams().math_flavor == OutputParams::MathAsHTML)
|
|
features.addPreambleSnippet("<style type=\"text/css\">\n"
|
|
"span.mathbox { font-style: italic; }\n"
|
|
"</style>");
|
|
|
|
InsetMathNest::validate(features);
|
|
}
|
|
|
|
} // namespace lyx
|