3 * This file is part of LyX, the document processor.
4 * Licence details can be found in the file COPYING.
6 * \author Alfredo Braunstein
8 * Full author contact details are available in file CREDITS.
14 #include "ParagraphList_fwd.h"
16 #include "iterators.h"
18 #include "support/types.h"
25 struct PosIteratorItem
27 PosIteratorItem(ParagraphList * pl,
28 ParagraphList::iterator pit,
31 : pl(pl), pit(pit), pos(pos), index(index) {};
33 ParagraphList::iterator pit;
42 PosIterator(BufferView & bv);
43 PosIterator(ParIterator & par, lyx::pos_type pos);
44 PosIterator(ParagraphList * pl, ParagraphList::iterator pit,
46 PosIterator(ParIterator const & parit, lyx::pos_type p);
47 PosIterator & operator++();
48 PosIterator & operator--();
49 friend bool operator==(PosIterator const &, PosIterator const &);
51 ParagraphList::iterator pit() const { return stack_.back().pit; }
52 lyx::pos_type pos() const { return stack_.back().pos; }
54 InsetOld * inset() const;
55 friend PosIterator ParIterator::asPosIterator(lyx::pos_type) const;
56 friend ParIterator::ParIterator(PosIterator const &);
60 //this is conceptually a stack, but we need random access sometimes
61 std::vector<PosIteratorItem> stack_;
64 bool operator!=(PosIterator const &, PosIterator const &);
65 bool operator==(PosIterator const &, PosIterator const &);
67 int distance(PosIterator const &, PosIterator const &);
68 void advance(PosIterator &, int);