mirror of
https://git.lyx.org/repos/lyx.git
synced 2025-01-21 07:03:32 +00:00
163 lines
4.4 KiB
C++
163 lines
4.4 KiB
C++
// -*- C++ -*-
|
|
/**
|
|
* \file TocBackend.h
|
|
* This file is part of LyX, the document processor.
|
|
* Licence details can be found in the file COPYING.
|
|
*
|
|
* \author Jean-Marc Lasgouttes
|
|
* \author Angus Leeming
|
|
* \author Abdelrazak Younes
|
|
* \author Guillaume Munch
|
|
*
|
|
* Full author contact details are available in file CREDITS.
|
|
*/
|
|
|
|
#ifndef TOC_BACKEND_H
|
|
#define TOC_BACKEND_H
|
|
|
|
#include "DocIterator.h"
|
|
#include "FuncRequest.h"
|
|
#include "OutputEnums.h"
|
|
#include "Toc.h"
|
|
#include "TocBuilder.h"
|
|
|
|
#include "support/strfwd.h"
|
|
#include "support/unique_ptr.h"
|
|
|
|
|
|
namespace lyx {
|
|
|
|
class Buffer;
|
|
|
|
/* Toc types are described by strings. They cannot be converted into an enum
|
|
* because of the user-configurable categories for index and the user-definable
|
|
* toc types provided in layout files.
|
|
*
|
|
* Here is a summary of built-in toc types
|
|
*
|
|
* Non-customizable (used without TocBuilder): "tableofcontents", "change",
|
|
* "citation", "label", "senseless".
|
|
*
|
|
* Built-in but customizable (used with TocBuilder): "child", "graphics",
|
|
* "equation", "index", "index:<user-str>", "nomencl", "listings", "math-macro",
|
|
* "external", any float type (as defined in the layouts).
|
|
*
|
|
* The following are used for XHTML output: "tableofcontents" (InsetText),
|
|
* "citation" (InsetCitation), any float type.
|
|
*
|
|
* Other types are defined in the layouts.
|
|
*/
|
|
|
|
///
|
|
/**
|
|
*/
|
|
class TocItem
|
|
{
|
|
public:
|
|
/// Default constructor for STL containers.
|
|
TocItem() : dit_(0), depth_(0), output_(false) {}
|
|
///
|
|
TocItem(DocIterator const & dit,
|
|
int depth,
|
|
docstring const & s,
|
|
bool output_active,
|
|
FuncRequest const & action = FuncRequest(LFUN_UNKNOWN_ACTION)
|
|
);
|
|
///
|
|
DocIterator const & dit() const { return dit_; }
|
|
///
|
|
int depth() const { return depth_; }
|
|
///
|
|
docstring const & str() const { return str_; }
|
|
///
|
|
void str(docstring const & s) { str_ = s; }
|
|
///
|
|
bool isOutput() const { return output_; }
|
|
///
|
|
void setAction(FuncRequest const & a) { action_ = a; }
|
|
|
|
/// custom action, or the default one (paragraph-goto) if not customised
|
|
FuncRequest action() const;
|
|
///
|
|
int id() const;
|
|
/// String for display, e.g. it has a mark if output is inactive
|
|
docstring const asString() const;
|
|
|
|
private:
|
|
/// Current position of item.
|
|
DocIterator dit_;
|
|
/// nesting depth
|
|
int depth_;
|
|
/// Full item string
|
|
docstring str_;
|
|
/// Is this item in a note, inactive branch, etc?
|
|
bool output_;
|
|
/// Custom action
|
|
FuncRequest action_;
|
|
};
|
|
|
|
|
|
/// Class to build and access the Tocs of a particular buffer.
|
|
class TocBackend
|
|
{
|
|
public:
|
|
static Toc::const_iterator findItem(Toc const & toc,
|
|
DocIterator const & dit);
|
|
/// Look for a TocItem given its depth and string.
|
|
/// \return The first matching item.
|
|
/// \retval end() if no item was found.
|
|
static Toc::iterator findItem(Toc & toc, int depth, docstring const & str);
|
|
///
|
|
TocBackend(Buffer const * buffer) : buffer_(buffer) {}
|
|
///
|
|
void setBuffer(Buffer const * buffer) { buffer_ = buffer; }
|
|
///
|
|
void update(bool output_active, UpdateType utype);
|
|
///
|
|
void reset();
|
|
/// \return true if the item was updated.
|
|
bool updateItem(DocIterator const & pit);
|
|
///
|
|
TocList const & tocs() const { return tocs_; }
|
|
/// never null
|
|
std::shared_ptr<Toc const> toc(std::string const & type) const;
|
|
/// never null
|
|
std::shared_ptr<Toc> toc(std::string const & type);
|
|
/// \return the current TocBuilder for the Toc of type \param type, or
|
|
/// creates one if it does not already exist.
|
|
TocBuilder & builder(std::string const & type);
|
|
/// \return the first Toc Item before the cursor.
|
|
/// \param type: Type of Toc.
|
|
/// \param dit: The cursor location in the document.
|
|
Toc::const_iterator
|
|
item(std::string const & type, DocIterator const & dit) const;
|
|
|
|
///
|
|
void writePlaintextTocList(std::string const & type,
|
|
odocstringstream & os, size_t max_length) const;
|
|
/// Localised name for type
|
|
docstring outlinerName(std::string const & type) const;
|
|
/// Add a new (localised) name if yet unknown
|
|
void addName(std::string const & type, docstring const & name);
|
|
/// Whether a toc type is less important and appears in the "Other lists"
|
|
/// submenu
|
|
static bool isOther(std::string const & type);
|
|
|
|
private:
|
|
///
|
|
void resetOutlinerNames();
|
|
///
|
|
TocList tocs_;
|
|
///
|
|
std::map<std::string, std::unique_ptr<TocBuilder>> builders_;
|
|
/// Stores localised outliner names from this buffer and its children
|
|
std::map<std::string, docstring> outliner_names_;
|
|
///
|
|
Buffer const * buffer_;
|
|
}; // TocBackend
|
|
|
|
|
|
} // namespace lyx
|
|
|
|
#endif // TOC_BACKEND_H
|