X-Git-Url: https://git.lyx.org/gitweb/?a=blobdiff_plain;f=src%2FLaTeXFeatures.h;h=7f010b33ca94522ba397e4ff098683c600a7df1c;hb=823e44822e6638824900eee2f7e2e7165af97f8d;hp=d5d02bb5d0cfc4b4a440a6ab98da1ae8bff4b504;hpb=701f204b22fb54e01ceb3c7e404e09ecbb5bebdb;p=lyx.git diff --git a/src/LaTeXFeatures.h b/src/LaTeXFeatures.h index d5d02bb5d0..7f010b33ca 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. @@ -13,7 +13,6 @@ #ifndef LATEXFEATURES_H #define LATEXFEATURES_H - #include "OutputParams.h" #include "support/docstring.h" @@ -47,6 +46,8 @@ 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 @@ -55,6 +56,8 @@ public: std::string const getBabelOptions() 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) const; /// The sgml definitions needed by the document (docbook) docstring const getLyXSGMLEntities() const; /// The SGML Required to include the files added with includeFile(); @@ -67,8 +70,10 @@ public: void showStruct() const; /// void addPreambleSnippet(std::string const &); - /// Provide a string name-space to the requirements + /// 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? @@ -81,7 +86,7 @@ public: */ bool mustProvide(std::string const & name) const; /// - void useFloat(std::string const & name); + void useFloat(std::string const & name, bool subfloat = false); /// void useLanguage(Language const *); /// @@ -91,7 +96,7 @@ public: /// std::set getEncodingSet(std::string const & doc_encoding) const; /// - void useLayout(std::string const & lyt); + void useLayout(docstring const & lyt); /// Buffer const & buffer() const; /// @@ -100,32 +105,38 @@ public: BufferParams const & bufferParams() const; /// the return value is dependent upon both LyXRC and LaTeXFeatures. bool useBabel() 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_; } private: - std::list usedLayouts_; + std::list usedLayouts_; - /// Static preamble bits from the external material insets - typedef std::list FeaturesList; + /// The features that are needed by the document + typedef std::set Features; /// - FeaturesList features_; + Features features_; + /// Static preamble bits from the external material insets + typedef std::list SnippetList; /// - FeaturesList preamble_snippets_; + SnippetList preamble_snippets_; /// The available (required) packages - typedef std::list PackagesList; + typedef std::set Packages; /// - static PackagesList packages_; + static Packages packages_; /// typedef std::set LanguageList; - /// + /// used languages (only those that are supported by babel) LanguageList UsedLanguages_; /// - typedef std::set UsedFloats; + typedef std::map UsedFloats; /// UsedFloats usedFloats_; /// - typedef std::map FileMap; + typedef std::map FileMap; /// FileMap IncludedFiles_; /** Buffer of the file being processed. @@ -140,6 +151,8 @@ private: * in validate(). */ OutputParams const & runparams_; + /// + bool in_float_; };