* the GNU General Public Licence version 2 or later.
*/
-#include <config.h>
-
#ifdef __GNUG__
-#pragma implementation "math_inset.h"
+#pragma implementation
#endif
-#include "math_iter.h"
+#include <config.h>
+
+#include "Lsstream.h"
#include "math_inset.h"
-#include "symbol_def.h"
+#include "math_scriptinset.h"
+#include "math_mathmlstream.h"
+#include "debug.h"
-MathedInset::MathedInset(MathedInset * inset)
+int MathInset::height() const
{
- if (inset) {
- name = inset->GetName();
- objtype = inset->GetType();
- size = inset->GetStyle();
- width = inset->Width();
- ascent = inset->Ascent();
- descent = inset->Descent();
- } else {
- objtype = LM_OT_UNDEF;
- size = LM_ST_TEXT;
- width = ascent = descent = 0;
- //name = 0;
- }
+ return ascent() + descent();
}
-MathFuncInset::MathFuncInset(string const & nm, short ot, short st)
- : MathedInset("", ot, st)
+std::ostream & operator<<(std::ostream & os, MathInset const & inset)
{
- ln = 0;
- lims = (GetType() == LM_OT_FUNCLIM);
- if (GetType() == LM_OT_UNDEF) {
- fname = nm;
- SetName(fname);
- } else {
- //fname = 0;
- SetName(nm);
- }
+ WriteStream wi(os, false);
+ inset.write(wi);
+ return os;
}
-MathedInset * MathFuncInset::Clone()
+MathInset::size_type MathInset::nargs() const
{
- return new MathFuncInset(name, GetType(), GetStyle());
+ return 0;
}
-MathSpaceInset::MathSpaceInset(int sp, short ot, short st)
- : MathedInset("", ot, st), space(sp)
-{}
-
-
-MathedInset * MathSpaceInset::Clone()
-{
- return new MathSpaceInset(space, GetType(), GetStyle());
-}
-
+MathXArray dummyCell;
-MathParInset::MathParInset(short st, string const & nm, short ot)
- : MathedInset(nm, ot, st)
+MathXArray & MathInset::xcell(idx_type)
{
- array = 0;
- ascent = 8;
- width = 4;
- descent = 0;
- flag = 1;
- if (objtype == LM_OT_SCRIPT)
- flag |= LMPF_SCRIPT;
+ lyxerr << "I don't have a cell 1\n";
+ return dummyCell;
}
-MathParInset::MathParInset(MathParInset * p)
- : MathedInset(p)
+MathXArray const & MathInset::xcell(idx_type) const
{
- flag = p->flag;
- p->setArgumentIdx(0);
- MathedIter it(p->GetData());
- SetData(it.Copy());
+ lyxerr << "I don't have a cell 2\n";
+ return dummyCell;
}
-MathParInset::~MathParInset()
+MathArray & MathInset::cell(idx_type)
{
- if (array) {
- MathedIter it(array);
- it.Clear();
- delete array;
- }
+ lyxerr << "I don't have a cell 3\n";
+ return dummyCell.data_;
}
-MathedInset * MathParInset::Clone()
+MathArray const & MathInset::cell(idx_type) const
{
- return new MathParInset(this);
+ lyxerr << "I don't have a cell 4\n";
+ return dummyCell.data_;
}
-void MathParInset::SetData(MathedArray * a)
+MathInset::idx_type MathInset::index(row_type row, col_type col) const
{
- array = a;
-
- // A standard paragraph shouldn't have any tabs nor CRs.
- if (array) {
- MathedIter it(array);
- while (it.OK()) {
- char c = it.GetChar();
- if (c == LM_TC_TAB || c == LM_TC_CR)
- it.Delete();
- else
- it.Next();
- }
- }
+ if (row != 0)
+ lyxerr << "illegal row: " << row << "\n";
+ if (col != 0)
+ lyxerr << "illegal col: " << col << "\n";
+ return 0;
}
-
-MathSqrtInset::MathSqrtInset(short st)
- : MathParInset(st, "sqrt", LM_OT_SQRT) {}
-
-
-MathedInset * MathSqrtInset::Clone()
-{
- MathSqrtInset * p = new MathSqrtInset(GetStyle());
- MathedIter it(array);
- p->SetData(it.Copy());
- return p;
-}
+void MathInset::substitute(MathMacro const &)
+{}
-bool MathSqrtInset::Inside(int x, int y)
+bool MathInset::idxNext(idx_type &, pos_type &) const
{
- return x >= xo - hmax
- && x <= xo + width - hmax
- && y <= yo + descent
- && y >= yo - ascent;
-}
-
-
-MathDelimInset::MathDelimInset(int l, int r, short st)
- : MathParInset(st, "", LM_OT_DELIM), left(l), right(r) {}
-
-
-MathedInset * MathDelimInset::Clone()
-{
- MathDelimInset * p = new MathDelimInset(left, right, GetStyle());
- MathedIter it(array);
- p->SetData(it.Copy());
- return p;
+ return false;
}
-MathDecorationInset::MathDecorationInset(int d, short st)
- : MathParInset(st, "", LM_OT_DECO), deco(d)
+bool MathInset::idxRight(idx_type &, pos_type &) const
{
- upper = (deco!= LM_underline && deco!= LM_underbrace);
-}
-
-
-MathedInset * MathDecorationInset::Clone()
-{
- MathDecorationInset * p = new MathDecorationInset(deco, GetStyle());
- MathedIter it(array);
- p->SetData(it.Copy());
- return p;
+ return false;
}
-MathFracInset::MathFracInset(short ot)
- : MathParInset(LM_ST_TEXT, "frac", ot)
+bool MathInset::idxPrev(idx_type &, pos_type &) const
{
-
- den = new MathParInset(LM_ST_TEXT); // this leaks
- dh = 0;
- idx = 0;
- if (objtype == LM_OT_STACKREL) {
- flag |= LMPF_SCRIPT;
- SetName("stackrel");
- }
+ return false;
}
-MathFracInset::~MathFracInset()
+bool MathInset::idxLeft(idx_type &, pos_type &) const
{
- delete den;
-}
-
-
-MathedInset * MathFracInset::Clone()
-{
- MathFracInset * p = new MathFracInset(GetType());
- MathedIter itn(array);
- MathedIter itd(den->GetData());
- p->SetData(itn.Copy(), itd.Copy());
- p->idx = idx;
- p->dh = dh;
- return p;
+ return false;
}
-bool MathFracInset::setArgumentIdx(int i)
+bool MathInset::idxUp(idx_type &) const
{
- if (i == 0 || i == 1) {
- idx = i;
- return true;
- } else
- return false;
+ return false;
}
-void MathFracInset::SetStyle(short st)
+bool MathInset::idxDown(idx_type &) const
{
- MathParInset::SetStyle(st);
- dh = 0;
- den->SetStyle((size == LM_ST_DISPLAY) ?
- static_cast<short>(LM_ST_TEXT)
- : size);
+ return false;
}
-void MathFracInset::SetData(MathedArray * n, MathedArray * d)
+bool MathInset::idxFirst(idx_type &, pos_type &) const
{
- den->SetData(d);
- MathParInset::SetData(n);
+ return false;
}
-void MathFracInset::SetData(MathedArray * d)
+bool MathInset::idxLast(idx_type &, pos_type &) const
{
- if (idx == 0)
- MathParInset::SetData(d);
- else {
- den->SetData(d);
- }
-}
-
-
-void MathFracInset::GetXY(int & x, int & y) const
-{
- if (idx == 0)
- MathParInset::GetXY(x, y);
- else
- den->GetXY(x, y);
+ return false;
}
-MathedArray * MathFracInset::GetData()
+bool MathInset::idxHome(idx_type &, pos_type &) const
{
- if (idx == 0)
- return array;
- else
- return den->GetData();
+ return false;
}
-bool MathFracInset::Inside(int x, int y)
+bool MathInset::idxEnd(idx_type &, pos_type &) const
{
- int xx = xo - (width - w0) / 2;
-
- return x >= xx && x <= xx + width && y <= yo + descent && y >= yo - ascent;
-}
-
-
-void MathFracInset::SetFocus(int /*x*/, int y)
-{
-// lyxerr << "y " << y << " " << yo << " " << den->yo << " ";
- idx = (y > yo) ? 1: 0;
+ return false;
}
-MathMatrixInset::MathMatrixInset(int m, int n, short st)
- : MathParInset(st, "array", LM_OT_MATRIX), nc(m), nr(0), ws_(m),
- v_align(0), h_align(nc, 'c')
+void MathInset::idxDelete(idx_type &, bool & popit, bool & deleteit)
{
- row = 0;
- flag = 15;
- if (n > 0) {
- row = new MathedRowSt(nc+1);
- MathedXIter it(this);
- for (int j = 1; j < n; ++j) it.addRow();
- nr = n;
- if (nr == 1 && nc > 1) {
- for (int j = 0; j < nc - 1; ++j)
- it.Insert('T', LM_TC_TAB);
- }
- } else if (n < 0) {
- row = new MathedRowSt(nc + 1);
- nr = 1;
- }
+ popit = false;
+ deleteit = false;
}
-MathMatrixInset::MathMatrixInset(MathMatrixInset * mt)
- : MathParInset(mt->GetStyle(), mt->GetName(), mt->GetType()),
- nc(mt->nc), nr(0), ws_(mt->nc), v_align(mt->v_align), h_align(mt->h_align)
-{
- MathedIter it;
- it.SetData(mt->GetData());
- array = it.Copy();
- if (mt->row != 0) {
- MathedRowSt * r, * ro= 0, * mrow = mt->row;
- //mrow = mt->row; // This must be redundant...
- while (mrow) {
- r = new MathedRowSt(nc + 1);
- r->setNumbered(mrow->isNumbered());
- //if (mrow->label)
- r->setLabel(mrow->getLabel());
- if (!ro)
- row = r;
- else
- ro->setNext(r);
- mrow = mrow->getNext();
- ro = r;
- ++nr;
- }
- } else
- row = 0;
- flag = mt->flag;
-}
+void MathInset::idxDeleteRange(idx_type, idx_type)
+{}
-MathMatrixInset::~MathMatrixInset()
+void MathInset::normalize(NormalStream & os) const
{
- MathedRowSt * r = row;
- while (r) {
- MathedRowSt * q = r->getNext();
- delete r;
- r = q;
- }
+ os << "[unknown ";
+ WriteStream wi(os.os(), false);
+ write(wi);
+ os << "] ";
}
-MathedInset * MathMatrixInset::Clone()
+void MathInset::dump() const
{
- return new MathMatrixInset(this);
+ lyxerr << "---------------------------------------------\n";
+ WriteStream wi(lyxerr, false);
+ write(wi);
+ lyxerr << "\n---------------------------------------------\n";
}
-void MathMatrixInset::SetAlign(char vv, string const & hh)
-{
- v_align = vv;
- h_align = hh.substr(0, nc); // usr just h_align = hh; perhaps
-}
+void MathInset::validate(LaTeXFeatures &) const
+{}
-// Check the number of tabs and crs
-void MathMatrixInset::SetData(MathedArray * a)
+std::vector<MathInset::idx_type>
+ MathInset::idxBetween(idx_type from, idx_type to) const
{
- if (!a) return;
- MathedIter it(a);
- int nn = nc - 1;
- nr = 1;
- // count tabs per row
- while (it.OK()) {
- if (it.IsTab()) {
- if (nn < 0) {
- it.Delete();
- continue;
- } else {
-// it.Next();
- --nn;
- }
- }
- if (it.IsCR()) {
- while (nn > 0) {
- it.Insert(' ', LM_TC_TAB);
- --nn;
- }
- nn = nc - 1;
- ++nr;
- }
- it.Next();
- }
- it.Reset();
-
- // Automatically inserts tabs around bops
- // DISABLED because it's very easy to insert tabs
- array = a;
+ std::vector<idx_type> res;
+ for (idx_type i = from; i <= to; ++i)
+ res.push_back(i);
+ return res;
}
-void MathMatrixInset::draw(Painter & pain, int x, int baseline)
+void MathInset::metrics(MathMetricsInfo const &) const
{
- MathParInset::draw(pain, x, baseline);
+ lyxerr << "MathInset::metrics() called directly!\n";
}
-void MathMatrixInset::Metrics()
+void MathInset::draw(Painter &, int, int) const
{
- int i, hl, h = 0;
- MathedRowSt * cprow= 0;
-
- if (!row) {
-// lyxerr << " MIDA ";
- MathedXIter it(this);
- row = it.adjustVerticalSt();
- }
-
- // Clean the arrays
- MathedRowSt * cxrow = row;
- while (cxrow) {
- for (i = 0; i <= nc; ++i) cxrow->setTab(i, 0);
- cxrow = cxrow->getNext();
- }
-
- // Basic metrics
- MathParInset::Metrics();
-
- if (nc <= 1 && !row->getNext()) {
- row->ascent(ascent);
- row->descent(descent);
- }
-
- // Vertical positions of each row
- cxrow = row;
- while (cxrow) {
- for (i = 0; i < nc; ++i) {
- if (cxrow == row || ws_[i] < cxrow->getTab(i))
- ws_[i] = cxrow->getTab(i);
- if (cxrow->getNext() == 0 && ws_[i] == 0) ws_[i] = df_width;
- }
-
- cxrow->setBaseline((cxrow == row) ?
- cxrow->ascent() :
- cxrow->ascent() + cprow->descent()
- + MATH_ROWSEP + cprow->getBaseline());
- h += cxrow->ascent() + cxrow->descent() + MATH_ROWSEP;
- cprow = cxrow;
- cxrow = cxrow->getNext();
- }
-
- hl = Descent();
- h -= MATH_ROWSEP;
-
- // Compute vertical align
- switch (v_align) {
- case 't': ascent = row->getBaseline(); break;
- case 'b': ascent = h - hl; break;
- default: ascent = (row->getNext()) ? h / 2: h - hl; break;
- }
- descent = h - ascent + 2;
-
- // Increase ws_[i] for 'R' columns (except the first one)
- for (i = 1; i < nc; ++i)
- if (h_align[i] == 'R')
- ws_[i] += 10*df_width;
- // Increase ws_[i] for 'C' column
- if (h_align[0] == 'C')
- if (ws_[0] < 7*workWidth/8)
- ws_[0] = 7*workWidth/8;
-
- // Adjust local tabs
- cxrow = row;
- width = MATH_COLSEP;
- while (cxrow) {
- int rg = MATH_COLSEP, ww, lf = 0; //, * w = cxrow->w;
- for (i = 0; i < nc; ++i) {
- bool isvoid = false;
- if (cxrow->getTab(i) <= 0) {
- cxrow->setTab(i, df_width);
- isvoid = true;
- }
- switch (h_align[i]) {
- case 'l':
- lf = 0;
- break;
- case 'c':
- lf = (ws_[i] - cxrow->getTab(i))/2;
- break;
- case 'r':
- case 'R':
- lf = ws_[i] - cxrow->getTab(i);
- break;
- case 'C':
- if (cxrow == row)
- lf = 0;
- else if (!cxrow->getNext())
- lf = ws_[i] - cxrow->getTab(i);
- else
- lf = (ws_[i] - cxrow->getTab(i))/2;
- break;
- }
- ww = (isvoid) ? lf : lf + cxrow->getTab(i);
- cxrow->setTab(i, lf + rg);
- rg = ws_[i] - ww + MATH_COLSEP;
- if (cxrow == row) width += ws_[i] + MATH_COLSEP;
- }
- cxrow->setBaseline(cxrow->getBaseline() - ascent);
- cxrow = cxrow->getNext();
- }
+ lyxerr << "MathInset::draw() called directly!\n";
}
-MathAccentInset::MathAccentInset(byte cx, MathedTextCodes f, int cd, short st)
- : MathedInset("", LM_OT_ACCENT, st), c(cx), fn(f), code(cd)
+void MathInset::write(WriteStream &) const
{
- inset = 0;
+ lyxerr << "MathInset::write() called directly!\n";
}
-MathAccentInset::MathAccentInset(MathedInset *ins, int cd, short st)
- : MathedInset("", LM_OT_ACCENT, st),
- c(0), fn(LM_TC_MIN), code(cd), inset(ins) {}
-
-
-MathAccentInset::~MathAccentInset()
+void MathInset::octavize(OctaveStream & os) const
{
- delete inset;
-}
-
-
-MathedInset * MathAccentInset::Clone()
-{
- MathAccentInset * p;
-
- if (inset)
- p = new MathAccentInset(inset->Clone(), code, GetStyle());
- else
- p = new MathAccentInset(c, fn, code, GetStyle());
-
- return p;
+ NormalStream ns(os.os());
+ normalize(ns);
}
-MathBigopInset::MathBigopInset(string const & nam, int id, short st)
- : MathedInset(nam, LM_OT_BIGOP, st), sym(id)
+void MathInset::maplize(MapleStream & os) const
{
- lims = -1;
+ NormalStream ns(os.os());
+ normalize(ns);
}
-MathedInset * MathBigopInset::Clone()
+void MathInset::mathmlize(MathMLStream & os) const
{
- return new MathBigopInset(name, sym, GetStyle());
+ NormalStream ns(os.os());
+ normalize(ns);
}
-
-
-MathDotsInset::MathDotsInset(string const & nam, int id, short st)
- : MathedInset(nam, LM_OT_DOTS, st), code(id) {}
-
-
-MathedInset * MathDotsInset::Clone()
-{
- return new MathDotsInset(name, code, GetStyle());
-}