]> git.lyx.org Git - features.git/blob - src/mathed/math_deliminset.C
40f548695cf822496ed5048ceac653ddf051cedd
[features.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 "mathed/support.h"
10 #include "support/LOstream.h"
11
12 using std::max;
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(MathWriteInfo & os) const
46 {
47         os << "\\left" << latexName(left_) << cell(0)
48            << "\\right" << latexName(right_);
49 }
50
51
52 int MathDelimInset::dw() const
53 {
54         int w = height() / 5;
55         if (w > 15)
56                 w = 15;
57         if (w < 4)
58                 w = 4;
59         return w;
60 }
61
62
63 void MathDelimInset::metrics(MathMetricsInfo const & mi) const
64 {
65         xcell(0).metrics(mi);
66         int a, d, w;
67         mathed_char_dim(LM_TC_VAR, mi, 'I', a, d, w);
68         int h0   = (a + d) / 2;
69         int a0   = std::max(xcell(0).ascent(), a)   - h0;
70         int d0   = std::max(xcell(0).descent(), d)  + h0;
71         ascent_  = max(a0, d0) + h0;
72         descent_ = max(a0, d0) - h0;
73         width_   = xcell(0).width() + 2 * dw() + 4;
74 }
75
76
77 void MathDelimInset::draw(Painter & pain, int x, int y) const
78
79         xo(x);
80         yo(y); 
81
82         int const w = dw();
83         int const b = y - ascent_;
84         xcell(0).draw(pain, x + w + 2, y);
85         mathed_draw_deco(pain, x + 1, b, w, height(), left_);
86         mathed_draw_deco(pain, x + width() - w - 1, b, w, height(), right_);
87 }