]> git.lyx.org Git - lyx.git/blobdiff - src/InsetList.h
ctests: categorize #12708 test file as resolved
[lyx.git] / src / InsetList.h
index 7b6a0f36790d62121b42297ba793238ae0361fc7..708eab86fa0377ca7bd56e6bfc10ebfb820594c3 100644 (file)
@@ -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.
  */
 #ifndef INSET_LIST_H
 #define INSET_LIST_H
 
+#include "insets/InsetCode.h"
+
 #include "support/types.h"
 
 #include <vector>
 
-class InsetBase;
-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 Element {
+       public:
                ///
-               lyx::pos_type pos;
+               Element(pos_type p, Inset * i) : pos(p), inset(i) {}
                ///
-               InsetBase * inset;
+               pos_type pos;
                ///
-               InsetTable(lyx::pos_type p, InsetBase * i) : pos(p), inset(i) {}
+               Inset * inset;
        };
        ///
-       typedef std::vector<InsetTable> List;
+       typedef std::vector<Element> List;
        ///
        typedef List::iterator iterator;
        ///
@@ -52,25 +69,43 @@ public:
        ///
        bool empty() const { return list_.empty(); }
        ///
-       iterator insetIterator(lyx::pos_type pos);
+       iterator insetIterator(pos_type pos);
        ///
-       const_iterator insetIterator(lyx::pos_type pos) const;
+       const_iterator insetIterator(pos_type pos) const;
        ///
-       void insert(InsetBase * inset, lyx::pos_type pos);
+       void insert(Inset * inset, pos_type pos);
        ///
-       void erase(lyx::pos_type pos);
+       void erase(pos_type pos);
        ///
-       InsetBase * release(lyx::pos_type);
+       Inset * release(pos_type);
        ///
-       InsetBase * get(lyx::pos_type pos) const;
+       Inset * get(pos_type pos) const;
        ///
-       void increasePosAfterPos(lyx::pos_type pos);
+       void increasePosAfterPos(pos_type pos);
        ///
-       void decreasePosAfterPos(lyx::pos_type pos);
+       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_;
 };
 
+
+} // namespace lyx
+
 #endif