X-Git-Url: https://git.lyx.org/gitweb/?a=blobdiff_plain;f=src%2FLayoutFile.h;h=b71f1230095e2d3c82e1a5993ca19f37c9da562b;hb=53a72a45266feb86c13f47615a4cbb15053f3c63;hp=976a7dd88103751c4bf99bc578561269583ca998;hpb=9db713da16ddefba7b270c79ae414dbf344054f9;p=lyx.git diff --git a/src/LayoutFile.h b/src/LayoutFile.h index 976a7dd881..b71f123009 100644 --- a/src/LayoutFile.h +++ b/src/LayoutFile.h @@ -13,6 +13,7 @@ #ifndef BASECLASSLIST_H #define BASECLASSLIST_H +#include "LayoutModuleList.h" #include "TextClass.h" #include "support/strfwd.h" @@ -28,10 +29,6 @@ namespace lyx { class Layout; -/// Reads the style files -extern bool LyXSetStyle(); - - /// Index into LayoutFileList. Basically a 'strong typedef'. class LayoutFileIndex { public: @@ -63,20 +60,23 @@ private: class LayoutFile : public TextClass, boost::noncopyable { public: /// check whether the TeX class is available - bool isTeXClassAvailable() const { return texClassAvail_; } + bool isTeXClassAvailable() const { return tex_class_avail_; } /// - std::list const & defaultModules() const + LayoutModuleList const & defaultModules() const { return default_modules_; } - std::list const & providedModules() const + /// + LayoutModuleList const & providedModules() const { return provided_modules_; } - std::list const & excludedModules() const + /// + LayoutModuleList const & excludedModules() const { return excluded_modules_; } private: /// Construct a layout with default values. Actual values loaded later. explicit LayoutFile(std::string const & filename, std::string const & className = std::string(), std::string const & description = std::string(), - bool texClassAvail = false); + std::string const & prerequisites = std::string(), + bool texclassavail = false); /// The only class that should create a LayoutFile is /// LayoutFileList, which calls the private constructor. friend class LayoutFileList; @@ -92,6 +92,7 @@ class LayoutFileList { public: /// LayoutFileList() {} + /// ~LayoutFileList(); /// \return The sole instance of this class. static LayoutFileList & get(); @@ -99,16 +100,20 @@ public: bool empty() const { return classmap_.empty(); } /// bool haveClass(std::string const & classname) const; - /// + /// Note that this will assert if we don't have classname, so + /// check via haveClass() first. LayoutFile const & operator[](std::string const & classname) const; - /// + /// Note that this will assert if we don't have classname, so + /// check via haveClass() first. LayoutFile & operator[](std::string const & classname); /// Read textclass list. Returns false if this fails. bool read(); /// Clears the textclass so as to force it to be reloaded void reset(LayoutFileIndex const & tc); - /// add a default textclass with all standard layouts. + /// Add a default textclass with all standard layouts. + /// Note that this will over-write any information we may have + /// gotten from textclass.lst about this class. LayoutFileIndex addEmptyClass(std::string const & textclass); /// add a textclass from user local directory. @@ -118,6 +123,10 @@ public: addLocalLayout(std::string const & textclass, std::string const & path); /// a list of the available classes std::vector classList() const; + + /// + bool load(std::string const & name, std::string const & buf_path); + private: /// typedef std::map ClassMap;