]> git.lyx.org Git - lyx.git/blob - src/mathed/InsetFormulaMacro.cpp
* dynamic macros as described in http://1stein.org/download/dynmacro.pdf
[lyx.git] / src / mathed / InsetFormulaMacro.cpp
1 /**
2  * \file InsetFormulaMacro.cpp
3  * This file is part of LyX, the document processor.
4  * Licence details can be found in the file COPYING.
5  *
6  * \author Alejandro Aguilar Sierra
7  * \author André Pönitz
8  *
9  * Full author contact details are available in file CREDITS.
10  */
11
12 #include <config.h>
13
14 #include "InsetFormulaMacro.h"
15 #include "MacroTable.h"
16 #include "MathMacroTemplate.h"
17
18 #include "BufferView.h"
19 #include "Cursor.h"
20 #include "debug.h"
21 #include "gettext.h"
22 #include "Lexer.h"
23 #include "OutputParams.h"
24
25 #include "frontends/FontMetrics.h"
26 #include "frontends/Painter.h"
27
28 #include "support/lstrings.h"
29
30 #include <sstream>
31
32 using std::string;
33 using std::ostream;
34 using std::endl;
35
36 namespace lyx {
37
38 using support::bformat;
39
40
41 InsetFormulaMacro::InsetFormulaMacro()
42         : InsetMathNest(2), name_("unknownA")
43 {}
44
45
46 InsetFormulaMacro::InsetFormulaMacro
47                 (docstring const & name, int nargs, docstring const & type)
48         : InsetMathNest(2), name_(name)
49 {
50         MathMacroTable::create(MathAtom(new MathMacroTemplate(name, nargs, type)));
51 }
52
53
54 InsetFormulaMacro::InsetFormulaMacro(string const & s)
55         : InsetMathNest(2), name_("unknownB")
56 {
57         std::istringstream is(s);
58         read(is);
59 }
60
61
62 Inset * InsetFormulaMacro::clone() const
63 {
64         return new InsetFormulaMacro(*this);
65 }
66
67
68 void InsetFormulaMacro::write(Buffer const &, ostream & os) const
69 {
70         os << "FormulaMacro\n";
71         WriteStream wi(os, false, false);
72         tmpl()->write(wi);
73 }
74
75
76 int InsetFormulaMacro::latex(Buffer const &, odocstream & os,
77                              OutputParams const & runparams) const
78 {
79         //lyxerr << "InsetFormulaMacro::latex" << endl;
80         WriteStream wi(os, runparams.moving_arg, true);
81         tmpl()->write(wi);
82         return 2;
83 }
84
85
86 int InsetFormulaMacro::plaintext(Buffer const &, odocstream & os,
87                                  OutputParams const &) const
88 {
89         odocstringstream oss;
90         WriteStream wi(oss, false, true);
91         tmpl()->write(wi);
92
93         docstring const str = oss.str();
94         os << str;
95         return str.size();
96 }
97
98
99 int InsetFormulaMacro::docbook(Buffer const & buf, ostream & os,
100                                OutputParams const & runparams) const
101 {
102         return plaintext(buf, os, runparams);
103 }
104
105
106 void InsetFormulaMacro::read(Buffer const &, Lexer & lex)
107 {
108         read(lex.getStream());
109 }
110
111
112 void InsetFormulaMacro::read(std::istream & is)
113 {
114         auto_ptr<MathMacroTemplate> p(new MathMacroTemplate(is));
115         name_ = p->name();
116         MathMacroTable::create(MathAtom(p.release()));
117 }
118
119
120 string InsetFormulaMacro::prefix() const
121 {
122         return to_utf8(bformat(_(" Macro: %1$s: "), lyx::from_utf8(name_)));
123 }
124
125
126 void InsetFormulaMacro::metrics(MetricsInfo & mi, Dimension & dim) const
127 {
128         //lyxerr << "InsetFormulaMacro: " << this << " -- " << &tmpl() << endl;
129         tmpl()->metrics(mi, dim);
130         dim.asc += 5;
131         dim.des += 5;
132         dim.wid += 10 + theFontMetrics(mi.base.font).width(prefix());
133         dim_ = dim;
134 }
135
136
137 void InsetFormulaMacro::draw(PainterInfo & p, int x, int y) const
138 {
139         // label
140         Font font = p.base.font;
141         font.setColor(Color_math);
142
143         PainterInfo pi(p.base.bv, p.pain);
144         pi.base.style = LM_ST_TEXT;
145         pi.base.font  = font;
146
147         int const a = y - dim_.asc + 1;
148         int const w = dim_.wid - 2;
149         int const h = dim_.height() - 2;
150
151         // Color_mathbg used to be "AntiqueWhite" but is "linen" now, too
152         pi.pain.fillRectangle(x, a, w, h, Color_mathmacrobg);
153         pi.pain.rectangle(x, a, w, h, Color_mathframe);
154
155         // FIXME
156 #if 0
157         Cursor & cur = p.base.bv->cursor();
158         if (cur.isInside(this))
159                 cur.drawSelection(pi);
160 #endif
161
162         pi.pain.text(x + 2, y, prefix(), font);
163
164         // body
165         tmpl()->draw(pi,
166                 x + theFontMetrics(p.base.font).width(prefix()) + 5,
167                 y);
168
169         setPosCache(pi, x, y);
170 }
171
172
173 MathAtom & InsetFormulaMacro::tmpl() const
174 {
175         return MathMacroTable::provide(name_);
176 }
177
178
179 } // namespace lyx