#define LATEXFEATURES_H
+#include "outputparams.h"
+
#include <set>
#include <list>
#include <map>
class Buffer;
class BufferParams;
-struct Language;
+class Language;
/** The packages and commands that a buffer needs. This class
* contains a list<string>. Each of the LaTeX packages that a buffer needs
class LaTeXFeatures {
public:
///
- LaTeXFeatures(Buffer const &, BufferParams const &, bool);
+ LaTeXFeatures(Buffer const &, BufferParams const &,
+ OutputParams const &);
/// The packages needed by the document
std::string const getPackages() const;
/// The macros definitions needed by the document
void addExternalPreamble(std::string const &);
/// Provide a string name-space to the requirements
void require(std::string const & name);
+ /// Which of the required packages are installed?
+ static void getAvailable();
/// Is the package required?
bool isRequired(std::string const & name) const;
+ /// Is the (required) package available?
+ bool isAvailable(std::string const & name) const;
///
void useFloat(std::string const & name);
///
BufferParams const & bufferParams() const;
/// the return value is dependent upon both LyXRC and LaTeXFeatures.
bool useBabel() const;
- ///
- bool nice() const { return nice_; };
+ /// Runparams that will be used for exporting this file.
+ OutputParams const & runparams() const { return runparams_; }
private:
std::list<std::string> usedLayouts_;
FeaturesList features_;
///
FeaturesList preamble_snippets_;
+ /// The available (required) packages
+ typedef std::list<std::string> PackagesList;
+ ///
+ static PackagesList packages_;
///
typedef std::set<Language const *> LanguageList;
///
Buffer const * buffer_;
///
BufferParams const & params_;
- /** If we are writing a nice LaTeX file or not.
- * Only needed by InsetInclude::validate().
+ /** Some insets need to know details about the to-be-produced file
+ * in validate().
*/
- bool nice_;
+ OutputParams const & runparams_;
};
#endif