///
virtual ~InsetMathNest();
///
- void setBuffer(Buffer &);
+ void setBuffer(Buffer &) override;
- // 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
- void metrics(MetricsInfo const & mi) const;
-#ifdef __clang__
-#pragma clang diagnostic pop
-#endif
+ /// Update the cells metrics
+ void cellsMetrics(MetricsInfo const & mi) const;
/// draw background if locked
- void draw(PainterInfo & pi, int x, int y) const;
- /// draw selection background
- void drawSelection(PainterInfo & pi, int x, int y) const;
- /// draw decorations.
- void drawDecoration(PainterInfo & pi, int x, int y) const
- { drawMarkers(pi, x, y); }
- ///
- void updateBuffer(ParIterator const &, UpdateType);
+ void draw(PainterInfo & pi, int x, int y) const override;
+ ///
+ void updateBuffer(ParIterator const &, UpdateType, bool const deleted = false) override;
/// identifies NestInsets
- InsetMathNest * asNestInset() { return this; }
+ InsetMathNest * asNestInset() override { return this; }
/// identifies NestInsets
- InsetMathNest const * asNestInset() const { return this; }
+ InsetMathNest const * asNestInset() const override { return this; }
/// get cursor position
void cursorPos(BufferView const & bv, CursorSlice const & sl,
- bool boundary, int & x, int & y) const;
+ bool boundary, int & x, int & y) const override;
///
- void edit(Cursor & cur, bool front,
- EntryDirection entry_from = ENTRY_DIRECTION_IGNORE);
+ void edit(Cursor & cur, bool front,
+ EntryDirection entry_from = ENTRY_DIRECTION_IGNORE) override;
///
- Inset * editXY(Cursor & cur, int x, int y);
+ Inset * editXY(Cursor & cur, int x, int y) override;
/// order of movement through the cells when moving backwards
- bool idxBackward(Cursor &) const;
+ bool idxBackward(Cursor &) const override;
/// order of movement through the cells when moving forward
- bool idxForward(Cursor &) const;
+ bool idxForward(Cursor &) const override;
/// move to next cell
- bool idxNext(Cursor &) const;
+ bool idxNext(Cursor &) const override;
/// move to previous cell
- bool idxPrev(Cursor &) const;
+ bool idxPrev(Cursor &) const override;
+
+ // The index of the cell entered while moving forward
+ virtual idx_type firstIdx() const { return 0; }
+ // The index of the cell entered while moving backward
+ virtual idx_type lastIdx() const { return nargs() - 1; }
/// target pos when we enter the inset while moving forward
- bool idxFirst(Cursor &) const;
+ bool idxFirst(Cursor &) const override;
/// target pos when we enter the inset while moving backwards
- bool idxLast(Cursor &) const;
+ bool idxLast(Cursor &) const override;
/// number of cells currently governed by us
- idx_type nargs() const;
+ idx_type nargs() const override;
/// access to the lock
- bool lock() const;
+ bool lock() const override;
/// access to the lock
- void lock(bool);
+ void lock(bool) override;
/// get notification when the cursor leaves this inset
- bool notifyCursorLeaves(Cursor const & old, Cursor & cur);
+ bool notifyCursorLeaves(Cursor const & old, Cursor & cur) override;
//@{
/// 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]; }
+ MathData & cell(idx_type i) override { return cells_[i]; }
+ MathData const & cell(idx_type i) const override { return cells_[i]; }
//@}
/// can we move into this cell (see macroarg.h)
- bool isActive() const;
+ bool isActive() const override;
/// request "external features"
- void validate(LaTeXFeatures & features) const;
+ void validate(LaTeXFeatures & features) const override;
/// replace in all cells
- void replace(ReplaceData &);
+ void replace(ReplaceData &) override;
/// do we contain a given pattern?
- bool contains(MathData const &) const;
+ bool contains(MathData const &) const override;
/// glue everything to a single cell
MathData glue() const;
/// debug helper
- void dump() const;
+ void dump() const override;
/// writes \\, name(), and args in braces and '\\lyxlock' if necessary
- void write(WriteStream & os) const;
+ void write(TeXMathStream & os) const override;
/// writes [, name(), and args in []
- void normalize(NormalStream & os) const;
+ void normalize(NormalStream & os) const override;
///
- void latex(otexstream & os, OutputParams const & runparams) const;
+ void latex(otexstream & os, OutputParams const & runparams) const override;
///
- bool setMouseHover(BufferView const * bv, bool mouse_hover) const;
+ bool setMouseHover(BufferView const * bv, bool mouse_hover) const override;
///
- bool mouseHovered(BufferView const * bv) const
+ bool mouseHovered(BufferView const * bv) const override
{ return mouse_hover_[bv]; }
///
- bool completionSupported(Cursor const &) const;
+ bool completionSupported(Cursor const &) const override;
+ ///
+ bool inlineCompletionSupported(Cursor const & cur) const override;
///
- bool inlineCompletionSupported(Cursor const & cur) const;
+ bool automaticInlineCompletion() const override;
///
- bool automaticInlineCompletion() const;
+ bool automaticPopupCompletion() const override;
///
- bool automaticPopupCompletion() const;
+ CompletionList const * createCompletionList(Cursor const & cur) const override;
///
- CompletionList const * createCompletionList(Cursor const & cur) const;
+ docstring completionPrefix(Cursor const & cur) const override;
///
- docstring completionPrefix(Cursor const & cur) const;
+ bool insertCompletion(Cursor & cur, docstring const & s, bool finished) override;
///
- bool insertCompletion(Cursor & cur, docstring const & s, bool finished);
+ void completionPosAndDim(Cursor const &, int & x, int & y, Dimension & dim) const override;
///
- void completionPosAndDim(Cursor const &, int & x, int & y, Dimension & dim) const;
+ InsetCode lyxCode() const override { return MATH_NEST_CODE; }
+
///
- InsetCode lyxCode() const { return MATH_NEST_CODE; }
+ bool confirmDeletion() const override { return nargs() > 0; }
protected:
///
InsetMathNest & operator=(InsetMathNest const &);
///
- virtual void doDispatch(Cursor & cur, FuncRequest & cmd);
+ void doDispatch(Cursor & cur, FuncRequest & cmd) override;
/// do we want to handle this event?
bool getStatus(Cursor & cur, FuncRequest const & cmd,
- FuncStatus & status) const;
+ FuncStatus & status) const override;
///
void handleFont(Cursor & cur,
docstring const & arg, docstring const & font);
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.
+ /// inserted. Handles undo.
virtual bool interpretString(Cursor & cur, docstring const & str);
private:
bool lock_;
///
mutable std::map<BufferView const *, bool> mouse_hover_;
-};
+};