7 #include "math_amsarrayinset.h"
8 #include "math_mathmlstream.h"
9 #include "math_metricsinfo.h"
10 #include "math_support.h"
11 #include "math_streamstr.h"
12 #include "math_support.h"
16 MathAMSArrayInset::MathAMSArrayInset(string const & name, int m, int n)
17 : MathGridInset(m, n), name_(name)
21 MathAMSArrayInset::MathAMSArrayInset(string const & name)
22 : MathGridInset(1, 1), name_(name)
26 MathInset * MathAMSArrayInset::clone() const
28 return new MathAMSArrayInset(*this);
32 char const * MathAMSArrayInset::name_left() const
34 if (name_ == "bmatrix")
36 if (name_ == "vmatrix")
38 if (name_ == "Vmatrix")
40 if (name_ == "pmatrix")
46 char const * MathAMSArrayInset::name_right() const
48 if (name_ == "bmatrix")
50 if (name_ == "vmatrix")
52 if (name_ == "Vmatrix")
54 if (name_ == "pmatrix")
60 void MathAMSArrayInset::metrics(MathMetricsInfo & mi) const
62 MathMetricsInfo m = mi;
63 if (m.base.style == LM_ST_DISPLAY)
64 m.base.style = LM_ST_TEXT;
65 MathGridInset::metrics(m);
70 void MathAMSArrayInset::draw(MathPainterInfo & pi, int x, int y) const
72 MathGridInset::draw(pi, x + 6, y);
73 int const yy = y - ascent();
74 mathed_draw_deco(pi, x + 1, yy, 5, height(), name_left());
75 mathed_draw_deco(pi, x + width() - 6, yy, 5, height(), name_right());
79 void MathAMSArrayInset::write(WriteStream & os) const
81 os << "\\begin{" << name_ << "}";
82 MathGridInset::write(os);
83 os << "\\end{" << name_ << "}";
87 void MathAMSArrayInset::normalize(NormalStream & os) const
89 os << "[" << name_ << " ";
90 MathGridInset::normalize(os);