// -*- C++ -*- /* \file iterators.h * This file is part of LyX, the document processor. * Licence details can be found in the file COPYING. * * \author unknown * \author Lars Gullik Bjønnes * * Full author contact details are available in file CREDITS. */ #ifndef ITERATORS_H #define ITERATORS_H #include "ParagraphList_fwd.h" #include class LyXText; class InsetOld; class ParIterator { public: /// ParIterator(ParagraphList::iterator pit, ParagraphList const & pl); /// ~ParIterator(); /// ParIterator(ParIterator const &); /// void operator=(ParIterator const &); /// ParIterator & operator++(); /// Paragraph & operator*() const; /// ParagraphList::iterator operator->() const; /// This gives us the top-most parent paragraph ParagraphList::iterator outerPar() const; /// ParagraphList::iterator pit() const; /// ParagraphList & plist() const; /// returns 'innermost' LyXText if in an inset or '0' instead of //bv->text LyXText * text() const; /// InsetOld * inset() const; /// size_t size() const; /// friend bool operator==(ParIterator const & iter1, ParIterator const & iter2); private: struct Pimpl; boost::scoped_ptr pimpl_; }; /// bool operator==(ParIterator const & iter1, ParIterator const & iter2); /// bool operator!=(ParIterator const & iter1, ParIterator const & iter2); class ParConstIterator { public: /// ParConstIterator(ParagraphList::iterator pit, ParagraphList const & pl); /// ~ParConstIterator(); /// ParConstIterator(ParConstIterator const &); /// ParConstIterator & operator++(); /// ParagraphList::const_iterator pit() const; /// Paragraph const & operator*() const; /// ParagraphList::const_iterator operator->() const; /// ParagraphList const & plist() const; /// depth of nesting size_t size() const; /// friend bool operator==(ParConstIterator const & iter1, ParConstIterator const & iter2); private: struct Pimpl; boost::scoped_ptr pimpl_; }; bool operator==(ParConstIterator const & iter1, ParConstIterator const & iter2); bool operator!=(ParConstIterator const & iter1, ParConstIterator const & iter2); #endif