X-Git-Url: https://git.lyx.org/gitweb/?a=blobdiff_plain;f=src%2FLaTeXFeatures.h;h=ed824d8b34aaee4510f3d868fba039b3d72a0603;hb=e903d0158e1d92c0d9c17656af10df9fa9a3d723;hp=bcf1ed43b82b618701684c670579ed40e48f4b69;hpb=ac1977018b67c3ec684e999cf6e4dc71a64138c4;p=lyx.git diff --git a/src/LaTeXFeatures.h b/src/LaTeXFeatures.h index bcf1ed43b8..ed824d8b34 100644 --- a/src/LaTeXFeatures.h +++ b/src/LaTeXFeatures.h @@ -4,7 +4,7 @@ * This file is part of LyX, the document processor. * Licence details can be found in the file COPYING. * - * \author Lars Gullik Bjønnes + * \author Lars Gullik Bjønnes * \author Jean-Marc Lasgouttes * * Full author contact details are available in file CREDITS. @@ -19,13 +19,13 @@ #include #include #include -#include namespace lyx { class Buffer; class BufferParams; +class InsetLayout; class Language; /** The packages and commands that a buffer needs. This class @@ -46,14 +46,28 @@ public: /// LaTeXFeatures(Buffer const &, BufferParams const &, OutputParams const &); + /// The color packages + std::string const getColorOptions() const; /// The packages needed by the document std::string const getPackages() const; /// The macros definitions needed by the document - std::string const getMacros() const; - /// - std::string const getBabelOptions() const; + docstring const getMacros() const; + /// Extra preamble code before babel is called + std::string const getBabelPresettings() const; + /// Extra preamble code after babel is called + std::string const getBabelPostsettings() const; + /// Do we need to pass the languages to babel directly? + bool needBabelLangOptions() const; + /// Load AMS packages when appropriate + std::string const loadAMSPackages() const; /// The definitions needed by the document's textclass docstring const getTClassPreamble() const; + /// The language dependent definitions needed by the document's textclass + docstring const getTClassI18nPreamble(bool use_babel, bool use_polyglossia) const; + /// + docstring const getTClassHTMLStyles() const; + /// + docstring const getTClassHTMLPreamble() const; /// The sgml definitions needed by the document (docbook) docstring const getLyXSGMLEntities() const; /// The SGML Required to include the files added with includeFile(); @@ -61,17 +75,21 @@ public: /// Include a file for use with the SGML entities void includeFile(docstring const & key, std::string const & name); /// The float definitions. - void getFloatDefinitions(std::ostream & os) const; + void getFloatDefinitions(odocstream & os) const; /// Print requirements to lyxerr void showStruct() const; /// void addPreambleSnippet(std::string const &); + /// + std::string getPreambleSnippets() const; + /// + void addCSSSnippet(std::string const &); + /// + std::string getCSSSnippets() const; /// Add a feature name requirements void require(std::string const & name); /// Add a set of feature names requirements void require(std::set const & names); - /// Which of the required packages are installed? - static void getAvailable(); /// Is the (required) package available? static bool isAvailable(std::string const & name); /// Has the package been required? @@ -87,13 +105,21 @@ public: void useLanguage(Language const *); /// bool hasLanguages() const; + /// check if all used languages are supported by polyglossia + bool hasOnlyPolyglossiaLanguages() const; + /// check if a language is supported only by polyglossia + bool hasPolyglossiaExclusiveLanguages() const; /// - std::string getLanguages() const; + std::string getBabelLanguages() const; + /// + std::map getPolyglossiaLanguages() const; /// std::set getEncodingSet(std::string const & doc_encoding) const; /// void useLayout(docstring const & lyt); /// + void useInsetLayout(InsetLayout const & lay); + /// Buffer const & buffer() const; /// void setBuffer(Buffer const &); @@ -101,24 +127,36 @@ public: BufferParams const & bufferParams() const; /// the return value is dependent upon both LyXRC and LaTeXFeatures. bool useBabel() const; + /// + bool usePolyglossia() const; + /// are we in a float? + bool inFloat() const { return in_float_; } + /// are we in a float? + void inFloat(bool const b) { in_float_ = b; } /// Runparams that will be used for exporting this file. OutputParams const & runparams() const { return runparams_; } + /// Resolve alternatives like "esint|amsmath|wasysym" + void resolveAlternatives(); + /// + void setHTMLTitle(docstring const & t) { htmltitle_ = t; } + /// + docstring const & htmlTitle() const { return htmltitle_; } private: + /// std::list usedLayouts_; - + /// + std::list usedInsetLayouts_; /// The features that are needed by the document typedef std::set Features; /// Features features_; - /// Static preamble bits from the external material insets + /// Static preamble bits, from external templates, or anywhere else typedef std::list SnippetList; /// SnippetList preamble_snippets_; - /// The available (required) packages - typedef std::set Packages; /// - static Packages packages_; + SnippetList css_snippets_; /// typedef std::set LanguageList; /// used languages (only those that are supported by babel) @@ -143,6 +181,10 @@ private: * in validate(). */ OutputParams const & runparams_; + /// + bool in_float_; + /// + docstring htmltitle_; };