#include "IndicesList.h"
#include "Language.h"
#include "LaTeXFeatures.h"
+#include "LaTeXFonts.h"
#include "ModuleList.h"
#include "Font.h"
#include "Lexer.h"
fonts_roman = "default";
fonts_sans = "default";
fonts_typewriter = "default";
+ fonts_math = "auto";
fonts_default_family = "default";
useNonTeXFonts = false;
fonts_expert_sc = false;
packages.push_back("mathdots");
packages.push_back("mathtools");
packages.push_back("mhchem");
+ packages.push_back("stackrel");
+ packages.push_back("stmaryrd");
packages.push_back("undertilde");
}
return packages;
} else if (token == "\\font_typewriter") {
lex.eatLine();
fonts_typewriter = lex.getString();
+ } else if (token == "\\font_math") {
+ lex.eatLine();
+ fonts_math = lex.getString();
} else if (token == "\\font_default_family") {
lex >> fonts_default_family;
} else if (token == "\\use_non_tex_fonts") {
lex.eatLine();
string color = lex.getString();
notefontcolor = lyx::rgbFromHexName(color);
+ lcolor.setColor("notefontcolor", color);
} else if (token == "\\boxbgcolor") {
lex.eatLine();
string color = lex.getString();
boxbgcolor = lyx::rgbFromHexName(color);
+ lcolor.setColor("boxbgcolor", color);
} else if (token == "\\paperwidth") {
lex >> paperwidth;
} else if (token == "\\paperheight") {
<< "\n\\font_roman " << fonts_roman
<< "\n\\font_sans " << fonts_sans
<< "\n\\font_typewriter " << fonts_typewriter
+ << "\n\\font_math " << fonts_math
<< "\n\\font_default_family " << fonts_default_family
<< "\n\\use_non_tex_fonts " << convert<string>(useNonTeXFonts)
<< "\n\\font_sc " << convert<string>(fonts_expert_sc)
if (!fonts_cjk.empty()) {
os << "\\font_cjk " << fonts_cjk << '\n';
}
- os << "\n\\graphics " << graphics_driver << '\n';
+ os << "\\graphics " << graphics_driver << '\n';
os << "\\default_output_format " << default_output_format << '\n';
os << "\\output_sync " << output_sync << '\n';
if (!output_sync_macro.empty())
{
features.require(documentClass().requires());
+ if (columns > 1 && language->rightToLeft())
+ features.require("rtloutputdblcol");
+
if (outputChanges) {
bool dvipost = LaTeXFeatures::isAvailable("dvipost");
bool xcolorulem = LaTeXFeatures::isAvailable("ulem") &&
if (it->first == "amsmath") {
// AMS Style is at document level
if (it->second == package_on ||
- documentClass().provides("amsmath"))
+ features.isProvided("amsmath"))
features.require(it->first);
} else if (it->second == package_on)
features.require(it->first);
features.require("color");
}
+ // some languages are only available via polyglossia
if (features.runparams().flavor == OutputParams::XETEX
- && useNonTeXFonts)
+ && (features.hasPolyglossiaExclusiveLanguages()
+ || useNonTeXFonts))
features.require("polyglossia");
- if (language->lang() == "vietnamese")
- features.require("vietnamese");
- else if (language->lang() == "japanese")
- features.require("japanese");
+ if (useNonTeXFonts && fonts_math != "auto")
+ features.require("unicode-math");
+
+ if (!language->requires().empty())
+ features.require(language->requires());
}
features.useLanguage(default_language);
ostringstream language_options;
- bool const use_babel = features.useBabel() && !tclass.provides("babel");
+ bool const use_babel = features.useBabel() && !features.isProvided("babel");
bool const use_polyglossia = features.usePolyglossia();
bool const global = lyxrc.language_global_options;
if (use_babel || (use_polyglossia && global)) {
- language_options << features.getLanguages();
+ language_options << features.getBabelLanguages();
if (!language->babel().empty()) {
if (!language_options.str().empty())
language_options << ',';
language_options << language->babel();
}
- if (global && !features.needBabelLangOptions())
+ if (global && !features.needBabelLangOptions()
+ && !language_options.str().empty())
clsoptions << language_options.str() << ',';
}
if (useNonTeXFonts && !ams.empty())
os << from_ascii(ams);
- if (useNonTeXFonts)
+ if (useNonTeXFonts) {
os << "\\usepackage{fontspec}\n";
+ if (features.mustProvide("unicode-math")
+ && features.isAvailable("unicode-math"))
+ os << "\\usepackage{unicode-math}\n";
+ }
// font selection must be done before loading fontenc.sty
- string const fonts =
- loadFonts(fonts_roman, fonts_sans, fonts_typewriter,
- fonts_expert_sc, fonts_old_figures,
- fonts_sans_scale, fonts_typewriter_scale,
- useNonTeXFonts, features);
+ string const fonts = loadFonts(features);
if (!fonts.empty())
os << from_utf8(fonts);
// LFE encoding
// XeTeX and LuaTeX (with OS fonts) work without fontenc
if (font_encoding() != "default" && language->lang() != "japanese"
- && !useNonTeXFonts && !tclass.provides("fontenc")) {
+ && !useNonTeXFonts && !features.isProvided("fontenc")) {
+ docstring extra_encoding;
+ if (features.mustProvide("textgreek"))
+ extra_encoding += from_ascii("LGR");
+ if (features.mustProvide("textcyr")) {
+ if (!extra_encoding.empty())
+ extra_encoding.push_back(',');
+ extra_encoding += from_ascii("T2A");
+ }
+ if (!extra_encoding.empty() && !font_encoding().empty())
+ extra_encoding.push_back(',');
size_t fars = language_options.str().find("farsi");
size_t arab = language_options.str().find("arabic");
if (language->lang() == "arabic_arabi"
|| language->lang() == "farsi" || fars != string::npos
|| arab != string::npos) {
- os << "\\usepackage[" << from_ascii(font_encoding())
+ os << "\\usepackage[" << extra_encoding
+ << from_ascii(font_encoding())
<< ",LFE,LAE]{fontenc}\n";
} else {
- os << "\\usepackage[" << from_ascii(font_encoding())
+ os << "\\usepackage[" << extra_encoding
+ << from_ascii(font_encoding())
<< "]{fontenc}\n";
}
}
os << from_utf8(par)
<< "}\n";
}
- if (!tclass.provides("geometry")
+ if (!features.isProvided("geometry")
&& (use_geometry || nonstandard_papersize)) {
odocstringstream ods;
if (!getGraphicsDriver("geometry").empty())
IndicesList::const_iterator iit = indiceslist().begin();
IndicesList::const_iterator iend = indiceslist().end();
for (; iit != iend; ++iit) {
+ pair<docstring, docstring> indexname_latex =
+ features.runparams().encoding->latexString(iit->index(),
+ features.runparams().dryrun);
+ if (!indexname_latex.second.empty()) {
+ // issue a warning about omitted characters
+ // FIXME: should be passed to the error dialog
+ frontend::Alert::warning(_("Uncodable characters"),
+ bformat(_("The following characters that are used in an index name are not\n"
+ "representable in the current encoding and therefore have been omitted:\n%1$s."),
+ indexname_latex.second));
+ }
lyxpreamble += "\\newindex[";
- lyxpreamble += iit->index();
+ lyxpreamble += indexname_latex.first;
lyxpreamble += "]{";
- lyxpreamble += iit->shortcut();
+ lyxpreamble += escape(iit->shortcut());
lyxpreamble += "}\n";
}
}
// Line spacing
- lyxpreamble += from_utf8(spacing().writePreamble(tclass.provides("SetSpace")));
+ lyxpreamble += from_utf8(spacing().writePreamble(features.isProvided("SetSpace")));
// PDF support.
// * Hyperref manual: "Make sure it comes last of your loaded
OutputParams tmp_params = features.runparams();
pdfoptions().writeLaTeX(tmp_params, os,
- documentClass().provides("hyperref"));
+ features.isProvided("hyperref"));
// set back for the rest
lyxpreamble.clear();
// correctly break URLs with hyperref and dvi output
}
}
+ // Load custom language package here
+ if (features.langPackage() == LaTeXFeatures::LANG_PACK_CUSTOM) {
+ if (lang_package == "default")
+ lyxpreamble += from_utf8(lyxrc.language_custom_package);
+ else
+ lyxpreamble += from_utf8(lang_package);
+ lyxpreamble += '\n';
+ }
+
docstring const i18npreamble =
features.getTClassI18nPreamble(use_babel, use_polyglossia);
if (!i18npreamble.empty())
return;
LayoutModuleList mods;
- LayoutModuleList::iterator it;
- LayoutModuleList::iterator en;
-
- it = layout_modules_.begin();
- en = layout_modules_.end();
+ LayoutModuleList::iterator it = layout_modules_.begin();
+ LayoutModuleList::iterator en = layout_modules_.end();
for (; it != en; ++it)
mods.push_back(*it);
+
it = cite_engine_.begin();
en = cite_engine_.end();
for (; it != en; ++it)
mods.push_back(*it);
+
doc_class_ = getDocumentClass(*baseClass(), mods);
if (!local_layout.empty()) {
}
-bool BufferParams::moduleCanBeAdded(string const & modName) const
+bool BufferParams::layoutModuleCanBeAdded(string const & modName) const
+{
+ return layout_modules_.moduleCanBeAdded(modName, baseClass());
+}
+
+
+bool BufferParams::citationModuleCanBeAdded(string const & modName) const
{
- return cite_engine_.moduleCanBeAdded(modName, baseClass()) &&
- layout_modules_.moduleCanBeAdded(modName, baseClass());
+ return cite_engine_.moduleCanBeAdded(modName, baseClass());
}
namespace {
-bool formatSorter(Format const * lhs, Format const * rhs) {
+
+bool formatSorter(Format const * lhs, Format const * rhs)
+{
return _(lhs->prettyname()) < _(rhs->prettyname());
}
+
}
OutputParams::FLAVOR result = OutputParams::LATEX;
+ // FIXME It'd be better not to hardcode this, but to do
+ // something with formats.
if (dformat == "xhtml")
result = OutputParams::HTML;
else if (dformat == "text")
result = OutputParams::TEXT;
+ else if (dformat == "lyx")
+ result = OutputParams::LYX;
+ else if (dformat == "pdflatex")
+ result = OutputParams::PDFLATEX;
+ else if (dformat == "xetex")
+ result = OutputParams::XETEX;
+ else if (dformat == "luatex")
+ result = OutputParams::LUATEX;
+ else if (dformat == "dviluatex")
+ result = OutputParams::DVILUATEX;
else {
// Try to determine flavor of default output format
vector<string> backs = backends();
}
+InsetQuotes::QuoteLanguage BufferParams::getQuoteStyle(string const qs) const
+{
+ return quoteslangtranslator().find(qs);
+}
+
+
bool BufferParams::isLatex() const
{
return documentClass().outputType() == LATEX;
string BufferParams::babelCall(string const & lang_opts, bool const langoptions) const
{
- if (lang_package != "auto" && lang_package != "babel"
- && lang_package != "default" && lang_package != "none")
- return lang_package;
- if (lyxrc.language_package_selection == LyXRC::LP_CUSTOM)
- return lyxrc.language_custom_package;
// suppress the babel call if there is no BabelName defined
// for the document language in the lib/languages file and if no
// other languages are used (lang_opts is then empty)
// If the "japanese" package (i.e. pLaTeX) is used,
// inputenc must be omitted.
// see http://www.mail-archive.com/lyx-devel@lists.lyx.org/msg129680.html
- if (package == Encoding::japanese)
- features.require("japanese");
-
if ((!encodings.empty() || package == Encoding::inputenc)
&& !features.isRequired("japanese")) {
os << "\\usepackage[";
break;
}
}
-
- // The encoding "armscii8" (for Armenian) is only available when
- // the package "armtex" is loaded.
- if (language->encoding()->latexName() == "armscii8"
- || inputenc == "armscii8")
- os << "\\usepackage{armtex}\n";
}
}
-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,
- bool const & use_systemfonts,
- LaTeXFeatures & features) const
-{
- /* The LaTeX font world is in a flux. In the PSNFSS font interface,
- several packages have been replaced by others, that might not
- be installed on every system. We have to take care for that
- (see psnfss.pdf). We try to support all psnfss fonts as well
- as the fonts that have become de facto standard in the LaTeX
- world (e.g. Latin Modern). We do not support obsolete fonts
- (like PSLatex). In general, it should be possible to mix any
- rm font with any sf or tt font, respectively. (JSpitzm)
- TODO:
- -- separate math fonts.
- */
-
- if (rm == "default" && sf == "default" && tt == "default")
+string const BufferParams::loadFonts(LaTeXFeatures & features) const
+{
+ if (fonts_roman == "default" && fonts_sans == "default"
+ && fonts_typewriter == "default"
+ && (fonts_math == "default" || fonts_math == "auto"))
//nothing to do
return string();
* -- if there's a way to find out if a font really supports
* OldStyle, enable/disable the widget accordingly.
*/
- if (use_systemfonts && features.isAvailable("fontspec")) {
+ if (useNonTeXFonts && features.isAvailable("fontspec")) {
// "Mapping=tex-text" and "Ligatures=TeX" are equivalent.
// However, until v.2 (2010/07/11) fontspec only knew
// Mapping=tex-text (for XeTeX only); then "Ligatures=TeX"
string const texmapping =
(features.runparams().flavor == OutputParams::XETEX) ?
"Mapping=tex-text" : "Ligatures=TeX";
- if (rm != "default") {
+ if (fonts_roman != "default") {
os << "\\setmainfont[" << texmapping;
- if (osf)
+ if (fonts_old_figures)
os << ",Numbers=OldStyle";
- os << "]{" << parseFontName(rm) << "}\n";
+ os << "]{" << parseFontName(fonts_roman) << "}\n";
}
- if (sf != "default") {
- string const sans = parseFontName(sf);
- if (sfscale != 100)
+ if (fonts_sans != "default") {
+ string const sans = parseFontName(fonts_sans);
+ if (fonts_sans_scale != 100)
os << "\\setsansfont[Scale="
- << float(sfscale) / 100
+ << float(fonts_sans_scale) / 100
<< "," << texmapping << "]{"
<< sans << "}\n";
else
os << "\\setsansfont[" << texmapping << "]{"
<< sans << "}\n";
}
- if (tt != "default") {
- string const mono = parseFontName(tt);
- if (ttscale != 100)
+ if (fonts_typewriter != "default") {
+ string const mono = parseFontName(fonts_typewriter);
+ if (fonts_typewriter_scale != 100)
os << "\\setmonofont[Scale="
- << float(ttscale) / 100
+ << float(fonts_typewriter_scale) / 100
<< "]{"
<< mono << "}\n";
else
return os.str();
}
+ // Tex Fonts
+ bool const ot1 = (font_encoding() == "default" || font_encoding() == "OT1");
+ bool const dryrun = features.runparams().dryrun;
+ bool const complete = (fonts_sans == "default" && fonts_typewriter == "default");
+ bool const nomath = (fonts_math == "default");
+
// ROMAN FONTS
- // Computer Modern (must be explicitly selectable -- there might be classes
- // that define a different default font!
- if (rm == "cmr") {
- os << "\\renewcommand{\\rmdefault}{cmr}\n";
- // osf for Computer Modern needs eco.sty
- if (osf)
- os << "\\usepackage{eco}\n";
- }
- // Latin Modern Roman
- else if (rm == "lmodern")
- os << "\\usepackage{lmodern}\n";
- // AE
- else if (rm == "ae") {
- // not needed when using OT1 font encoding.
- if (font_encoding() != "default")
- os << "\\usepackage{ae,aecompl}\n";
- }
- // Times
- else if (rm == "times") {
- // try to load the best available package
- if (LaTeXFeatures::isAvailable("mathptmx"))
- os << "\\usepackage{mathptmx}\n";
- 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 (LaTeXFeatures::isAvailable("mathpazo")) {
- os << "\\usepackage";
- if (osf || sc) {
- os << '[';
- if (!osf)
- os << "sc";
- else
- // "osf" includes "sc"!
- os << "osf";
- os << ']';
- }
- os << "{mathpazo}\n";
- }
- else if (LaTeXFeatures::isAvailable("mathpple"))
- os << "\\usepackage{mathpple}\n";
- else
- os << "\\usepackage{palatino}\n";
- }
- // Utopia
- else if (rm == "utopia") {
- // fourier supersedes utopia.sty, but does
- // not work with OT1 encoding.
- if (LaTeXFeatures::isAvailable("fourier")
- && font_encoding() != "default") {
- os << "\\usepackage";
- if (osf || sc) {
- os << '[';
- if (sc)
- os << "expert";
- if (osf && sc)
- os << ',';
- if (osf)
- os << "oldstyle";
- os << ']';
- }
- os << "{fourier}\n";
- }
- else
- os << "\\usepackage{utopia}\n";
- }
- // Bera (complete fontset)
- else if (rm == "bera" && sf == "default" && tt == "default")
- os << "\\usepackage{bera}\n";
- // everything else
- else if (rm != "default")
- os << "\\usepackage" << "{" << rm << "}\n";
+ os << theLaTeXFonts().getLaTeXFont(from_ascii(fonts_roman)).getLaTeXCode(
+ dryrun, ot1, complete, fonts_expert_sc, fonts_old_figures,
+ nomath);
// SANS SERIF
- // Helvetica, Bera Sans
- if (sf == "helvet" || sf == "berasans") {
- if (sfscale != 100)
- os << "\\usepackage[scaled=" << float(sfscale) / 100
- << "]{" << sf << "}\n";
- else
- os << "\\usepackage{" << sf << "}\n";
- }
- // Avant Garde
- else if (sf == "avant")
- os << "\\usepackage{" << sf << "}\n";
- // Computer Modern, Latin Modern, CM Bright
- else if (sf != "default")
- os << "\\renewcommand{\\sfdefault}{" << sf << "}\n";
-
- // monospaced/typewriter
- // Courier, LuxiMono
- if (tt == "luximono" || tt == "beramono") {
- if (ttscale != 100)
- os << "\\usepackage[scaled=" << float(ttscale) / 100
- << "]{" << tt << "}\n";
- else
- os << "\\usepackage{" << tt << "}\n";
- }
- // Courier
- else if (tt == "courier" )
- os << "\\usepackage{" << tt << "}\n";
- // Computer Modern, Latin Modern, CM Bright
- else if (tt != "default")
- os << "\\renewcommand{\\ttdefault}{" << tt << "}\n";
+ os << theLaTeXFonts().getLaTeXFont(from_ascii(fonts_sans)).getLaTeXCode(
+ dryrun, ot1, complete, fonts_expert_sc, fonts_old_figures,
+ nomath, fonts_sans_scale);
+
+ // MONOSPACED/TYPEWRITER
+ os << theLaTeXFonts().getLaTeXFont(from_ascii(fonts_typewriter)).getLaTeXCode(
+ dryrun, ot1, complete, fonts_expert_sc, fonts_old_figures,
+ nomath, fonts_typewriter_scale);
+
+ // MATH
+ os << theLaTeXFonts().getLaTeXFont(from_ascii(fonts_math)).getLaTeXCode(
+ dryrun, ot1, complete, fonts_expert_sc, fonts_old_figures,
+ nomath);
return os.str();
}