use_geometry = false;
use_amsmath = package_auto;
use_esint = package_auto;
- cite_engine = biblio::ENGINE_BASIC;
+ cite_engine_ = biblio::ENGINE_BASIC;
use_bibtopic = false;
trackChanges = false;
outputChanges = false;
// the layout file will be correctly loaded later.
if (!getLyXTextClass().isTeXClassAvailable()) {
docstring const msg =
- bformat(_("The document uses a missing "
- "TeX class \"%1$s\".\n"), from_utf8(classname));
+ bformat(_("The layout file requested by this document,\n"
+ "%1$s.layout,\n"
+ "is not usable. This is probably because a LaTeX\n"
+ "class or style file required by it is not\n"
+ "available. See the Customization documentation\n"
+ "for more information.\n"), from_utf8(classname));
Alert::warning(_("Document class not available"),
msg + _("LyX will not be able to produce output."));
}
} else if (token == "\\cite_engine") {
string engine;
lex >> engine;
- cite_engine = citeenginetranslator().find(engine);
+ cite_engine_ = citeenginetranslator().find(engine);
} else if (token == "\\use_bibtopic") {
lex >> use_bibtopic;
} else if (token == "\\tracking_changes") {
// the textclass
os << "\\textclass " << textclasslist[textclass].name() << '\n';
- // then the the preamble
+ // then the preamble
if (!preamble.empty()) {
// remove '\n' from the end of preamble
string const tmppreamble = rtrim(preamble, "\n");
<< "\n\\use_geometry " << convert<string>(use_geometry)
<< "\n\\use_amsmath " << use_amsmath
<< "\n\\use_esint " << use_esint
- << "\n\\cite_engine " << citeenginetranslator().find(cite_engine)
+ << "\n\\cite_engine " << citeenginetranslator().find(cite_engine_)
<< "\n\\use_bibtopic " << convert<string>(use_bibtopic)
<< "\n\\paperorientation " << string_orientation[orientation]
<< '\n';
// font selection must be done before loading fontenc.sty
string const fonts =
- loadFonts(features, fontsRoman, fontsSans,
+ loadFonts(fontsRoman, fontsSans,
fontsTypewriter, fontsSC, fontsOSF,
fontsSansScale, fontsTypewriterScale);
if (!fonts.empty()) {
os << "]{inputenc}\n";
texrow.newline();
}
- } else if (inputenc != "default" && inputenc != "tis620-0") {
+ } else if (inputenc != "default" && inputenc != "tis620-0" &&
+ inputenc != "ascii") {
os << "\\usepackage[" << from_ascii(inputenc)
<< "]{inputenc}\n";
texrow.newline();
}
}
if (!topmargin.empty())
- os << ",tmargin=" << from_ascii(topmargin);
+ os << ",tmargin=" << from_ascii(LyXLength(topmargin).asLatexString());
if (!bottommargin.empty())
- os << ",bmargin=" << from_ascii(bottommargin);
+ os << ",bmargin=" << from_ascii(LyXLength(bottommargin).asLatexString());
if (!leftmargin.empty())
- os << ",lmargin=" << from_ascii(leftmargin);
+ os << ",lmargin=" << from_ascii(LyXLength(leftmargin).asLatexString());
if (!rightmargin.empty())
- os << ",rmargin=" << from_ascii(rightmargin);
+ os << ",rmargin=" << from_ascii(LyXLength(rightmargin).asLatexString());
if (!headheight.empty())
- os << ",headheight=" << from_ascii(headheight);
+ os << ",headheight=" << from_ascii(LyXLength(headheight).asLatexString());
if (!headsep.empty())
- os << ",headsep=" << from_ascii(headsep);
+ os << ",headsep=" << from_ascii(LyXLength(headsep).asLatexString());
if (!footskip.empty())
- os << ",footskip=" << from_ascii(footskip);
+ os << ",footskip=" << from_ascii(LyXLength(footskip).asLatexString());
os << "}\n";
texrow.newline();
}
}
-string const BufferParams::loadFonts(LaTeXFeatures & features, string const & rm,
+string const BufferParams::loadFonts(string const & rm,
string const & sf, string const & tt,
bool const & sc, bool const & osf,
int const & sfscale, int const & ttscale) const
// Times
else if (rm == "times") {
// try to load the best available package
- if (features.isAvailable("mathptmx"))
+ if (LaTeXFeatures::isAvailable("mathptmx"))
os << "\\usepackage{mathptmx}\n";
- else if (features.isAvailable("mathptm"))
+ else if (LaTeXFeatures::isAvailable("mathptm"))
os << "\\usepackage{mathptm}\n";
else
os << "\\usepackage{times}\n";
// Palatino
else if (rm == "palatino") {
// try to load the best available package
- if (features.isAvailable("mathpazo")) {
+ if (LaTeXFeatures::isAvailable("mathpazo")) {
os << "\\usepackage";
if (osf || sc) {
os << '[';
}
os << "{mathpazo}\n";
}
- else if (features.isAvailable("mathpple"))
+ else if (LaTeXFeatures::isAvailable("mathpple"))
os << "\\usepackage{mathpple}\n";
else
os << "\\usepackage{palatino}\n";
else if (rm == "utopia") {
// fourier supersedes utopia.sty, but does
// not work with OT1 encoding.
- if (features.isAvailable("fourier")
+ if (LaTeXFeatures::isAvailable("fourier")
&& lyxrc.fontenc != "default") {
os << "\\usepackage";
if (osf || sc) {
return *(language->encoding());
}
+
+biblio::CiteEngine BufferParams::getEngine() const
+{
+ // FIXME the class should provide the numerical/
+ // authoryear choice
+ if (getLyXTextClass().provides("natbib")
+ && cite_engine_ != biblio::ENGINE_NATBIB_NUMERICAL)
+ return biblio::ENGINE_NATBIB_AUTHORYEAR;
+ return cite_engine_;
+}
+
+
+void BufferParams::setCiteEngine(biblio::CiteEngine const cite_engine)
+{
+ cite_engine_ = cite_engine;
+}
+
} // namespace lyx