* the GNU General Public Licence version 2 or later.
*/
-#include <config.h>
-
#ifdef __GNUG__
#pragma implementation
#endif
-#include "math_iter.h"
#include "math_inset.h"
-#include "symbol_def.h"
-#include "lyxfont.h"
-#include "mathed/support.h"
-#include "Painter.h"
+#include "debug.h"
-// Initialize some static class variables.
-int MathedInset::df_asc;
-int MathedInset::df_des;
-int MathedInset::df_width;
-int MathedInset::workWidth;
+int MathInset::workwidth;
-MathedInset::MathedInset(string const & nm, short ot, short st)
- : name(nm), objtype(ot), width(0), ascent(0), descent(0), size_(st)
+MathInset::MathInset(int nargs, string const & name, MathInsetTypes ot)
+ : name_(name), objtype(ot), width_(0), ascent_(0), descent_(0),
+ size_(LM_ST_DISPLAY), cells_(nargs), xo_(0), yo_(0)
{}
-// In a near future maybe we use a better fonts renderer
-void MathedInset::drawStr(Painter & pain, short type, int siz,
- int x, int y, string const & s)
+int MathInset::ascent() const
{
- string st;
- if (MathIsBinary(type))
- for (string::const_iterator it = s.begin();
- it != s.end(); ++it) {
- st += ' ';
- st += *it;
- st += ' ';
- }
- else
- st = s;
-
- LyXFont const mf = mathed_get_font(type, siz);
- pain.text(x, y, st, mf);
+ return ascent_;
}
-int MathedInset::Ascent() const
+int MathInset::descent() const
{
- return ascent;
+ return descent_;
}
-int MathedInset::Descent() const
+int MathInset::width() const
{
- return descent;
+ return width_;
}
-int MathedInset::Width() const
+int MathInset::height() const
{
- return width;
+ return ascent_ + descent_;
}
-int MathedInset::Height() const
+int MathInset::limits() const
{
- return ascent + descent;
+ return false;
}
-bool MathedInset::GetLimits() const
+void MathInset::limits(int)
{
- return false;
+}
+
+string const & MathInset::name() const
+{
+ return name_;
}
-void MathedInset::SetLimits(bool) {}
+MathInsetTypes MathInset::GetType() const
+{
+ return objtype;
+}
-string const & MathedInset::GetName() const
+void MathInset::SetType(MathInsetTypes t)
{
- return name;
+ objtype = t;
}
-short MathedInset::GetType() const
+void MathInset::SetName(string const & n)
{
- return objtype;
+ name_ = n;
}
-short MathedInset::GetStyle() const
+MathStyles MathInset::size() const
{
return size_;
}
-void MathedInset::SetType(short t)
+void MathInset::size(MathStyles s)
{
- objtype = t;
+ size_ = s;
+}
+
+std::ostream & operator<<(std::ostream & os, MathInset const & inset)
+{
+ inset.Write(os, false);
+ return os;
+}
+
+
+int MathInset::xo() const
+{
+ return xo_;
+}
+
+
+int MathInset::yo() const
+{
+ return yo_;
+}
+
+
+void MathInset::xo(int x)
+{
+ xo_ = x;
+}
+
+
+void MathInset::yo(int y)
+{
+ yo_ = y;
}
-void MathedInset::SetStyle(short st)
+int MathInset::nargs() const
+{
+ return cells_.size();
+}
+
+
+
+MathXArray & MathInset::xcell(int i)
+{
+ return cells_[i];
+}
+
+MathXArray const & MathInset::xcell(int i) const
+{
+ return cells_[i];
+}
+
+
+
+MathArray & MathInset::cell(int i)
+{
+ return cells_[i].data_;
+}
+
+MathArray const & MathInset::cell(int i) const
+{
+ return cells_[i].data_;
+}
+
+
+void MathInset::substitute(MathArray & array, MathMacro const & m) const
+{
+ MathInset * p = clone();
+ for (int i = 0; i < nargs(); ++i)
+ p->cell(i).substitute(m);
+ array.push_back(p);
+}
+
+void MathInset::Metrics(MathStyles st)
{
size_ = st;
+ for (int i = 0; i < nargs(); ++i)
+ xcell(i).Metrics(st);
+}
+
+void MathInset::draw(Painter & pain, int x, int y)
+{
+ xo_ = x;
+ yo_ = y;
+ for (int i = 0; i < nargs(); ++i)
+ xcell(i).draw(pain, x + xcell(i).xo(), y + xcell(i).yo());
+}
+
+
+bool MathInset::idxNext(int & idx, int & pos) const
+{
+ if (idx + 1 >= nargs())
+ return false;
+ ++idx;
+ pos = 0;
+ return true;
+}
+
+
+bool MathInset::idxRight(int & idx, int & pos) const
+{
+ return idxNext(idx, pos);
+}
+
+
+bool MathInset::idxPrev(int & idx, int & pos) const
+{
+ if (idx == 0)
+ return false;
+ --idx;
+ pos = cell(idx).size();
+ return true;
+}
+
+
+bool MathInset::idxLeft(int & idx, int & pos) const
+{
+ return idxPrev(idx, pos);
+}
+
+bool MathInset::idxUp(int &, int &) const
+{
+ return false;
+}
+
+
+bool MathInset::idxDown(int &, int &) const
+{
+ return false;
+}
+
+
+bool MathInset::idxFirst(int & i, int & pos) const
+{
+ if (nargs() == 0)
+ return false;
+ i = 0;
+ pos = 0;
+ return true;
+}
+
+bool MathInset::idxLast(int & i, int & pos) const
+{
+ if (nargs() == 0)
+ return false;
+ i = nargs() - 1;
+ pos = cell(i).size();
+ return true;
+}
+
+
+bool MathInset::idxHome(int & /* idx */, int & pos) const
+{
+ if (pos == 0)
+ return false;
+ pos = 0;
+ return true;
+}
+
+
+bool MathInset::idxEnd(int & idx, int & pos) const
+{
+ if (pos == cell(idx).size())
+ return false;
+
+ pos = cell(idx).size();
+ return true;
}
-void MathedInset::SetName(string const & n)
+bool MathInset::idxFirstUp(int &, int &) const
{
- name = n;
+ return false;
}
-void MathedInset::defaultAscent(int da)
+bool MathInset::idxFirstDown(int &, int &) const
{
- df_asc = da;
+ return false;
}
+void MathInset::idxDelete(int &, bool & popit, bool & deleteit)
+{
+ popit = false;
+ deleteit = false;
+}
+
+void MathInset::idxDeleteRange(int, int)
+{}
-void MathedInset::defaultDescent(int dd)
+bool MathInset::idxLastUp(int &, int &) const
{
- df_des = dd;
+ return false;
}
-void MathedInset::defaultWidth(int dw)
+bool MathInset::idxLastDown(int &, int &) const
{
- df_width = dw;
+ return false;
}
+
+void MathInset::GetXY(int & x, int & y) const
+{
+ x = xo();
+ y = yo();
+}
+
+
+/*
+void MathInset::UserSetSize(MathStyles sz)
+{
+ if (sz >= 0) {
+ size_ = sz;
+ flag = flag & ~LMPF_FIXED_SIZE;
+ }
+}
+*/
+
+void MathInset::WriteNormal(std::ostream & os) const
+{
+ os << "[" << name_ << "] ";
+}
+
+
+void MathInset::dump() const
+{
+ lyxerr << "---------------------------------------------\n";
+ Write(lyxerr, false);
+ lyxerr << "\n";
+ for (int i = 0; i < nargs(); ++i)
+ lyxerr << cell(i) << "\n";
+ lyxerr << "---------------------------------------------\n";
+}
+
+
+void MathInset::push_back(unsigned char ch, MathTextCodes fcode)
+{
+ if (nargs())
+ cells_.back().data_.push_back(ch, fcode);
+ else
+ lyxerr << "can't push without a cell\n";
+}
+
+
+void MathInset::push_back(MathInset * p)
+{
+ if (nargs())
+ cells_.back().data_.push_back(p);
+ else
+ lyxerr << "can't push without a cell\n";
+}
+
+
+bool MathInset::covers(int x, int y) const
+{
+ return
+ x >= xo_ &&
+ x <= xo_ + width_ &&
+ y >= yo_ - ascent_ &&
+ y <= yo_ + descent_;
+}
+
+void MathInset::Validate(LaTeXFeatures & features) const
+{
+ for (int i = 0; i < nargs(); ++i)
+ cell(i).Validate(features);
+}
+
+std::vector<int> MathInset::idxBetween(int from, int to) const
+{
+ std::vector<int> res;
+ for (int i = from; i <= to; ++i)
+ res.push_back(i);
+ return res;
+}