mirror of
https://git.lyx.org/repos/lyx.git
synced 2025-01-11 19:14:51 +00:00
f9fa189e02
no text classes for some reason (e.g., a corrupt textclass.lst). We still give the user a chance to reconfigure (Bo's idea). I wonder if we still really need to "restart LyX to make use of any updated document class specifications". What would happen if we just reloaded? git-svn-id: svn://svn.lyx.org/lyx/lyx-devel/trunk@34081 a592a061-630c-0410-9148-cb99ea01b6c8
148 lines
4.2 KiB
C++
148 lines
4.2 KiB
C++
// -*- C++ -*-
|
|
/**
|
|
* \file LayoutFile.h
|
|
* This file is part of LyX, the document processor.
|
|
* Licence details can be found in the file COPYING.
|
|
*
|
|
* \author Lars Gullik Bjønnes
|
|
* \author Richard Heck (typedefs and such)
|
|
*
|
|
* Full author contact details are available in file CREDITS.
|
|
*/
|
|
|
|
#ifndef BASECLASSLIST_H
|
|
#define BASECLASSLIST_H
|
|
|
|
#include "LayoutModuleList.h"
|
|
#include "TextClass.h"
|
|
|
|
#include "support/strfwd.h"
|
|
|
|
#include <boost/noncopyable.hpp>
|
|
|
|
#include <set>
|
|
#include <string>
|
|
#include <vector>
|
|
|
|
|
|
namespace lyx {
|
|
|
|
class Layout;
|
|
|
|
/// Index into LayoutFileList. Basically a 'strong typedef'.
|
|
class LayoutFileIndex {
|
|
public:
|
|
///
|
|
typedef std::string base_type;
|
|
///
|
|
LayoutFileIndex(base_type t) { data_ = t; }
|
|
///
|
|
operator base_type() const { return data_; }
|
|
///
|
|
bool empty() const { return data_.empty(); }
|
|
private:
|
|
base_type data_;
|
|
};
|
|
|
|
/// This class amounts to little more than a `strong typedef'.
|
|
///
|
|
/// 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
|
|
/// constructing DocumentClass objects, which are what represent
|
|
/// 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 {
|
|
public:
|
|
/// check whether the TeX class is available
|
|
bool isTeXClassAvailable() const { return tex_class_avail_; }
|
|
///
|
|
LayoutModuleList const & defaultModules() const
|
|
{ return default_modules_; }
|
|
///
|
|
LayoutModuleList const & providedModules() const
|
|
{ return provided_modules_; }
|
|
///
|
|
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(),
|
|
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;
|
|
/// can't create empty LayoutFile
|
|
LayoutFile() {};
|
|
};
|
|
|
|
|
|
/// A list of base document classes (*.layout files).
|
|
/// This is a singleton class. The sole instance is accessed
|
|
/// via LayoutFileList::get()
|
|
class LayoutFileList {
|
|
public:
|
|
///
|
|
LayoutFileList() {}
|
|
///
|
|
~LayoutFileList();
|
|
/// \return The sole instance of this class.
|
|
static LayoutFileList & get();
|
|
///
|
|
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.
|
|
/// 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);
|
|
/// a list of the available classes
|
|
std::vector<LayoutFileIndex> classList() const;
|
|
|
|
///
|
|
bool load(std::string const & name, std::string const & buf_path);
|
|
|
|
private:
|
|
///
|
|
typedef std::map<std::string, LayoutFile *> ClassMap;
|
|
/// noncopyable
|
|
LayoutFileList(LayoutFileList const &);
|
|
/// nonassignable
|
|
void operator=(LayoutFileList const &);
|
|
///
|
|
mutable ClassMap classmap_; //FIXME
|
|
};
|
|
|
|
///
|
|
LayoutFileIndex defaultBaseclass();
|
|
|
|
|
|
} // namespace lyx
|
|
|
|
#endif
|