]> git.lyx.org Git - lyx.git/blobdiff - src/mathed/InsetMathNest.h
visual mode for bidi cursor movement
[lyx.git] / src / mathed / InsetMathNest.h
index 41387136d69b4629cefa6625682e589c1fa3fcf6..408d13a05b5c70623dab04abd1ee0d12790a2f91 100644 (file)
@@ -27,6 +27,8 @@ class InsetMathNest : public InsetMath {
 public:
        /// nestinsets have a fixed size to start with
        explicit InsetMathNest(idx_type ncells);
+       ///
+       virtual ~InsetMathNest() {}
 
        /// the size is usually some sort of convex hull of the cells
        /// hides inset::metrics() intentionally!
@@ -46,23 +48,24 @@ public:
        void cursorPos(BufferView const & bv, CursorSlice const & sl,
                bool boundary, int & x, int & y) const;
        ///
-       void edit(Cursor & cur, bool left);
+       void edit(Cursor & cur, bool front, 
+               EntryDirectionType entry_from = IGNORE_ENTRY_DIRECTION);
        ///
        Inset * editXY(Cursor & cur, int x, int y);
 
-       /// order of movement through the cells when pressing the left key
-       bool idxLeft(Cursor &) const;
-       /// order of movement through the cells when pressing the right key
-       bool idxRight(Cursor &) const;
+       /// order of movement through the cells when moving backwards
+       bool idxBackward(Cursor &) const;
+       /// order of movement through the cells when moving forward
+       bool idxForward(Cursor &) const;
 
-       /// move one physical cell up
+       /// move to next cell
        bool idxNext(Cursor &) const;
-       /// move one physical cell down
+       /// move to previous cell
        bool idxPrev(Cursor &) const;
 
-       /// target pos when we enter the inset from the left by pressing "Right"
+       /// target pos when we enter the inset while moving forward
        bool idxFirst(Cursor &) const;
-       /// target pos when we enter the inset from the right by pressing "Left"
+       /// target pos when we enter the inset while moving backwards
        bool idxLast(Cursor &) const;
 
        /// number of cells currently governed by us
@@ -103,8 +106,17 @@ public:
        ///
        int latex(Buffer const &, odocstream & os,
                        OutputParams const & runparams) const;
+       ///
+       bool setMouseHover(bool mouse_hover);
+       ///
+       bool mouseHovered() const { return mouse_hover_; }
 
 protected:
+       ///
+       InsetMathNest(InsetMathNest const & inset);
+       ///
+       InsetMathNest & operator=(InsetMathNest const &);
+
        ///
        virtual void doDispatch(Cursor & cur, FuncRequest & cmd);
        /// do we want to handle this event?
@@ -138,6 +150,9 @@ private:
        void lfunMouseRelease(Cursor &, FuncRequest &);
        ///
        void lfunMouseMotion(Cursor &, FuncRequest &);
+       /// Find a macro to fold or unfold, starting at searchCur and searchCur.nextInset() pointing to a macro
+       /// afterwards if found
+       bool findMacroToFoldUnfold(Cursor & searchCur, bool fold) const;
 
 protected:
        /// we store the cells in a vector
@@ -146,6 +161,8 @@ protected:
        cells_type cells_;
        /// if the inset is locked, it can't be entered with the cursor
        bool lock_;
+       ///
+       bool mouse_hover_;
 };