]> git.lyx.org Git - lyx.git/blobdiff - src/BufferParams.cpp
- moderncv.layout: add missing separator style
[lyx.git] / src / BufferParams.cpp
index 4cc875934bfeea8a4a51870f9800693c401021c3..d6415415be9e3760940f1da61379bae579219ddc 100644 (file)
@@ -265,8 +265,7 @@ typedef Translator<string, CiteEngine> CiteEngineTranslator;
 CiteEngineTranslator const init_citeenginetranslator()
 {
        CiteEngineTranslator translator("basic", ENGINE_BASIC);
-       translator.addPair("natbib_numerical", ENGINE_NATBIB_NUMERICAL);
-       translator.addPair("natbib_authoryear", ENGINE_NATBIB_AUTHORYEAR);
+       translator.addPair("natbib", ENGINE_NATBIB);
        translator.addPair("jurabib", ENGINE_JURABIB);
        return translator;
 }
@@ -279,6 +278,24 @@ CiteEngineTranslator const & citeenginetranslator()
 }
 
 
+typedef Translator<string, CiteEngineType> CiteEngineTypeTranslator;
+
+
+CiteEngineTypeTranslator const init_citeenginetypetranslator()
+{
+       CiteEngineTypeTranslator translator("authoryear", ENGINE_TYPE_AUTHORYEAR);
+       translator.addPair("numerical", ENGINE_TYPE_NUMERICAL);
+       return translator;
+}
+
+
+CiteEngineTypeTranslator const & citeenginetypetranslator()
+{
+       static CiteEngineTypeTranslator translator = init_citeenginetypetranslator();
+       return translator;
+}
+
+
 // Spacing
 typedef Translator<string, Spacing::Space> SpaceTranslator;
 
@@ -362,6 +379,7 @@ BufferParams::BufferParams()
        orientation = ORIENTATION_PORTRAIT;
        use_geometry = false;
        cite_engine_ = ENGINE_BASIC;
+       cite_engine_type_ = ENGINE_TYPE_NUMERICAL;
        biblio_style = "plain";
        use_bibtopic = false;
        use_indices = false;
@@ -450,6 +468,7 @@ vector<string> const & BufferParams::auto_packages()
                packages.push_back("amsmath");
                packages.push_back("esint");
                packages.push_back("mathdots");
+               packages.push_back("mathtools");
                packages.push_back("mhchem");
                packages.push_back("undertilde");
        }
@@ -710,6 +729,10 @@ string BufferParams::readToken(Lexer & lex, string const & token,
                string engine;
                lex >> engine;
                cite_engine_ = citeenginetranslator().find(engine);
+       } else if (token == "\\cite_engine_type") {
+               string engine_type;
+               lex >> engine_type;
+               cite_engine_type_ = citeenginetypetranslator().find(engine_type);
        } else if (token == "\\biblio_style") {
                lex.eatLine();
                biblio_style = lex.getString();
@@ -1015,6 +1038,7 @@ void BufferParams::writeFile(ostream & os) const
                os << "\n\\use_package " << packages[i] << ' '
                   << use_package(packages[i]);
        os << "\n\\cite_engine " << citeenginetranslator().find(cite_engine_)
+          << "\n\\cite_engine_type " << citeenginetypetranslator().find(cite_engine_type_)
           << "\n\\biblio_style " << biblio_style
           << "\n\\use_bibtopic " << convert<string>(use_bibtopic)
           << "\n\\use_indices " << convert<string>(use_indices)
@@ -2525,6 +2549,14 @@ string const BufferParams::dvips_options() const
 {
        string result;
 
+       // If the class loads the geometry package, we do not know which
+       // paper size is used, since we do not set it (bug 7013).
+       // Therefore we must not specify any argument here.
+       // dvips gets the correct paper size via DVI specials in this case
+       // (if the class uses the geometry package correctly).
+       if (documentClass().provides("geometry"))
+               return result;
+
        if (use_geometry
            && papersize == PAPER_CUSTOM
            && !lyxrc.print_paper_dimension_flag.empty()
@@ -2913,9 +2945,8 @@ CiteEngine BufferParams::citeEngine() const
 {
        // FIXME the class should provide the numerical/
        // authoryear choice
-       if (documentClass().provides("natbib")
-           && cite_engine_ != ENGINE_NATBIB_NUMERICAL)
-               return ENGINE_NATBIB_AUTHORYEAR;
+       if (documentClass().provides("natbib"))
+               return ENGINE_NATBIB;
        return cite_engine_;
 }