+/**
+ * \file math_exintinset.C
+ * This file is part of LyX, the document processor.
+ * Licence details can be found in the file COPYING.
+ *
+ * \author André Pönitz
+ *
+ * Full author contact details are available in file CREDITS.
+ */
+
+#include <config.h>
+
#include "math_exintinset.h"
-#include "math_support.h"
-#include "debug.h"
+#include "math_data.h"
#include "math_mathmlstream.h"
+#include "math_streamstr.h"
#include "math_symbolinset.h"
+#include "debug.h"
+
+#include <boost/scoped_ptr.hpp>
+
+
+using std::string;
+using std::auto_ptr;
+using std::endl;
-MathExIntInset::MathExIntInset()
- : int_(new MathSymbolInset("int"))
+MathExIntInset::MathExIntInset(string const & name)
+ : MathNestInset(4), symbol_(name)
{}
+// 0 - core
+// 1 - diff
+// 2 - lower
+// 3 - upper
-MathInset * MathExIntInset::clone() const
+
+auto_ptr<InsetBase> MathExIntInset::clone() const
{
- return new MathExIntInset(*this);
+ return auto_ptr<InsetBase>(new MathExIntInset(*this));
}
-void MathExIntInset::differential(MathArray const & ar)
+void MathExIntInset::symbol(string const & symbol)
{
- diff_ = ar;
+ symbol_ = symbol;
}
-void MathExIntInset::core(MathArray const & ar)
+bool MathExIntInset::hasScripts() const
{
- core_ = ar;
+ // take empty upper bound as "no scripts"
+ return !cell(3).empty();
}
-void MathExIntInset::scripts(MathAtom const & at)
+
+void MathExIntInset::normalize(NormalStream & os) const
{
- scripts_ = at;
+ os << '[' << symbol_ << ' ' << cell(0) << ' ' << cell(1) << ' '
+ << cell(2) << ' ' << cell(3) << ']';
}
-void MathExIntInset::symbol(MathAtom const & at)
+void MathExIntInset::metrics(MetricsInfo &, Dimension &) const
{
- int_ = at;
+ lyxerr << "should not happen" << endl;
}
-bool MathExIntInset::hasScripts() const
+void MathExIntInset::draw(PainterInfo &, int, int) const
{
- return scripts_.hasNucleus();
+ lyxerr << "should not happen" << endl;
}
-
-void MathExIntInset::normalize(NormalStream & os) const
+void MathExIntInset::maple(MapleStream & os) const
{
- os << "[int ";
+ os << symbol_ << '(';
+ if (cell(0).size())
+ os << cell(0);
+ else
+ os << '1';
+ os << ',' << cell(1);
if (hasScripts())
- os << scripts_.nucleus();
- else
- os << "{}";
- os << ' ' << core_ << ' ' << diff_ << ']';
+ os << '=' << cell(2) << ".." << cell(3);
+ os << ')';
}
-void MathExIntInset::metrics(MathMetricsInfo const &) const
+void MathExIntInset::maxima(MaximaStream & os) const
{
- lyxerr << "should not happen\n";
-}
-
-
-void MathExIntInset::draw(Painter &, int, int) const
-{
- lyxerr << "should not happen\n";
+ if ( symbol_ == "int" )
+ os << "integrate(";
+ else
+ os << symbol_ << '(';
+
+ if (cell(0).size())
+ os << cell(0) << ',';
+ else
+ os << '1' << ',';
+ if (hasScripts())
+ os << cell(1) << ',' << cell(2) << ',' << cell(3) << ')';
+ else
+ os << cell(1) << ')';
}
-
-void MathExIntInset::maplize(MapleStream & os) const
+void MathExIntInset::mathematica(MathematicaStream & os) const
{
- os << int_.nucleus() << '(' << core_ << ',' << diff_;
- if (hasScripts()) {
- MathScriptInset * p = scripts_->asScriptInset();
- os << '=' << p->down().data_ << ".." << p->up().data_;
- }
- os << ')';
+ if ( symbol_ == "int" )
+ os << "Integrate[";
+ else if (symbol_ == "sum")
+ os << "Sum[";
+ else
+ os << symbol_ << '[';
+
+ if (cell(0).size())
+ os << cell(0) << ',';
+ else
+ os << '1' << ',';
+ if (hasScripts())
+ os << '{' << cell(1) << ',' << cell(2) << ',' << cell(3) << "}]";
+ else
+ os << cell(1) << ']';
}
void MathExIntInset::mathmlize(MathMLStream & os) const
{
- if (hasScripts())
- scripts_->asScriptInset()->mathmlize(int_.nucleus(), os);
- else
- int_->mathmlize(os);
- os << core_ << "<mo> ⁢ </mo>"
+ boost::scoped_ptr<MathSymbolInset> sym(new MathSymbolInset(symbol_));
+ //if (hasScripts())
+ // mathmlize(sym, os);
+ //else
+ sym->mathmlize(os);
+ os << cell(0) << "<mo> ⁢ </mo>"
<< MTag("mrow") << "<mo> ⅆ </mo>"
- << diff_ << ETag("mrow");
+ << cell(1) << ETag("mrow");
}
-void MathExIntInset::write(WriteStream & os) const
+void MathExIntInset::write(WriteStream &) const
{
- if (hasScripts())
- os << scripts_.nucleus();
- os << core_ << "d" << diff_;
+ lyxerr << "should not happen" << endl;
}
-