lyx_mirror/src/mathed/MathMacroTemplate.h

173 lines
4.4 KiB
C
Raw Normal View History

// -*- C++ -*-
/**
* \file math_macrotemplate.h
* This file is part of LyX, the document processor.
* Licence details can be found in the file COPYING.
*
* \author Alejandro Aguilar Sierra
* \author Andr<EFBFBD> P<EFBFBD>nitz
*
* Full author contact details are available in file CREDITS.
*/
#ifndef MATH_MACROTEMPLATE_H
#define MATH_MACROTEMPLATE_H
#include "InsetMathNest.h"
#include "MacroTable.h"
#include "MathData.h"
#include "support/types.h"
namespace lyx {
/// This class contains the macro definition.
class MathMacroTemplate : public InsetMathNest {
public:
///
MathMacroTemplate();
///
MathMacroTemplate(docstring const & name, int nargs, int optional,
MacroType type,
std::vector<MathData> const & optionalValues = std::vector<MathData>(),
MathData const & def = MathData(),
MathData const & display = MathData());
///
explicit MathMacroTemplate(const docstring & str);
///
EDITABLE editable() const { return HIGHLY_EDITABLE; }
///
void edit(Cursor & cur, bool left);
///
Inset * editXY(Cursor & cur, int x, int y);
///
bool notifyCursorLeaves(Cursor & cur);
///
void read(Buffer const &, Lexer & lex);
///
void write(Buffer const &, std::ostream & os) const;
///
void write(WriteStream & os) const;
/// Output LaTeX code, but assume that the macro is not definied yet
/// if overwriteRedefinition is true
void write(WriteStream & os, bool overwriteRedefinition) const;
///
int plaintext(Buffer const &, odocstream &,
OutputParams const &) const;
///
bool noFontChange() const { return true; }
///
docstring name() const;
///
void getDefaults(std::vector<docstring> & defaults) const;
///
docstring definition() const;
///
docstring displayDefinition() const;
///
size_t numArgs() const;
///
size_t numOptionals() const;
///
bool redefinition() const { return redefinition_; }
///
MacroType type() const { return type_; }
/// check name and possible other formal properties
bool validMacro() const;
///
bool validName() const;
/// Remove everything from the name which makes it invalid
/// and return true iff it is valid.
bool fixNameAndCheckIfValid();
/// decide whether its a redefinition
void updateToContext(MacroContext const & mc) const;
///
void draw(PainterInfo & pi, int x, int y) const;
///
void metrics(MetricsInfo & mi, Dimension & dim) const;
/// identifies macro templates
MathMacroTemplate * asMacroTemplate() { return this; }
/// identifies macro templates
MathMacroTemplate const * asMacroTemplate() const { return this; }
///
InsetCode lyxCode() const { return MATHMACRO_CODE; }
///
void infoize(odocstream & os) const;
protected:
///
virtual void doDispatch(Cursor & cur, FuncRequest & cmd);
/// do we want to handle this event?
bool getStatus(Cursor & cur, FuncRequest const & cmd,
FuncStatus & status) const;
private:
virtual Inset * clone() const;
/// remove #n with from<=n<=to
void removeArguments(Cursor & cur, int from, int to);
/// shift every #n with from<=n, i.e. #n -> #(n-by)
void shiftArguments(size_t from, int by);
///
void insertParameter(Cursor & cur, int pos, bool greedy = false);
///
void removeParameter(Cursor & cur, int pos, bool greedy = false );
///
void makeOptional(Cursor & cur);
///
void makeNonOptional(Cursor & cur);
///
idx_type defIdx() const { return optionals_ + 1; }
/// index of default value cell of optional parameter (#1 -> n=0)
idx_type optIdx(idx_type n) const { return n + 1; }
///
idx_type displayIdx() const { return optionals_ + 2; }
///
void updateLook() const;
/// The representation of the macro tempalte, with some holes to edit
mutable MathData look_;
///
mutable int numargs_;
///
int optionals_;
/// keeps the old optional default value when an
/// optional argument is disabled
std::vector<MathData> optionalValues_;
/// (re)newcommand or def
mutable MacroType type_;
/// defined before already?
mutable bool redefinition_;
///
mutable bool editing_;
///
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_;
private:
friend class InsetLabelBox;
///
bool premetrics() const { return premetrics_; }
///
int commonLabelBoxAscent() const { return labelBoxAscent_; }
///
int commonLabelBoxDescent() const { return labelBoxDescent_; }
};
} // namespace lyx
#endif