X-Git-Url: https://git.lyx.org/gitweb/?a=blobdiff_plain;f=src%2FInsetList.h;h=708eab86fa0377ca7bd56e6bfc10ebfb820594c3;hb=801d7dc9f42baf331642606a6641606779985439;hp=6f86f3a444bde628b056c0fd500ae18cc231b16e;hpb=3159d1a52e777f62531932edc010bf5f8b9d6d59;p=lyx.git diff --git a/src/InsetList.h b/src/InsetList.h index 6f86f3a444..708eab86fa 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,28 +12,45 @@ #ifndef INSET_LIST_H #define INSET_LIST_H +#include "insets/InsetCode.h" + #include "support/types.h" #include -class InsetOld; -class BufferView; +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 Element { + public: /// - lyx::pos_type pos; + Element(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; + typedef std::vector List; /// typedef List::iterator iterator; /// @@ -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(BufferView * bv); + 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