void InsetMathBox::mathmlize(MathStream & ms) const
{
- SetMode textmode(ms, true);
+ SetMode textmode(ms, true, "class='mathbox'");
+ ms << cell(0);
+}
+
+
+void InsetMathBox::htmlize(HtmlStream & ms) const
+{
+ SetHTMLMode textmode(ms, true);
ms << cell(0);
}
{
if (name_ == "tag" || name_ == "tag*")
features.require("amsmath");
+
cell(0).validate(features);
}
}
+void InsetMathFBox::mathmlize(MathStream & ms) const
+{
+ SetMode textmode(ms, true, "class='fbox'");
+ ms << cell(0);
+}
+
+
+void InsetMathFBox::htmlize(HtmlStream & ms) const
+{
+ SetHTMLMode textmode(ms, true, "class='fbox'");
+ ms << cell(0);
+}
+
+
void InsetMathFBox::infoize(odocstream & os) const
{
os << "FBox: ";
}
+void InsetMathFBox::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"
+ "mtext.fbox { border: 1px solid black; }\n"
+ "</style>");
+ else if (features.runparams().math_flavor == OutputParams::MathAsHTML)
+ features.addPreambleSnippet("<style type=\"text/css\">\n"
+ "span.fbox { border: 1px solid black; }\n"
+ "</style>");
+ InsetMathNest::validate(features);
+}
+
+
+
/////////////////////////////////////////////////////////////////////
//
// InsetMathMakebox
}
+void InsetMathMakebox::mathmlize(MathStream & ms) const
+{
+ // FIXME We could do something with the other arguments.
+ std::string const cssclass = framebox_ ? "framebox" : "makebox";
+ SetMode textmode(ms, true, "class='" + cssclass + "'");
+ ms << cell(2);
+}
+
+
+void InsetMathMakebox::htmlize(HtmlStream & ms) const
+{
+ // FIXME We could do something with the other arguments.
+ std::string const cssclass = framebox_ ? "framebox" : "makebox";
+ SetHTMLMode textmode(ms, true, "class='" + cssclass + "'");
+ ms << cell(2);
+}
+
+
+void InsetMathMakebox::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"
+ "span.framebox { border: 1px solid black; }\n"
+ "</style>");
+ else if (features.runparams().math_flavor == OutputParams::MathAsHTML)
+ features.addPreambleSnippet("<style type=\"text/css\">\n"
+ "span.framebox { border: 1px solid black; }\n"
+ "</style>");
+ InsetMathNest::validate(features);
+}
+
+
/////////////////////////////////////////////////////////////////////
//
// InsetMathBoxed
}
+void InsetMathBoxed::mathmlize(MathStream & ms) const
+{
+ SetMode mathmode(ms, false, "class='boxed'");
+ ms << cell(0);
+}
+
+
+void InsetMathBoxed::htmlize(HtmlStream & ms) const
+{
+ SetHTMLMode mathmode(ms, false, "class='boxed'");
+ ms << cell(0);
+}
+
+
void InsetMathBoxed::validate(LaTeXFeatures & features) const
{
features.require("amsmath");
+
+ // 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.boxed { border: 1px solid black; }\n"
+ "</style>");
+ else if (features.runparams().math_flavor == OutputParams::MathAsHTML)
+ features.addPreambleSnippet("<style type=\"text/css\">\n"
+ "span.boxed { border: 1px solid black; }\n"
+ "</style>");
+
InsetMathNest::validate(features);
}