#include "buffer.h"
#include "bufferparams.h"
+#include "BranchList.h"
#include "BufferView.h"
#include "debug.h"
using std::endl;
using std::lower_bound;
-
namespace {
-struct MatchIt {
- /// used by lower_bound
- inline
- int operator()(InsetList::InsetTable const & a,
- InsetList::InsetTable const & b) const
+class InsetTablePosLess : public std::binary_function<InsetList::InsetTable, InsetList::InsetTable, bool> {
+public:
+ bool operator()(InsetList::InsetTable const & t1,
+ InsetList::InsetTable const & t2) const
{
- return a.pos < b.pos;
+ return t1.pos < t2.pos;
}
};
} // namespace anon
-
InsetList::~InsetList()
{
// If we begin storing a shared_ptr in the List
}
-InsetList::iterator InsetList::begin()
-{
- return list.begin();
-}
-
-
-InsetList::iterator InsetList::end()
-{
- return list.end();
-}
-
-
-InsetList::const_iterator InsetList::begin() const
-{
- return list.begin();
-}
-
-
-InsetList::const_iterator InsetList::end() const
-{
- return list.end();
-}
-
-
InsetList::iterator InsetList::insetIterator(pos_type pos)
{
InsetTable search_elem(pos, 0);
- return lower_bound(list.begin(), list.end(), search_elem, MatchIt());
+ return lower_bound(list.begin(), list.end(), search_elem,
+ InsetTablePosLess());
}
InsetList::const_iterator InsetList::insetIterator(pos_type pos) const
{
InsetTable search_elem(pos, 0);
- return lower_bound(list.begin(), list.end(), search_elem, MatchIt());
+ return lower_bound(list.begin(), list.end(), search_elem,
+ InsetTablePosLess());
}
List::iterator it = list.begin();
List::iterator end = list.end();
for (; it != end; ++it) {
- if (it->inset && it->inset->lyxCode() == InsetOld::BRANCH_CODE) {
- InsetBranch * inset = static_cast<InsetBranch *>(it->inset);
- if (buf.params().branchlist().selected(inset->params().branch)) {
- inset->open();
- } else {
- inset->close();
- }
+ if (!it->inset ||
+ it->inset->lyxCode() != InsetOld::BRANCH_CODE)
+ continue;
+
+ InsetBranch * inset = static_cast<InsetBranch *>(it->inset);
+ if (inset->isBranchSelected(buf.params().branchlist())) {
+ inset->open();
+ } else {
+ inset->close();
}
}
}