]> git.lyx.org Git - lyx.git/blobdiff - src/mathed/InsetMathSymbol.cpp
* zh_TW.po: Update from Mingyi Wu
[lyx.git] / src / mathed / InsetMathSymbol.cpp
index 6cf3a29c224e759d28a863b4e38e7dbb6867683f..1999846729868998005b1f628e392481e63257d1 100644 (file)
@@ -23,6 +23,8 @@
 #include "support/docstream.h"
 #include "support/textutils.h"
 
+#include <boost/scoped_ptr.hpp>
+
 
 namespace lyx {
 
@@ -111,6 +113,12 @@ void InsetMathSymbol::draw(PainterInfo & pi, int x, int y) const
 }
 
 
+InsetMath::mode_type InsetMathSymbol::currentMode() const
+{
+       return sym_->extra == "textmode" ? TEXT_MODE : MATH_MODE;
+}
+
+
 bool InsetMathSymbol::isRelOp() const
 {
        return sym_->extra == "mathrel";
@@ -235,7 +243,9 @@ void InsetMathSymbol::octave(OctaveStream & os) const
 
 void InsetMathSymbol::write(WriteStream & os) const
 {
-       MathEnsurer ensurer(os);
+       boost::scoped_ptr<MathEnsurer> ensurer;
+       if (currentMode() != TEXT_MODE)
+               ensurer.reset(new MathEnsurer(os));
        os << '\\' << name();
 
        // $,#, etc. In theory the restriction based on catcodes, but then
@@ -260,13 +270,12 @@ void InsetMathSymbol::validate(LaTeXFeatures & features) const
        // validate in InsetMathExInt.
        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));