7 #include "math_amsarrayinset.h"
8 #include "math_mathmlstream.h"
9 #include "math_support.h"
10 #include "math_streamstr.h"
11 #include "math_support.h"
15 MathAMSArrayInset::MathAMSArrayInset(string const & name, int m, int n)
16 : MathGridInset(m, n), name_(name)
20 MathAMSArrayInset::MathAMSArrayInset(string const & name)
21 : MathGridInset(1, 1), name_(name)
25 MathInset * MathAMSArrayInset::clone() const
27 return new MathAMSArrayInset(*this);
31 char const * MathAMSArrayInset::name_left() const
33 if (name_ == "bmatrix")
35 if (name_ == "vmatrix")
37 if (name_ == "Vmatrix")
43 char const * MathAMSArrayInset::name_right() const
45 if (name_ == "bmatrix")
47 if (name_ == "vmatrix")
49 if (name_ == "Vmatrix")
55 void MathAMSArrayInset::metrics(MathMetricsInfo const & st) const
57 MathMetricsInfo mi = st;
58 if (mi.style == LM_ST_DISPLAY)
59 mi.style = LM_ST_TEXT;
60 MathGridInset::metrics(mi);
65 void MathAMSArrayInset::draw(Painter & pain, int x, int y) const
67 MathGridInset::draw(pain, x + 6, y);
69 mathed_draw_deco(pain, x + 1, yy, 5, height(), name_left());
70 mathed_draw_deco(pain, x + width_ - 6, yy, 5, height(), name_right());
74 void MathAMSArrayInset::write(WriteStream & os) const
76 os << "\\begin{" << name_ << "}";
77 MathGridInset::write(os);
78 os << "\\end{" << name_ << "}";
82 void MathAMSArrayInset::normalize(NormalStream & os) const
84 os << "[" << name_ << " ";
85 MathGridInset::normalize(os);
90 void MathAMSArrayInset::maplize(MapleStream & os) const
93 MathGridInset::maplize(os);