void InsetMathFont::validate(LaTeXFeatures & features) const
{
InsetMathNest::validate(features);
- // Make sure amssymb is put in preamble if Blackboard Bold or
- // Fraktur used:
- if (key_->name == "mathfrak" || key_->name == "mathbb")
- features.require("amssymb");
- if (key_->name == "text" || key_->name == "textnormal"
- || (key_->name.length() == 6 && key_->name.substr(0, 4) == "text"))
- features.require("amstext");
- if (key_->name == "textipa")
- features.require("tipa");
- if (key_->name == "ce" || key_->name == "cf")
- features.require("mhchem");
+ if (features.runparams().isLaTeX()) {
+ // Make sure amssymb is put in preamble if Blackboard Bold or
+ // Fraktur used:
+ if (key_->name == "mathfrak" || key_->name == "mathbb")
+ features.require("amssymb");
+ if (key_->name == "text" || key_->name == "textnormal"
+ || (key_->name.length() == 6 && key_->name.substr(0, 4) == "text"))
+ features.require("amstext");
+ if (key_->name == "mathscr")
+ features.require("mathrsfs");
+ if (key_->name == "textipa")
+ features.require("tipa");
+ if (key_->name == "ce" || key_->name == "cf")
+ features.require("mhchem");
+ } else if (features.runparams().math_flavor == OutputParams::MathAsHTML) {
+ features.addCSSSnippet(
+ "span.normal{font: normal normal normal inherit serif;}\n"
+ "span.fraktur{font: normal normal normal inherit cursive;}\n"
+ "span.bold{font: normal normal bold inherit serif;}\n"
+ "span.script{font: normal normal normal inherit cursive;}\n"
+ "span.italic{font: italic normal normal inherit serif;}\n"
+ "span.sans{font: normal normal normal inherit sans-serif;}\n"
+ "span.monospace{font: normal normal normal inherit monospace;}\n"
+ "span.noun{font: normal small-caps normal inherit normal;}");
+ }
+}
+
+
+// The fonts we want to support are listed in lib/symbols
+void InsetMathFont::htmlize(HtmlStream & os) const
+{
+ // FIXME These are not quite right, because they do not nest
+ // correctly. A proper fix would presumably involve tracking
+ // the fonts already in effect.
+ std::string variant;
+ docstring const & tag = key_->name;
+ if (tag == "mathnormal" || tag == "mathrm"
+ || tag == "text" || tag == "textnormal"
+ || tag == "textrm" || tag == "textup"
+ || tag == "textmd")
+ variant = "normal";
+ else if (tag == "frak" || tag == "mathfrak")
+ variant = "fraktur";
+ else if (tag == "mathbb" || tag == "mathbf"
+ || tag == "textbf")
+ variant = "bold";
+ else if (tag == "mathcal")
+ variant = "script";
+ else if (tag == "mathit" || tag == "textsl"
+ || tag == "emph" || tag == "textit")
+ variant = "italic";
+ else if (tag == "mathsf" || tag == "textsf")
+ variant = "sans";
+ else if (tag == "mathtt" || tag == "texttt")
+ variant = "monospace";
+ else if (tag == "textipa" || tag == "textsc" || tag == "noun")
+ variant = "noun";
+
+ docstring const beg = (tag.size() < 4) ? from_ascii("") : tag.substr(0, 4);
+ if (!variant.empty()) {
+ os << MTag("span", "class='" + variant + "'")
+ << cell(0)
+ << ETag("span");
+ } else
+ os << cell(0);
}
// correctly. A proper fix would presumably involve tracking
// the fonts already in effect.
std::string variant;
- if (key_->name == "mathnormal" || key_->name == "mathrm"
- || key_->name == "text" || key_->name == "textnormal"
- || key_->name == "textrm" || key_->name == "textup"
- || key_->name == "textmd")
+ docstring const & tag = key_->name;
+ if (tag == "mathnormal" || tag == "mathrm"
+ || tag == "text" || tag == "textnormal"
+ || tag == "textrm" || tag == "textup"
+ || tag == "textmd")
variant = "normal";
- else if (key_->name == "frak" || key_->name == "mathfrak")
+ else if (tag == "frak" || tag == "mathfrak")
variant = "fraktur";
- else if (key_->name == "mathbb" || key_->name == "mathbf"
- || key_->name == "textbf")
+ else if (tag == "mathbb" || tag == "mathbf"
+ || tag == "textbf")
variant = "bold";
- else if (key_->name == "mathcal")
- variant == "script";
- else if (key_->name == "mathit" || key_->name == "textsl"
- || key_->name == "emph")
+ else if (tag == "mathcal")
+ variant = "script";
+ else if (tag == "mathit" || tag == "textsl"
+ || tag == "emph" || tag == "textit")
variant = "italic";
- else if (key_->name == "mathsf" || key_->name == "textit"
- || key_->name == "textsf")
+ else if (tag == "mathsf" || tag == "textsf")
variant = "sans-serif";
- else if (key_->name == "mathtt" || key_->name == "texttt")
+ else if (tag == "mathtt" || tag == "texttt")
variant = "monospace";
// no support at present for textipa, textsc, noun
-
- // FIXME We need some kind of "mode tracker", so we can
- // just output verbatim text in some cases.
- if (!variant.empty())
- os << "<mstyle mathvariant='" << from_utf8(variant) << "'>"
- << cell(0) << "</mstyle>";
+
+ if (!variant.empty()) {
+ os << MTag("mstyle", "mathvariant='" + variant + "'")
+ << cell(0)
+ << ETag("mstyle");
+ } else
+ os << cell(0);
}