X-Git-Url: https://git.lyx.org/gitweb/?a=blobdiff_plain;f=src%2Fcursor_slice.C;h=f891844e196547906fa8ac0d54d414290325c0ab;hb=32d281cba0a2e4d0e8425a34a1a8d1f5e7251412;hp=7528be9d4337a6248f5777747a4065cb43748148;hpb=1b3f5ee46ff2924c4b374f52ad6317b5fd7ac9a5;p=lyx.git diff --git a/src/cursor_slice.C b/src/cursor_slice.C index 7528be9d43..f891844e19 100644 --- a/src/cursor_slice.C +++ b/src/cursor_slice.C @@ -37,7 +37,7 @@ CursorSlice::CursorSlice() CursorSlice::CursorSlice(InsetBase & p) : inset_(&p), idx_(0), par_(0), pos_(0), boundary_(false) { - ///BOOST_ASSERT(inset_); + BOOST_ASSERT(inset_); } @@ -62,42 +62,6 @@ size_t CursorSlice::ncols() const } -CursorSlice::idx_type CursorSlice::idx() const -{ - return idx_; -} - - -CursorSlice::idx_type & CursorSlice::idx() -{ - return idx_; -} - - -CursorSlice::par_type CursorSlice::par() const -{ - return par_; -} - - -CursorSlice::par_type & CursorSlice::par() -{ - return par_; -} - - -CursorSlice::pos_type CursorSlice::pos() const -{ - return pos_; -} - - -CursorSlice::pos_type & CursorSlice::pos() -{ - return pos_; -} - - CursorSlice::pos_type CursorSlice::lastpos() const { BOOST_ASSERT(inset_); @@ -105,18 +69,6 @@ CursorSlice::pos_type CursorSlice::lastpos() const } -bool CursorSlice::boundary() const -{ - return boundary_; -} - - -bool & CursorSlice::boundary() -{ - return boundary_; -} - - CursorSlice::row_type CursorSlice::row() const { BOOST_ASSERT(asMathInset()); @@ -163,7 +115,7 @@ Paragraph & CursorSlice::paragraph() { // access to the main lyx text must be handled in the cursor BOOST_ASSERT(text()); - return *text()->getPar(par_); + return text()->getPar(par_); } @@ -171,40 +123,40 @@ Paragraph const & CursorSlice::paragraph() const { // access to the main lyx text must be handled in the cursor BOOST_ASSERT(text()); - return *text()->getPar(par_); + 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.par() == q.par() + && 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.par() != q.par() + || 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.par() != q.par()) + return p.par() < q.par(); + return p.pos() < q.pos(); } @@ -214,15 +166,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) { return os - << "inset: " << item.inset_ + << "inset: " << &item.inset() // << " text: " << item.text() - << " idx: " << item.idx_ - << " par: " << item.par_ - << " pos: " << item.pos_ -// << " x: " << item.inset_->x() -// << " y: " << item.inset_->y() + << " idx: " << item.idx() + << " par: " << item.par() + << " pos: " << item.pos() +// << " x: " << item.inset().x() +// << " y: " << item.inset().y() ; }