X-Git-Url: https://git.lyx.org/gitweb/?a=blobdiff_plain;f=src%2FInsetList.cpp;h=f5f8cf27029f252c770d4db5113fe1d2dc8e51a2;hb=62af7ee772f16f154225d2d0b65d77f4376b6001;hp=5f6398b48c56d5eb62c923f5fa2b1ac314edf0fa;hpb=1026a87b72ee7f2b2e3fe69577b68c228ebbde88;p=lyx.git diff --git a/src/InsetList.cpp b/src/InsetList.cpp index 5f6398b48c..f5f8cf2702 100644 --- a/src/InsetList.cpp +++ b/src/InsetList.cpp @@ -3,7 +3,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 * \author Martin Vermeer * * Full author contact details are available in file CREDITS. @@ -13,61 +13,96 @@ #include "InsetList.h" -#include "Buffer.h" -#include "BufferParams.h" -#include "BranchList.h" -#include "debug.h" +#include "insets/Inset.h" -#include "insets/InsetBranch.h" +#include "support/debug.h" -using std::endl; -using std::lower_bound; +#include +using namespace std; namespace lyx { namespace { -typedef InsetList::InsetTable Table; +typedef InsetList::Element Table; -class InsetTablePosLess : public std::binary_function { -public: +struct ElementPosLess +{ bool operator()(Table const & t1, Table const & t2) const { return t1.pos < t2.pos; } }; -} // namespace anon +} // namespace +InsetList::InsetList(InsetList const & il) : list_(il.list_) +{ + List::iterator it = list_.begin(); + List::iterator end = list_.end(); + for (; it != end; ++it) + it->inset = it->inset->clone(); +} + + +InsetList::InsetList(InsetList const & il, pos_type beg, pos_type end) +{ + InsetList::const_iterator cit = il.begin(); + InsetList::const_iterator cend = il.end(); + for (; cit != cend; ++cit) { + if (cit->pos < beg) + continue; + if (cit->pos >= end) + break; + // Add a new entry in the insetlist_. + insert(cit->inset->clone(), cit->pos - beg); + } +} + InsetList::~InsetList() { - // If we begin storing a shared_ptr in the List - // this code can be removed. (Lgb) List::iterator it = list_.begin(); List::iterator end = list_.end(); - for (; it != end; ++it) { + for (; it != end; ++it) delete it->inset; - } +} + + +void InsetList::setBuffer(Buffer & b) +{ + List::iterator it = list_.begin(); + List::iterator end = list_.end(); + for (; it != end; ++it) + it->inset->setBuffer(b); +} + + +void InsetList::resetBuffer() +{ + List::iterator it = list_.begin(); + List::iterator end = list_.end(); + for (; it != end; ++it) + it->inset->resetBuffer(); } InsetList::iterator InsetList::insetIterator(pos_type pos) { - InsetTable search_elem(pos, 0); + Element search_elem(pos, 0); return lower_bound(list_.begin(), list_.end(), search_elem, - InsetTablePosLess()); + ElementPosLess()); } InsetList::const_iterator InsetList::insetIterator(pos_type pos) const { - InsetTable search_elem(pos, 0); + Element search_elem(pos, 0); return lower_bound(list_.begin(), list_.end(), search_elem, - InsetTablePosLess()); + ElementPosLess()); } @@ -76,10 +111,10 @@ void InsetList::insert(Inset * inset, pos_type pos) List::iterator end = list_.end(); List::iterator it = insetIterator(pos); if (it != end && it->pos == pos) { - lyxerr << "ERROR (InsetList::insert): " - << "There is an inset in position: " << pos << endl; + LYXERR0("ERROR (InsetList::insert): " + << "There is an inset in position: " << pos); } else { - list_.insert(it, InsetTable(pos, inset)); + list_.insert(it, Element(pos, inset)); } } @@ -122,9 +157,8 @@ void InsetList::increasePosAfterPos(pos_type pos) { List::iterator end = list_.end(); List::iterator it = insetIterator(pos); - for (; it != end; ++it) { + for (; it != end; ++it) ++it->pos; - } } @@ -132,19 +166,8 @@ void InsetList::decreasePosAfterPos(pos_type pos) { List::iterator end = list_.end(); List::iterator it = insetIterator(pos); - for (; it != end; ++it) { - --it->pos; - } -} - - -InsetList::InsetList(InsetList const & il) -{ - list_ = il.list_; - List::iterator it = list_.begin(); - List::iterator end = list_.end(); for (; it != end; ++it) - it->inset = it->inset->clone(); + --it->pos; }