X-Git-Url: https://git.lyx.org/gitweb/?a=blobdiff_plain;f=src%2Fmathed%2FInsetMathNest.h;h=4e18dbda71e25d787945371e654213922e212474;hb=981e958b9d63930c83b1adced65b75b3d857ac97;hp=7b320e61c3b4008788af704bbd2b76ff3d1dbc2c;hpb=0facb603fefec1ecc927f77bcf6228ca1f035444;p=lyx.git diff --git a/src/mathed/InsetMathNest.h b/src/mathed/InsetMathNest.h index 7b320e61c3..4e18dbda71 100644 --- a/src/mathed/InsetMathNest.h +++ b/src/mathed/InsetMathNest.h @@ -17,6 +17,8 @@ // FIXME: remove #include "support/docstring.h" +#include + namespace lyx { /** Abstract base class for all math objects that contain nested items. @@ -27,9 +29,11 @@ namespace lyx { class InsetMathNest : public InsetMath { public: /// nestinsets have a fixed size to start with - explicit InsetMathNest(idx_type ncells); + InsetMathNest(Buffer * buf, idx_type ncells); + /// + virtual ~InsetMathNest(); /// - virtual ~InsetMathNest() {} + void setBuffer(Buffer &); /// the size is usually some sort of convex hull of the cells /// hides inset::metrics() intentionally! @@ -41,6 +45,8 @@ public: /// draw decorations. void drawDecoration(PainterInfo & pi, int x, int y) const { drawMarkers(pi, x, y); } + /// + void updateBuffer(ParIterator const &, UpdateType); /// identifies NestInsets InsetMathNest * asNestInset() { return this; } /// identifies NestInsets @@ -78,9 +84,9 @@ public: /// get notification when the cursor leaves this inset bool notifyCursorLeaves(Cursor const & old, Cursor & cur); - /// direct access to the cell. - /// inlined because shows in profile. //@{ + /// direct access to the cell. + /// Inlined because of performance reasons. MathData & cell(idx_type i) { return cells_[i]; } MathData const & cell(idx_type i) const { return cells_[i]; } //@} @@ -105,11 +111,12 @@ public: /// writes [, name(), and args in [] void normalize(NormalStream & os) const; /// - int latex(odocstream & os, OutputParams const & runparams) const; + void latex(otexstream & os, OutputParams const & runparams) const; /// - bool setMouseHover(bool mouse_hover); + bool setMouseHover(BufferView const * bv, bool mouse_hover) const; /// - bool mouseHovered() const { return mouse_hover_; } + bool mouseHovered(BufferView const * bv) const + { return mouse_hover_[bv]; } /// bool completionSupported(Cursor const &) const; @@ -190,8 +197,8 @@ protected: /// if the inset is locked, it can't be entered with the cursor bool lock_; /// - bool mouse_hover_; -}; + mutable std::map mouse_hover_; +};