]> git.lyx.org Git - lyx.git/blob - src/mathed/math_deliminset.C
some support for matrix operations with maple ('M-x math-extern maple evalm')
[lyx.git] / src / mathed / math_deliminset.C
1 #include <config.h>
2
3 #ifdef __GNUG__
4 #pragma implementation
5 #endif
6
7 #include "math_deliminset.h"
8 #include "math_parser.h"
9 #include "math_support.h"
10 #include "math_mathmlstream.h"
11 #include "math_extern.h"
12
13
14 MathDelimInset::MathDelimInset(string const & l, string const & r)
15         : MathNestInset(1), left_(l), right_(r)
16 {}
17
18
19 MathInset * MathDelimInset::clone() const
20 {   
21         return new MathDelimInset(*this);
22 }
23
24
25 string MathDelimInset::latexName(string const & name)
26 {
27         if (name == "(")
28                 return name;
29         if (name == "[")
30                 return name;
31         if (name == ".")
32                 return name;
33         if (name == ")")
34                 return name;
35         if (name == "]")
36                 return name;
37         if (name == "/")
38                 return name;
39         if (name == "|")
40                 return name;
41         return "\\" + name + " ";
42 }
43
44
45 void MathDelimInset::write(WriteStream & os) const
46 {
47         os << "\\left" << latexName(left_).c_str() << cell(0)
48            << "\\right" << latexName(right_).c_str();
49 }
50
51
52 void MathDelimInset::normalize(NormalStream & os) const
53 {
54         os << "[delim " << latexName(left_).c_str() << ' '
55                 << latexName(right_).c_str() << ' ' << cell(0) << ']';
56 }
57
58
59 int MathDelimInset::dw() const
60 {
61         int w = height() / 5;
62         if (w > 15)
63                 w = 15;
64         if (w < 4)
65                 w = 4;
66         return w;
67 }
68
69
70 void MathDelimInset::metrics(MathMetricsInfo const & mi) const
71 {
72         xcell(0).metrics(mi);
73         int a, d, w;
74         mathed_char_dim(LM_TC_VAR, mi, 'I', a, d, w);
75         int h0   = (a + d) / 2;
76         int a0   = std::max(xcell(0).ascent(), a)   - h0;
77         int d0   = std::max(xcell(0).descent(), d)  + h0;
78         ascent_  = std::max(a0, d0) + h0;
79         descent_ = std::max(a0, d0) - h0;
80         width_   = xcell(0).width() + 2 * dw() + 4;
81 }
82
83
84 void MathDelimInset::draw(Painter & pain, int x, int y) const
85
86         int const w = dw();
87         int const b = y - ascent_;
88         xcell(0).draw(pain, x + w + 2, y);
89         mathed_draw_deco(pain, x + 1, b, w, height(), left_);
90         mathed_draw_deco(pain, x + width() - w - 1, b, w, height(), right_);
91 }
92
93
94 void MathDelimInset::maplize(MapleStream & os) const
95 {
96         if (left_ == "|" && right_ == "|") {
97                 bool mat =
98                         cell(0).size() == 1 && cell(0).begin()->nucleus()
99                                         && cell(0).begin()->nucleus()->asMatrixInset();
100                 if (mat)        
101                         os << "linalg[det](" << cell(0) << ")";
102                 else
103                         os << "abs(" << cell(0) << ")";
104         }
105         else
106                 os << left_.c_str() << cell(0) << right_.c_str();
107 }
108
109
110 void MathDelimInset::mathmlize(MathMLStream & os) const
111 {
112         os << "<fenced open=\"" << left_.c_str() << "\" close=\""
113                 << right_.c_str() << "\">" << cell(0) << "</fenced>";
114 }
115
116
117 void MathDelimInset::octavize(OctaveStream & os) const
118 {
119         if (left_ == "|" && right_ == "|")
120                 os << "det(" << cell(0) << ")";
121         else
122                 os << left_.c_str() << cell(0) << right_.c_str();
123 }