#ifndef CURSORSLICE_H
#define CURSORSLICE_H
+#include "insets/insetbase.h"
+#include "support/types.h"
+
#include <cstddef>
#include <iosfwd>
-#include "support/types.h"
+
+namespace lyx {
class BufferView;
class InsetBase;
class MathArray;
class LyXText;
class Paragraph;
-class UpdatableInset;
-
/// This encapsulates a single slice of a document iterator as used e.g.
/// for cursors.
-// After IU, the distinction of MathInset and UpdatableInset as well as
+// After IU, the distinction of MathInset and InsetOld as well as
// that of MathArray and LyXText should vanish. They are conceptually the
// same (now...)
public:
/// type for cell number in inset
typedef size_t idx_type;
- /// type for paragraph numbers positions within a cell
- typedef lyx::paroffset_type par_type;
- /// type for cursor positions within a cell
- typedef lyx::pos_type pos_type;
/// type for row indices
typedef size_t row_type;
/// type for col indices
///
CursorSlice();
///
- explicit CursorSlice(InsetBase *);
+ explicit CursorSlice(InsetBase &);
/// the current inset
- InsetBase * inset() const { return inset_; }
- /// set the paragraph that contains this cursor
- void idx(idx_type idx);
+ InsetBase & inset() const { return *inset_; }
/// return the cell this cursor is in
- idx_type idx() const;
+ idx_type idx() const { return idx_; }
/// return the cell this cursor is in
- idx_type & idx();
+ idx_type & idx() { return idx_; }
/// return the last cell in this inset
idx_type lastidx() const { return nargs() - 1; }
- /// set the paragraph that contains this cursor
- void par(par_type par);
- /// return the paragraph this cursor is in
- par_type par() const;
- /// return the paragraph this cursor is in
- par_type & par();
- /// set the position within the paragraph
- void pos(pos_type pos);
+ /// return the offset of the paragraph this cursor is in
+ pit_type pit() const { return pit_; }
+ /// set the offset of the paragraph this cursor is in
+ pit_type & pit() { return pit_; }
+ /// increments the paragraph this cursor is in
+ void incrementPar();
+ /// decrements the paragraph this cursor is in
+ void decrementPar();
/// return the position within the paragraph
- pos_type pos() const;
+ pos_type pos() const { return pos_; }
/// return the position within the paragraph
- pos_type & pos();
+ pos_type & pos() { return pos_; }
/// return the last position within the paragraph
pos_type lastpos() const;
/// return the number of embedded cells
- size_t nargs() const;
- /// return the number of embedded cells
- size_t ncols() const;
- /// return the number of embedded cells
- size_t nrows() const;
- /// return the grid row of the current cell
+ size_t nargs() const { return inset_->nargs(); }
+ /// return the number of columns (1 in non-grid-like insets)
+ size_t ncols() const { return inset_->ncols(); }
+ /// return the number of rows (1 in non-grid-like insets)
+ size_t nrows() const { return inset_->nrows(); }
+ /*!
+ * \return the grid row of the current cell.
+ * This does only make sense in grid like insets.
+ */
row_type row() const;
- /// return the grid row of the current cell
+ /*!
+ * \return the grid column of the current cell.
+ * This does only make sense in grid like insets.
+ */
col_type col() const;
///
/// texted specific stuff
///
- /// see comment for the member
- void boundary(bool b);
- /// see comment for the member
- bool boundary() const;
- /// see comment for the member
- bool & boundary();
- ///
- LyXText * text() const;
- ///
- UpdatableInset * asUpdatableInset() const;
- ///
+ /// returns text corresponding to this position
+ LyXText * text() { return inset_->getText(idx_); }
+ /// returns text corresponding to this position
+ LyXText const * text() const { return inset_->getText(idx_); }
+ /// paragraph in this cell
Paragraph & paragraph();
- ///
+ /// paragraph in this cell
Paragraph const & paragraph() const;
///
/// mathed specific stuff
///
+ /// returns the owning inset if it is a InsetMath, else 0
+ InsetMath * asInsetMath() const { return inset_->asInsetMath(); }
/// returns cell corresponding to this position
MathArray & cell() const;
- ///
- MathInset * asMathInset() const;
- ///
+ /// write some debug information to \p os
friend std::ostream & operator<<(std::ostream &, CursorSlice const &);
public:
- /// pointer to 'owning' inset
+ /// pointer to 'owning' inset. This is some kind of cache.
InsetBase * inset_;
- /// cell index of a position in this inset
+private:
+ /*!
+ * Cell index of a position in this inset.
+ * This is the primary cell information also for grid like insets,
+ * although we have the convenience functions row() and col() for
+ * those * and column changes every time the number of columns ornumber
+ * of rows changes. Normally the cursor should stay in the same cell,
+ * so these changes should typically be performed like the following:
+ * \code
+ * row_type const r = cur.row();
+ * col_type const c = cur.col();
+ * // change nrows() and/or ncols()
+ * cur.idx = index(r, c);
+ * \endcode
+ */
idx_type idx_;
/// paragraph in this cell (used by texted)
- par_type par_;
+ pit_type pit_;
+ /// true if 'pit' was properly initialized
+ bool pit_valid_;
/// position in this cell
pos_type pos_;
- /**
- * When the cursor position is i, is the cursor is after the i-th char
- * or before the i+1-th char ? Normally, these two interpretations are
- * equivalent, except when the fonts of the i-th and i+1-th char
- * differ.
- * We use boundary_ to distinguish between the two options:
- * If boundary_=true, then the cursor is after the i-th char
- * and if boundary_=false, then the cursor is before the i+1-th char.
- *
- * We currently use the boundary only when the language direction of
- * the i-th char is different than the one of the i+1-th char.
- * In this case it is important to distinguish between the two
- * cursor interpretations, in order to give a reasonable behavior to
- * the user.
- */
- bool boundary_;
};
/// test for equality
bool operator<(CursorSlice const &, CursorSlice const &);
/// test for order
bool operator>(CursorSlice const &, CursorSlice const &);
+/// test for order
+bool operator<=(CursorSlice const &, CursorSlice const &);
+
+
+} // namespace lyx
#endif