X-Git-Url: https://git.lyx.org/gitweb/?a=blobdiff_plain;f=src%2FTocBackend.h;h=15a800d990347ad8ed6e71b51a9db01eb84c3e5a;hb=cb351665f432671eb263eec76164aa546abd7151;hp=f9e700e379411c46706c8d884ffe8631cbf69fed;hpb=1e51e87f680a7a903d1c24bccf26598459efec47;p=lyx.git diff --git a/src/TocBackend.h b/src/TocBackend.h index f9e700e379..15a800d990 100644 --- a/src/TocBackend.h +++ b/src/TocBackend.h @@ -33,15 +33,18 @@ class FuncRequest; */ class TocItem { + friend class Toc; friend class TocBackend; public: /// Default constructor for STL containers. - TocItem() {} + TocItem() : dit_(0) {} /// TocItem(DocIterator const & dit, int depth, - docstring const & s + docstring const & s, + bool output_active, + docstring const & t = docstring() ); /// ~TocItem() {} @@ -52,7 +55,13 @@ public: /// docstring const & str() const; /// + docstring const & tooltip() const; + /// docstring const asString() const; + /// + DocIterator const & dit() const; + /// + bool isOutput() const { return output_; } /// the action corresponding to the goTo above FuncRequest action() const; @@ -60,17 +69,29 @@ public: protected: /// Current position of item. DocIterator dit_; - /// nesting depth int depth_; - /// Full item string docstring str_; + /// The tooltip string + docstring tooltip_; + /// Is this item in a note, inactive branch, etc? + bool output_; }; /// -class Toc : public std::vector {}; +class Toc : public std::vector +{ +public: + typedef std::vector::const_iterator const_iterator; + typedef std::vector::iterator iterator; + const_iterator item(DocIterator const & dit) const; + /// Look for a TocItem given its depth and string. + /// \return The first matching item. + /// \retval end() if no item was found. + iterator item(int depth, docstring const & str); +}; typedef Toc::const_iterator TocIterator; @@ -90,9 +111,9 @@ public: /// void setBuffer(Buffer const * buffer) { buffer_ = buffer; } /// - void update(); - /// - void updateItem(DocIterator const & pit); + void update(bool output_active); + /// \return true if the item was updated. + bool updateItem(DocIterator const & pit); /// TocList const & tocs() const { return tocs_; } @@ -109,7 +130,8 @@ public: ) const; /// - void writePlaintextTocList(std::string const & type, odocstream & os) const; + void writePlaintextTocList(std::string const & type, + odocstringstream & os, size_t max_length) const; private: ///