]> git.lyx.org Git - lyx.git/blobdiff - src/cursor_slice.C
Tweak layout in GToc
[lyx.git] / src / cursor_slice.C
index e1c06bcf7c4e9c4403e1f85fca5168b84ce4e575..eda679a2e95750fa10c79da8517003c57dd63ba3 100644 (file)
 #include "mathed/math_inset.h"
 #include "mathed/math_data.h"
 
-#include "insets/updatableinset.h"
-
-
 #include <boost/assert.hpp>
 
 using std::endl;
 
 
 CursorSlice::CursorSlice()
-       : inset_(0), idx_(0), par_(0), pos_(0), boundary_(false)
+       : inset_(0), idx_(0), pit_(0), pos_(0)
 {}
 
 
-CursorSlice::CursorSlice(InsetBase * p)
-       : inset_(p), idx_(0), par_(0), pos_(0), boundary_(false)
-{
-       ///BOOST_ASSERT(inset_);
-}
-
-
-void CursorSlice::idx(idx_type idx)
-{
-       idx_ = idx;
-}
-
-
-size_t CursorSlice::nargs() const
-{
-       return inset_->nargs();
-}
-
-
-size_t CursorSlice::nrows() const
-{
-       return inset_->nrows();
-}
-
-
-size_t CursorSlice::ncols() const
-{
-       return inset_->ncols();
-}
-
-
-CursorSlice::idx_type CursorSlice::idx() const
+CursorSlice::CursorSlice(InsetBase & p)
+       : inset_(&p), idx_(0), pit_(0), pos_(0)
 {
-       return idx_;
+       BOOST_ASSERT(inset_);
 }
 
 
-CursorSlice::idx_type & CursorSlice::idx()
-{
-       return idx_;
-}
-
-
-void CursorSlice::par(par_type par)
-{
-       par_ = par;
-}
-
-
-CursorSlice::par_type CursorSlice::par() const
-{
-       return par_;
-}
-
-
-CursorSlice::par_type & CursorSlice::par()
-{
-       return par_;
-}
-
-
-void CursorSlice::pos(pos_type pos)
+MathArray & CursorSlice::cell() const
 {
-       pos_ = pos;
+       return inset_->asMathInset()->cell(idx_);
 }
 
 
-CursorSlice::pos_type CursorSlice::pos() const
+Paragraph & CursorSlice::paragraph()
 {
-       return pos_;
+       return text()->getPar(pit_);
 }
 
 
-CursorSlice::pos_type & CursorSlice::pos()
+Paragraph const & CursorSlice::paragraph() const
 {
-       return pos_;
+       return text()->getPar(pit_);
 }
 
 
 CursorSlice::pos_type CursorSlice::lastpos() const
 {
-       return (inset_ && inset_->asMathInset()) ? cell().size() : paragraph().size();
-}
-
-
-void CursorSlice::boundary(bool boundary)
-{
-       boundary_ = boundary;
-}
-
-
-bool CursorSlice::boundary() const
-{
-       return boundary_;
-}
-
-
-bool & CursorSlice::boundary()
-{
-       return boundary_;
+       BOOST_ASSERT(inset_);
+       return inset_->asMathInset() ? cell().size() : paragraph().size();
 }
 
 
@@ -151,77 +77,36 @@ CursorSlice::col_type CursorSlice::col() const
 }
 
 
-MathInset * CursorSlice::asMathInset() const
-{
-       return inset_ ? inset_->asMathInset() : 0;
-}
-
-
-UpdatableInset * CursorSlice::asUpdatableInset() const
-{
-       return inset_ ? inset_->asUpdatableInset() : 0;
-}
-
-
-MathArray & CursorSlice::cell() const
-{
-       BOOST_ASSERT(asMathInset());
-       return asMathInset()->cell(idx_);
-}
-
-
-LyXText * CursorSlice::text() const
-{
-       return inset_ ? inset_->getText(idx_) : 0;
-}
-
-
-Paragraph & CursorSlice::paragraph()
-{
-       // access to the main lyx text must be handled in the cursor
-       BOOST_ASSERT(text());
-       return *text()->getPar(par_);
-}
-
-
-Paragraph const & CursorSlice::paragraph() const
-{
-       // access to the main lyx text must be handled in the cursor
-       BOOST_ASSERT(text());
-       return *text()->getPar(par_);
-}
-
-
 bool operator==(CursorSlice const & p, CursorSlice const & q)
 {
-       return p.inset_ == q.inset_
-              && p.idx_ == q.idx_
-              && p.par_ == q.par_
-              && p.pos_ == q.pos_;
+       return &p.inset() == &q.inset()
+              && p.idx() == q.idx()
+              && p.pit() == q.pit()
+              && p.pos() == q.pos();
 }
 
 
 bool operator!=(CursorSlice const & p, CursorSlice const & q)
 {
-       return p.inset_ != q.inset_
-              || p.idx_ != q.idx_
-              || p.par_ != q.par_
-              || p.pos_ != q.pos_;
+       return &p.inset() != &q.inset()
+              || p.idx() != q.idx()
+              || p.pit() != q.pit()
+              || p.pos() != q.pos();
 }
 
 
 bool operator<(CursorSlice const & p, CursorSlice const & q)
 {
-       if (p.inset_ != q.inset_) {
+       if (&p.inset() != &q.inset()) {
                lyxerr << "can't compare cursor and anchor in different insets\n"
                       << "p: " << p << '\n' << "q: " << q << endl;
-               return true;
+               BOOST_ASSERT(false);
        }
-       if (p.idx_ != q.idx_)
-               return p.idx_ < q.idx_;
-       if (p.par_ != q.par_)
-               return p.par_ < q.par_;
-       return p.pos_ < q.pos_;
+       if (p.idx() != q.idx())
+               return p.idx() < q.idx();
+       if (p.pit() != q.pit())
+               return p.pit() < q.pit();
+       return p.pos() < q.pos();
 }
 
 
@@ -231,15 +116,21 @@ bool operator>(CursorSlice const & p, CursorSlice const & q)
 }
 
 
+bool operator<=(CursorSlice const & p, CursorSlice const & q)
+{
+       return !(q < p);
+}
+
+
 std::ostream & operator<<(std::ostream & os, CursorSlice const & item)
 {
-       os << "inset: " << item.inset_
-          << " text: " << item.text()
-          << " idx: " << item.idx_
-//        << " par: " << item.par_
-          << " pos: " << item.pos_
-//        << " x: " << item.inset_->x()
-//        << " y: " << item.inset_->y()
+       return os
+          << "inset: " << &item.inset()
+//        << " text: " << item.text()
+          << " idx: " << item.idx()
+          << " par: " << item.pit()
+          << " pos: " << item.pos()
+//        << " x: " << item.inset().x()
+//        << " y: " << item.inset().y()
 ;
-       return os;
 }