]> git.lyx.org Git - lyx.git/blobdiff - src/BufferParams.cpp
- moderncv.layout: add missing separator style
[lyx.git] / src / BufferParams.cpp
index 38f298c76fa4a0a0a04b2e918ca2fc9e46c30516..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;
 
@@ -361,12 +378,8 @@ BufferParams::BufferParams()
        papersize = PAPER_DEFAULT;
        orientation = ORIENTATION_PORTRAIT;
        use_geometry = false;
-       use_amsmath = package_auto;
-       use_esint = package_auto;
-       use_mhchem = package_auto;
-       use_mathdots = package_auto;
-       use_undertilde = package_auto;
        cite_engine_ = ENGINE_BASIC;
+       cite_engine_type_ = ENGINE_TYPE_NUMERICAL;
        biblio_style = "plain";
        use_bibtopic = false;
        use_indices = false;
@@ -432,6 +445,37 @@ docstring BufferParams::B_(string const & l10n) const
 }
 
 
+BufferParams::Package BufferParams::use_package(std::string const & p) const
+{
+       PackageMap::const_iterator it = use_packages.find(p);
+       if (it == use_packages.end())
+               return package_auto;
+       return it->second;
+}
+
+
+void BufferParams::use_package(std::string const & p, BufferParams::Package u)
+{
+       use_packages[p] = u;
+}
+
+
+vector<string> const & BufferParams::auto_packages()
+{
+       static vector<string> packages;
+       if (packages.empty()) {
+               // adding a package here implies a file format change!
+               packages.push_back("amsmath");
+               packages.push_back("esint");
+               packages.push_back("mathdots");
+               packages.push_back("mathtools");
+               packages.push_back("mhchem");
+               packages.push_back("undertilde");
+       }
+       return packages;
+}
+
+
 AuthorList & BufferParams::authors()
 {
        return pimpl_->authorlist;
@@ -675,30 +719,20 @@ string BufferParams::readToken(Lexer & lex, string const & token,
                papersize = papersizetranslator().find(ppsize);
        } else if (token == "\\use_geometry") {
                lex >> use_geometry;
-       } else if (token == "\\use_amsmath") {
-               int use_ams;
-               lex >> use_ams;
-               use_amsmath = packagetranslator().find(use_ams);
-       } else if (token == "\\use_esint") {
-               int useesint;
-               lex >> useesint;
-               use_esint = packagetranslator().find(useesint);
-       } else if (token == "\\use_mhchem") {
-               int usemhchem;
-               lex >> usemhchem;
-               use_mhchem = packagetranslator().find(usemhchem);
-       } else if (token == "\\use_mathdots") {
-               int usemathdots;
-               lex >> usemathdots;
-               use_mathdots = packagetranslator().find(usemathdots);
-       } else if (token == "\\use_undertilde") {
-               int useundertilde;
-               lex >> useundertilde;
-               use_undertilde = packagetranslator().find(useundertilde);
+       } else if (token == "\\use_package") {
+               string package;
+               int use;
+               lex >> package;
+               lex >> use;
+               use_package(package, packagetranslator().find(use));
        } else if (token == "\\cite_engine") {
                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();
@@ -998,13 +1032,13 @@ void BufferParams::writeFile(ostream & os) const
        pdfoptions().writeFile(os);
 
        os << "\\papersize " << string_papersize[papersize]
-          << "\n\\use_geometry " << convert<string>(use_geometry)
-          << "\n\\use_amsmath " << use_amsmath
-          << "\n\\use_esint " << use_esint
-          << "\n\\use_mhchem " << use_mhchem
-          << "\n\\use_mathdots " << use_mathdots
-          << "\n\\use_undertilde " << use_undertilde
-          << "\n\\cite_engine " << citeenginetranslator().find(cite_engine_)
+          << "\n\\use_geometry " << convert<string>(use_geometry);
+       vector<string> const & packages = auto_packages();
+       for (size_t i = 0; i < packages.size(); ++i)
+               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)
@@ -1168,18 +1202,16 @@ void BufferParams::validate(LaTeXFeatures & features) const
        if (float_placement.find('H') != string::npos)
                features.require("float");
 
-       // AMS Style is at document level
-       if (use_amsmath == package_on
-           || documentClass().provides("amsmath"))
-               features.require("amsmath");
-       if (use_esint == package_on)
-               features.require("esint");
-       if (use_mhchem == package_on)
-               features.require("mhchem");
-       if (use_mathdots == package_on)
-               features.require("mathdots");
-       if (use_undertilde == package_on)
-               features.require("undertilde");
+       for (PackageMap::const_iterator it = use_packages.begin();
+            it != use_packages.end(); ++it) {
+               if (it->first == "amsmath") {
+                       // AMS Style is at document level
+                       if (it->second == package_on ||
+                           documentClass().provides("amsmath"))
+                               features.require(it->first);
+               } else if (it->second == package_on)
+                       features.require(it->first);
+       }
 
        // Document-level line spacing
        if (spacing().getSpace() != Spacing::Single && !spacing().isDefault())
@@ -2517,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()
@@ -2905,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_;
 }