]> git.lyx.org Git - features.git/blob - src/mathed/InsetMath.cpp
dce8d598923f3d2be916bae4922a0b8b1a2aad20
[features.git] / src / mathed / InsetMath.cpp
1 /**
2  * \file InsetMath.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 "InsetMath.h"
15 #include "MathData.h"
16 #include "MathStream.h"
17
18 #include "support/debug.h"
19 #include "support/docstream.h"
20 #include "support/gettext.h"
21 #include "support/lstrings.h"
22 #include "support/textutils.h"
23
24 #include "support/lassert.h"
25
26 using namespace std;
27
28 namespace lyx {
29
30 MathData & InsetMath::cell(idx_type)
31 {
32         static MathData dummyCell;
33         LYXERR0("I don't have any cell");
34         return dummyCell;
35 }
36
37
38 MathData const & InsetMath::cell(idx_type) const
39 {
40         static MathData dummyCell;
41         LYXERR0("I don't have any cell");
42         return dummyCell;
43 }
44
45
46 void InsetMath::dump() const
47 {
48         lyxerr << "---------------------------------------------" << endl;
49         odocstringstream os;
50         WriteStream wi(os, false, true, false);
51         write(wi);
52         lyxerr << to_utf8(os.str());
53         lyxerr << "\n---------------------------------------------" << endl;
54 }
55
56
57 void InsetMath::metricsT(TextMetricsInfo const &, Dimension &) const
58 {
59         LYXERR0("InsetMath::metricsT(Text) called directly!");
60 }
61
62
63 void InsetMath::drawT(TextPainter &, int, int) const
64 {
65         LYXERR0("InsetMath::drawT(Text) called directly!");
66 }
67
68
69 void InsetMath::write(WriteStream & os) const
70 {
71         bool brace = os.pendingBrace();
72         os.pendingBrace(false);
73         if (os.latex() && os.textMode()) {
74                 os << "\\ensuremath{";
75                 os.textMode(false);
76         }
77         docstring const s = name();
78         os << "\\" << s;
79         // We need an extra ' ' unless this is a single-char-non-ASCII name
80         // or anything non-ASCII follows
81         if (s.size() != 1 || isAlphaASCII(s[0]))
82                 os.pendingSpace(true);
83         os.pendingBrace(brace);
84 }
85
86
87 int InsetMath::plaintext(odocstream &, OutputParams const &) const
88 {
89         // all math plain text output shall take place in InsetMathHull
90         LASSERT(false, /**/);
91         return 0;
92 }
93
94
95 void InsetMath::normalize(NormalStream & os) const
96 {
97         os << '[' << name() << "] ";
98 }
99
100
101 void InsetMath::octave(OctaveStream & os) const
102 {
103         NormalStream ns(os.os());
104         normalize(ns);
105 }
106
107
108 void InsetMath::maple(MapleStream & os) const
109 {
110         NormalStream ns(os.os());
111         normalize(ns);
112 }
113
114
115 void InsetMath::maxima(MaximaStream & os) const
116 {
117         MapleStream ns(os.os());
118         maple(ns);
119 }
120
121
122 void InsetMath::mathematica(MathematicaStream & os) const
123 {
124         NormalStream ns(os.os());
125         normalize(ns);
126 }
127
128
129 void InsetMath::mathmlize(MathStream & os) const
130 {
131         NormalStream ns(os.os());
132         normalize(ns);
133 }
134
135
136 HullType InsetMath::getType() const
137 {
138         return hullNone;
139 }
140
141
142 ostream & operator<<(ostream & os, MathAtom const & at)
143 {
144         odocstringstream oss;
145         WriteStream wi(oss, false, false, false);
146         at->write(wi);
147         return os << to_utf8(oss.str());
148 }
149
150
151 odocstream & operator<<(odocstream & os, MathAtom const & at)
152 {
153         WriteStream wi(os, false, false, false);
154         at->write(wi);
155         return os;
156 }
157
158
159 } // namespace lyx