X-Git-Url: https://git.lyx.org/gitweb/?a=blobdiff_plain;f=src%2FLayoutFile.h;h=7fcc820bbf6f467949e28e2a544e9f3ee0df303a;hb=a506c6b73b81fac52e32b2ca31b9e92d67ae250a;hp=847b469435fc9ed99ac90a016e7474f8fe4253de;hpb=08d7f7885a007a03bf958d2ba2b402a1a53c5bf2;p=lyx.git diff --git a/src/LayoutFile.h b/src/LayoutFile.h index 847b469435..7fcc820bbf 100644 --- a/src/LayoutFile.h +++ b/src/LayoutFile.h @@ -18,9 +18,6 @@ #include "support/strfwd.h" -#include - -#include #include #include @@ -29,17 +26,13 @@ namespace lyx { class Layout; -/// Reads the style files -extern bool LyXSetStyle(); - - /// Index into LayoutFileList. Basically a 'strong typedef'. class LayoutFileIndex { public: /// typedef std::string base_type; /// - LayoutFileIndex(base_type t) { data_ = t; } + LayoutFileIndex(base_type const & t) : data_(t) { } /// operator base_type() const { return data_; } /// @@ -49,42 +42,47 @@ private: }; /// This class amounts to little more than a `strong typedef'. -/// -/// A LayoutFile represents the layout information that is +/// +/// A LayoutFile represents the layout information that is /// contained in a *.layout file. -/// -/// No document- (that is, Buffer-) specific information should -/// be placed in these objects. They are used as the basis for +/// +/// No document- (that is, Buffer-) specific information should +/// be placed in these objects. They are used as the basis for /// constructing DocumentClass objects, which are what represent -/// the layout information associated with a Buffer. (This is also +/// the layout information associated with a Buffer. (This is also /// a subclass of TextClass, implemented in TextClass.{h,cpp}.) /// Buffer-specific information should therefore be placed in a /// DocumentClass object. -/// -class LayoutFile : public TextClass, boost::noncopyable { +/// +class LayoutFile : public TextClass { public: /// check whether the TeX class is available - bool isTeXClassAvailable() const { return texClassAvail_; } + bool isTeXClassAvailable() const { return tex_class_avail_; } /// - LayoutModuleList const & defaultModules() const + LayoutModuleList const & defaultModules() const { return default_modules_; } /// - LayoutModuleList const & providedModules() const + LayoutModuleList const & providedModules() const { return provided_modules_; } /// - LayoutModuleList const & excludedModules() const + LayoutModuleList const & excludedModules() const { return excluded_modules_; } private: + /// noncopyable + LayoutFile(LayoutFile const &); + void operator=(LayoutFile const &); /// 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(), + std::string const & category = std::string(), + bool texclassavail = false); /// The only class that should create a LayoutFile is /// LayoutFileList, which calls the private constructor. friend class LayoutFileList; /// can't create empty LayoutFile - LayoutFile() {}; + LayoutFile() {} }; @@ -93,8 +91,6 @@ private: /// via LayoutFileList::get() class LayoutFileList { public: - /// - LayoutFileList() {} /// ~LayoutFileList(); /// \return The sole instance of this class. @@ -114,17 +110,26 @@ public: /// 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. /// \return the identifier for the loaded file, or else an /// empty string if no file was loaded. - LayoutFileIndex - addLocalLayout(std::string const & textclass, std::string const & path); + LayoutFileIndex addLocalLayout(std::string const & textclass, + std::string const & path, + std::string const & oldpath = empty_string()); /// a list of the available classes std::vector classList() const; + + /// + bool load(std::string const & name, std::string const & buf_path); + private: + /// + LayoutFileList() {} /// typedef std::map ClassMap; /// noncopyable