#include "math_deliminset.h"
#include "math_parser.h"
-#include "mathed/support.h"
-#include "support/LOstream.h"
-
-using std::max;
+#include "math_support.h"
+#include "math_mathmlstream.h"
+#include "math_streamstr.h"
+#include "math_extern.h"
MathDelimInset::MathDelimInset(string const & l, string const & r)
}
-void MathDelimInset::write(MathWriteInfo & os) const
+void MathDelimInset::write(WriteStream & os) const
{
os << "\\left" << latexName(left_) << cell(0)
<< "\\right" << latexName(right_);
}
-void MathDelimInset::writeNormal(std::ostream & os) const
+void MathDelimInset::normalize(NormalStream & os) const
{
- os << "[delim " << latexName(left_) << ' ' << latexName(right_) << ' ';
- cell(0).writeNormal(os);
- os << "]";
+ os << "[delim " << latexName(left_) << ' '
+ << latexName(right_) << ' ' << cell(0) << ']';
}
int MathDelimInset::dw() const
{
int w = height() / 5;
- if (w > 15)
- w = 15;
+ if (w > 12)
+ w = 12;
if (w < 4)
w = 4;
return w;
int h0 = (a + d) / 2;
int a0 = std::max(xcell(0).ascent(), a) - h0;
int d0 = std::max(xcell(0).descent(), d) + h0;
- ascent_ = max(a0, d0) + h0;
- descent_ = max(a0, d0) - h0;
+ ascent_ = std::max(a0, d0) + h0;
+ descent_ = std::max(a0, d0) - h0;
width_ = xcell(0).width() + 2 * dw() + 4;
}
}
-bool MathDelimInset::isMatrix() const
+bool MathDelimInset::isParanthesis() const
+{
+ return left_ == "(" && right_ == ")";
+}
+
+
+bool MathDelimInset::isBrackets() const
+{
+ return left_ == "[" && right_ == "]";
+}
+
+
+bool MathDelimInset::isAbs() const
{
- return left_ == "(" && right_ == ")" && cell(0).size() == 1 &&
- cell(0).begin()->nucleus() && cell(0).begin()->nucleus()->asArrayInset();
+ return left_ == "|" && right_ == "|";
}
void MathDelimInset::maplize(MapleStream & os) const
{
- if (left_ == "|" && right_ == "|") {
- if (cell(0).isMatrix())
+ 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) << ")";
}
else
- os << left_.c_str() << cell(0) << right_.c_str();
+ os << left_ << cell(0) << right_;
}
void MathDelimInset::mathmlize(MathMLStream & os) const
{
- os << "<fenced open=\"" << left_.c_str() << "\" close=\""
- << right_.c_str() << "\">" << cell(0) << "</fenced>";
+ os << "<fenced open=\"" << left_ << "\" close=\""
+ << right_ << "\">" << cell(0) << "</fenced>";
}
void MathDelimInset::octavize(OctaveStream & os) const
{
- if (left_ == "|" && right_ == "|")
+ if (isAbs())
os << "det(" << cell(0) << ")";
else
- os << left_.c_str() << cell(0) << right_.c_str();
+ os << left_ << cell(0) << right_;
}