X-Git-Url: https://git.lyx.org/gitweb/?a=blobdiff_plain;f=src%2Fmathed%2FInsetMathNest.h;h=80f5f6d9d67f3a46f4f78a4f8a0ac20dac607e39;hb=5fdc577badb1cb133d6a0dc7d831bb1f82576adb;hp=275d2731f3860425718cea0f2eb1704d5893573d;hpb=224fb0b4b522ff89b9c6145125d80d51b68f61ee;p=lyx.git diff --git a/src/mathed/InsetMathNest.h b/src/mathed/InsetMathNest.h index 275d2731f3..80f5f6d9d6 100644 --- a/src/mathed/InsetMathNest.h +++ b/src/mathed/InsetMathNest.h @@ -4,7 +4,7 @@ * This file is part of LyX, the document processor. * Licence details can be found in the file COPYING. * - * \author André Pönitz + * \author André Pönitz * * Full author contact details are available in file CREDITS. */ @@ -13,9 +13,9 @@ #define MATH_NESTINSET_H #include "InsetMath.h" +#include "MathData.h" -// FIXME: remove -#include "support/docstring.h" +#include namespace lyx { @@ -27,13 +27,23 @@ 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 method below hides inset::metrics() intentionally! + // We have to tell clang not to be fussy about that. +#ifdef __clang__ +#pragma clang diagnostic push +#pragma clang diagnostic ignored "-Woverloaded-virtual" +#endif /// the size is usually some sort of convex hull of the cells - /// hides inset::metrics() intentionally! void metrics(MetricsInfo const & mi) const; +#ifdef __clang__ +#pragma clang diagnostic pop +#endif /// draw background if locked void draw(PainterInfo & pi, int x, int y) const; /// draw selection background @@ -41,6 +51,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 +90,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 +117,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; @@ -127,6 +140,8 @@ public: bool insertCompletion(Cursor & cur, docstring const & s, bool finished); /// void completionPosAndDim(Cursor const &, int & x, int & y, Dimension & dim) const; + /// + InsetCode lyxCode() const { return MATH_NEST_CODE; } protected: /// @@ -163,7 +178,7 @@ public: /// interpret \p str and insert the result at the current position of /// \p cur if it is something known. Return whether \p cur was /// inserted. - bool interpretString(Cursor & cur, docstring const & str); + virtual bool interpretString(Cursor & cur, docstring const & str); private: /// lfun handler @@ -176,9 +191,9 @@ private: /// afterwards if found bool findMacroToFoldUnfold(Cursor & searchCur, bool fold) const; /// move cursor forward - bool cursorMathForward(Cursor & cur); + bool cursorMathForward(Cursor & cur, bool enter = true); /// move cursor backwards - bool cursorMathBackward(Cursor & cur); + bool cursorMathBackward(Cursor & cur, bool enter = true); protected: /// we store the cells in a vector @@ -188,8 +203,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_; +};