X-Git-Url: https://git.lyx.org/gitweb/?a=blobdiff_plain;f=src%2FInsetList.h;h=36a40c7bebe7d11dd9ceb2bd9582074931ec4e53;hb=b80e9503feea2e66c0bcc2b45b413aad1a9a61e2;hp=1141a8a84a13418aed63f7cbd27ddb8f0bd61ee9;hpb=6ff15cc813aa4575144e1287747b5468f56c84aa;p=lyx.git diff --git a/src/InsetList.h b/src/InsetList.h index 1141a8a84a..36a40c7beb 100644 --- a/src/InsetList.h +++ b/src/InsetList.h @@ -4,7 +4,7 @@ * This file is part of LyX, the document processor. * Licence details can be found in the file COPYING. * - * \author Lars Gullik Bjønnes + * \author Lars Gullik Bjønnes * * Full author contact details are available in file CREDITS. */ @@ -12,25 +12,42 @@ #ifndef INSET_LIST_H #define INSET_LIST_H +#include "insets/InsetCode.h" + #include "support/types.h" #include -class InsetOld; -class Buffer; +namespace lyx { + +class Inset; +class Buffer; /// class InsetList { public: /// - struct InsetTable { + InsetList() {} + /// + InsetList(InsetList const &); + /// Partial copy constructor. + /// Copy the InsetList contents from \p beg to \p end (without end). + InsetList(InsetList const &, pos_type beg, pos_type end); + /// + void setBuffer(Buffer &); + /// + void resetBuffer(); + + /// + class InsetTable { + public: /// - lyx::pos_type pos; + InsetTable(pos_type p, Inset * i) : pos(p), inset(i) {} /// - InsetOld * inset; + pos_type pos; /// - InsetTable(lyx::pos_type p, InsetOld * i) : pos(p), inset(i) {} + Inset * inset; }; /// typedef std::vector List; @@ -42,35 +59,53 @@ public: /// ~InsetList(); /// - iterator begin(); + iterator begin() { return list_.begin(); } /// - iterator end(); + iterator end() { return list_.end(); } /// - const_iterator begin() const; + const_iterator begin() const { return list_.begin(); } /// - const_iterator end() const; + const_iterator end() const { return list_.end(); } /// - iterator insetIterator(lyx::pos_type pos); + bool empty() const { return list_.empty(); } /// - const_iterator insetIterator(lyx::pos_type pos) const; + iterator insetIterator(pos_type pos); /// - void insert(InsetOld * inset, lyx::pos_type pos); + const_iterator insetIterator(pos_type pos) const; /// - void erase(lyx::pos_type pos); + void insert(Inset * inset, pos_type pos); /// - InsetOld * release(lyx::pos_type); + void erase(pos_type pos); /// - InsetOld * get(lyx::pos_type pos) const; + Inset * release(pos_type); /// - void increasePosAfterPos(lyx::pos_type pos); + Inset * get(pos_type pos) const; /// - void decreasePosAfterPos(lyx::pos_type pos); + void increasePosAfterPos(pos_type pos); /// - void insetsOpenCloseBranch(Buffer const & buf); + void decreasePosAfterPos(pos_type pos); + + /// search for next occurence of an \c Inset type. + /// \return the position of the found inset. + /// \retval -1 if no \c Inset is found. + pos_type find( + InsetCode code, ///< Code of inset to find. + pos_type startpos = 0 ///< start position for the search. + ) const; + + /// count occurrences of an \c Inset type. + /// \return the number of found inset(s). + int count( + InsetCode code, ///< Code of inset type to count. + pos_type startpos = 0 ///< start position for the counting. + ) const; private: /// - List list; + List list_; }; + +} // namespace lyx + #endif