///
EDITABLE editable() const { return HIGHLY_EDITABLE; }
///
+ void edit(Cursor & cur, bool front, EntryDirection entry_from);
+ ///
+ bool notifyCursorLeaves(Cursor & cur);
+ ///
void read(Buffer const &, Lexer & lex);
///
void write(Buffer const &, std::ostream & os) const;
/// Remove everything from the name which makes it invalid
/// and return true iff it is valid.
bool fixNameAndCheckIfValid();
+
+ /// request "external features"
+ virtual void validate(LaTeXFeatures &) const;
/// decide whether its a redefinition
void updateToContext(MacroContext const & mc) const;
MathMacroTemplate const * asMacroTemplate() const { return this; }
///
InsetCode lyxCode() const { return MATHMACRO_CODE; }
+ ///
+ void infoize(odocstream & os) const;
protected:
///
FuncStatus & status) const;
private:
+ friend class InsetLabelBox;
+ friend class DisplayLabelBox;
+
+ ///
virtual Inset * clone() const;
/// remove #n with from<=n<=to
idx_type optIdx(idx_type n) const { return n + 1; }
///
idx_type displayIdx() const { return optionals_ + 2; }
- /// The label with some holes to edit
- mutable MathData label_;
+ ///
+ void updateLook() const;
+ /// The representation of the macro tempalte, with some holes to edit
+ mutable MathData look_;
///
mutable int numargs_;
///
mutable MacroType type_;
/// defined before already?
mutable bool redefinition_;
+ ///
+ void createLook() const;
+ ///
+ mutable bool lookOutdated_;
+ /// true if in pre-calculations of metrics to get height of boxes
+ mutable bool premetrics_;
+ ///
+ mutable int labelBoxAscent_;
+ ///
+ mutable int labelBoxDescent_;
+ ///
+ bool premetrics() const { return premetrics_; }
+ ///
+ int commonLabelBoxAscent() const { return labelBoxAscent_; }
+ ///
+ int commonLabelBoxDescent() const { return labelBoxDescent_; }
};