]> git.lyx.org Git - lyx.git/blobdiff - src/mathed/InsetMathSymbol.cpp
Add \makeat switches to babel settings if necessary.
[lyx.git] / src / mathed / InsetMathSymbol.cpp
index 5ca45a16fe0804ffbf8f4cc5c88d988b08c123cf..ed6c155784b6471fcc5fe69665fd50bda11dd467 100644 (file)
@@ -60,8 +60,12 @@ void InsetMathSymbol::metrics(MetricsInfo & mi, Dimension & dim) const
        //      << "' drawn as: '" << sym_->draw
        //      << "'" << endl;
 
+       bool const italic_upcase_greek = sym_->inset == "cmr" &&
+                                        sym_->extra == "mathalpha" &&
+                                        mi.base.fontname == "mathit";
+       docstring const font = italic_upcase_greek ? from_ascii("cmm") : sym_->inset;
        int const em = mathed_char_width(mi.base.font, 'M');
-       FontSetChanger dummy(mi.base, sym_->inset);
+       FontSetChanger dummy(mi.base, font);
        mathed_string_dim(mi.base.font, sym_->draw, dim);
        docstring::const_reverse_iterator rit = sym_->draw.rbegin();
        kerning_ = mathed_char_kerning(mi.base.font, *rit);
@@ -91,13 +95,18 @@ void InsetMathSymbol::draw(PainterInfo & pi, int x, int y) const
        //      << "' in font: '" << sym_->inset
        //      << "' drawn as: '" << sym_->draw
        //      << "'" << endl;
+
+       bool const italic_upcase_greek = sym_->inset == "cmr" &&
+                                        sym_->extra == "mathalpha" &&
+                                        pi.base.fontname == "mathit";
+       docstring const font = italic_upcase_greek ? from_ascii("cmm") : sym_->inset;
        int const em = mathed_char_width(pi.base.font, 'M');
        if (isRelOp())
                x += static_cast<int>(0.25*em+0.5);
        else
                x += static_cast<int>(0.0833*em+0.5);
 
-       FontSetChanger dummy(pi.base, sym_->inset.c_str());
+       FontSetChanger dummy(pi.base, font);
        pi.draw(x, y - h_, sym_->draw);
 }
 
@@ -249,15 +258,14 @@ void InsetMathSymbol::validate(LaTeXFeatures & features) const
 {
        // this is not really the ideal place to do this, but we can't
        // validate in InsetMathExInt.
-       if (features.runparams().flavor == OutputParams::HTML
+       if (features.runparams().math_flavor == OutputParams::MathAsHTML
            && sym_->name == from_ascii("int")) {
-               features.addPreambleSnippet("<style type=\"text/css\">\n"
+               features.addCSSSnippet(
                        "span.limits{display: inline-block; vertical-align: middle; text-align:center; font-size: 75%;}\n"
                        "span.limits span{display: block;}\n"
                        "span.intsym{font-size: 150%;}\n"
                        "sub.limit{font-size: 75%;}\n"
-                       "sup.limit{font-size: 75%;}\n"
-                       "</style>");
+                       "sup.limit{font-size: 75%;}");
        } else {
                if (!sym_->requires.empty())
                        features.require(to_utf8(sym_->requires));