2 * \file math_macrotemplate.C
3 * This file is part of LyX, the document processor.
4 * Licence details can be found in the file COPYING.
8 * Full author contact details are available in file CREDITS.
13 #include "MathMacroTemplate.h"
14 #include "MathMLStream.h"
15 #include "MathParser.h"
16 #include "MathSupport.h"
24 #include "frontends/Painter.h"
25 #include "frontends/font_metrics.h"
27 #include "support/lstrings.h"
30 using lyx::support::bformat;
38 MathMacroTemplate::MathMacroTemplate()
39 : InsetMathNest(2), numargs_(0), name_(), type_("newcommand")
45 MathMacroTemplate::MathMacroTemplate(string const & nm, int numargs,
46 string const & type, MathArray const & ar1, MathArray const & ar2)
47 : InsetMathNest(2), numargs_(numargs), name_(nm), type_(type)
52 lyxerr << "MathMacroTemplate::MathMacroTemplate: wrong # of arguments: "
53 << numargs_ << std::endl;
59 MathMacroTemplate::MathMacroTemplate(std::istream & is)
60 : InsetMathNest(2), numargs_(0), name_()
65 mathed_parse_cell(ar, is);
66 if (ar.size() != 1 || !ar[0]->asMacroTemplate()) {
67 lyxerr << "cannot read macro from '" << ar << "'" << endl;
70 operator=( *(ar[0]->asMacroTemplate()) );
74 auto_ptr<InsetBase> MathMacroTemplate::doClone() const
76 return auto_ptr<InsetBase>(new MathMacroTemplate(*this));
80 void MathMacroTemplate::edit(LCursor & cur, bool)
82 lyxerr << "MathMacroTemplate: edit left/right" << endl;
87 int MathMacroTemplate::numargs() const
93 void MathMacroTemplate::numargs(int numargs)
99 string MathMacroTemplate::name() const
105 docstring MathMacroTemplate::prefix() const
108 // delete the conversion when bformat() will return a docstring.
109 // delete the conversion when bformat() takes a docstring arg.
110 return bformat(_(" Macro: %1$s: "), lyx::from_utf8(name_));
114 void MathMacroTemplate::metrics(MetricsInfo & mi, Dimension & dim) const
118 docstring dp = prefix();
119 dim.wid = cell(0).width() + cell(1).width() + 20
120 + font_metrics::width(dp, mi.base.font);
121 dim.asc = std::max(cell(0).ascent(), cell(1).ascent()) + 7;
122 dim.des = std::max(cell(0).descent(), cell(1).descent()) + 7;
127 void MathMacroTemplate::draw(PainterInfo & p, int x, int y) const
129 setPosCache(p, x, y);
132 LyXFont font = p.base.font;
133 font.setColor(LColor::math);
135 PainterInfo pi(p.base.bv, p.pain);
136 pi.base.style = LM_ST_TEXT;
139 int const a = y - dim_.asc + 1;
140 int const w = dim_.wid - 2;
141 int const h = dim_.height() - 2;
143 // LColor::mathbg used to be "AntiqueWhite" but is "linen" now, too
144 // the next line would overwrite the selection!
145 //pi.pain.fillRectangle(x, a, w, h, LColor::mathmacrobg);
146 pi.pain.rectangle(x, a, w, h, LColor::mathframe);
152 LCursor & cur = p.base.bv->cursor();
153 if (cur.isInside(this))
154 cur.drawSelection(pi);
156 docstring dp = prefix();
157 pi.pain.text(x + 2, y, dp, font);
158 x += font_metrics::width(dp, pi.base.font) + 6;
160 int const w0 = cell(0).width();
161 int const w1 = cell(1).width();
162 cell(0).draw(pi, x + 2, y + 1);
163 pi.pain.rectangle(x, y - dim_.ascent() + 3,
164 w0 + 4, dim_.height() - 6, LColor::mathline);
165 cell(1).draw(pi, x + 8 + w0, y + 1);
166 pi.pain.rectangle(x + w0 + 6, y - dim_.ascent() + 3,
167 w1 + 4, dim_.height() - 6, LColor::mathline);
171 void MathMacroTemplate::read(Buffer const &, LyXLex & lex)
174 mathed_parse_cell(ar, lex.getStream());
175 if (ar.size() != 1 || !ar[0]->asMacroTemplate()) {
176 lyxerr << "cannot read macro from '" << ar << "'" << endl;
179 operator=( *(ar[0]->asMacroTemplate()) );
183 void MathMacroTemplate::write(Buffer const &, std::ostream & os) const
185 WriteStream wi(os, false, false);
186 os << "FormulaMacro\n";
191 void MathMacroTemplate::write(WriteStream & os) const
193 if (type_ == "def") {
194 os << "\\def\\" << name_.c_str();
195 for (int i = 1; i <= numargs_; ++i)
198 // newcommand or renewcommand
199 os << "\\" << type_.c_str() << "{\\" << name_.c_str() << '}';
201 os << '[' << numargs_ << ']';
204 os << '{' << cell(0) << "}";
207 // writing .tex. done.
210 // writing .lyx, write special .tex export only if necessary
211 if (!cell(1).empty())
212 os << "\n{" << cell(1) << '}';
217 MacroData MathMacroTemplate::asMacroData() const
219 return MacroData(asString(cell(0)), numargs(), asString(cell(1)));