- latexkeys const * l = (left_ != '|') ?
- lm_get_key_by_id(left_, LM_TK_SYM) : 0;
- latexkeys const * r = (right_ != '|') ?
- lm_get_key_by_id(right_, LM_TK_SYM) : 0;
- os << "\\left";
- if (l) {
- os << '\\' << l->name << ' ';
- } else {
- if (left_ == '{' || left_ == '}') {
- os << '\\' << char(left_) << ' ';
- } else {
- os << char(left_) << ' ';
- }
- }
- MathParInset::Write(os, fragile);
- os << "\\right";
- if (r) {
- os << '\\' << r->name << ' ';
- } else {
- if (right_ == '{' || right_ == '}') {
- os << '\\' << char(right_) << ' ';
- } else {
- os << char(right_) << ' ';
- }
+ os << "\\left" << convertDelimToLatexName(left_) << cell(0)
+ << "\\right" << convertDelimToLatexName(right_);
+}
+
+
+void MathDelimInset::normalize(NormalStream & os) const
+{
+ os << "[delim " << convertDelimToLatexName(left_) << ' '
+ << convertDelimToLatexName(right_) << ' ' << cell(0) << ']';
+}
+
+
+int MathDelimInset::dw() const
+{
+ int w = height() / 5;
+ if (w > 8)
+ w = 8;
+ if (w < 4)
+ w = 4;
+ return w;
+}
+
+
+void MathDelimInset::metrics(MathMetricsInfo & mi) const
+{
+ xcell(0).metrics(mi);
+ int a, d, w;
+ mathed_char_dim(mi.base.font, 'I', a, d, w);
+ int h0 = (a + d) / 2;
+ int a0 = max(xcell(0).ascent(), a) - h0;
+ int d0 = max(xcell(0).descent(), d) + h0;
+ ascent_ = max(a0, d0) + h0;
+ descent_ = max(a0, d0) - h0;
+ width_ = xcell(0).width() + 2 * dw() + 8;
+}
+
+
+void MathDelimInset::draw(MathPainterInfo & pi, int x, int y) const
+{
+ int const w = dw();
+ int const b = y - ascent_;
+ xcell(0).draw(pi, x + w + 4, y);
+ mathed_draw_deco(pi, x + 4, b, w, height(), left_);
+ mathed_draw_deco(pi, x + width() - w - 4, b, w, height(), right_);
+}
+
+
+bool MathDelimInset::isParanthesis() const
+{
+ return left_ == "(" && right_ == ")";
+}
+
+
+bool MathDelimInset::isBrackets() const
+{
+ return left_ == "[" && right_ == "]";
+}
+
+
+bool MathDelimInset::isAbs() const
+{
+ return left_ == "|" && right_ == "|";
+}
+
+
+void MathDelimInset::maplize(MapleStream & os) const
+{
+ if (isAbs()) {
+ bool mat =
+ cell(0).size() == 1 && cell(0).begin()->nucleus()
+ && cell(0).begin()->nucleus()->asMatrixInset();
+ if (mat)
+ os << "linalg[det](" << cell(0) << ")";
+ else
+ os << "abs(" << cell(0) << ")";