+#ifdef __GNUG__
+#pragma implementation
+#endif
+
#include <config.h>
#include "math_symbolinset.h"
#include "math_streamstr.h"
#include "math_support.h"
#include "math_parser.h"
+#include "LaTeXFeatures.h"
#include "debug.h"
-
MathSymbolInset::MathSymbolInset(const latexkeys * l)
: sym_(l), h_(0)
{}
}
-MathTextCodes MathSymbolInset::code() const
-{
- switch(sym_->token) {
- case LM_TK_CMR:
- return LM_TC_CMR;
- case LM_TK_CMSY:
- return LM_TC_CMSY;
- case LM_TK_CMM:
- return LM_TC_CMM;
- case LM_TK_CMEX:
- return LM_TC_CMEX;
- case LM_TK_MSA:
- return LM_TC_MSA;
- case LM_TK_MSB:
- return LM_TC_MSB;
- default:
- return LM_TC_SYMB;
- }
-}
-
-
-MathTextCodes MathSymbolInset::code2() const
-{
- if (sym_->token == LM_TK_CMEX)
- return LM_TC_BOLDSYMB;
- else
- return LM_TC_SYMB;
-}
-
-
string MathSymbolInset::name() const
{
return sym_->name;
}
-void MathSymbolInset::metrics(MathMetricsInfo const & mi) const
+void MathSymbolInset::metrics(MathMetricsInfo & mi) const
{
- mi_ = mi;
- MathTextCodes c = code();
- if (sym_->latex_font_id > 0 && math_font_available(c)) {
- mathed_char_dim(c, mi_, sym_->latex_font_id, ascent_, descent_, width_);
- if (c == LM_TC_CMEX) {
- h_ = 4 * descent_ / 5;
- ascent_ += h_;
- descent_ -= h_;
- }
- } else {
- if (sym_->id > 0 && sym_->id < 255 && math_font_available(LM_TC_SYMB))
- mathed_char_dim(code2(), mi_, sym_->id, ascent_, descent_, width_);
- else
- mathed_string_dim(LM_TC_TEX, mi_, sym_->name, ascent_, descent_, width_);
+ //lyxerr << "metrics: symbol: '" << sym_->name
+ // << "' in font: '" << sym_->inset
+ // << "' drawn as: '" << sym_->draw
+ // << "'\n";
+
+ int const em = mathed_char_width(mi.base.font, 'M');
+ MathFontSetChanger dummy(mi.base, sym_->inset.c_str());
+ mathed_string_dim(mi.base.font, sym_->draw, dim_);
+ // correct height for broken cmex and wasy font
+ if (sym_->inset == "cmex" || sym_->inset == "wasy") {
+ h_ = 4 * dim_.d / 5;
+ dim_.a += h_;
+ dim_.d -= h_;
}
+ // seperate things a bit
if (isRelOp())
- width_ += mathed_char_width(LM_TC_TEX, mi_, 'I');
+ dim_.w += static_cast<int>(0.5*em+0.5);
+ else
+ dim_.w += static_cast<int>(0.1667*em+0.5);
+
+ scriptable_ = false;
+ if (mi.base.style == LM_ST_DISPLAY)
+ if (sym_->inset == "cmex" || sym_->extra == "funclim")
+ scriptable_ = true;
}
-void MathSymbolInset::draw(Painter & pain, int x, int y) const
-{
+void MathSymbolInset::draw(MathPainterInfo & pi, int x, int y) const
+{
+ //lyxerr << "metrics: symbol: '" << sym_->name
+ // << "' in font: '" << sym_->inset
+ // << "' drawn as: '" << sym_->draw
+ // << "'\n";
+ int const em = mathed_char_width(pi.base.font, 'M');
if (isRelOp())
- x += mathed_char_width(LM_TC_TEX, mi_, 'I') / 2;
- MathTextCodes Code = code();
- if (sym_->latex_font_id > 0 && math_font_available(Code))
- drawChar(pain, Code, mi_, x, y - h_, sym_->latex_font_id);
- else if (sym_->id > 0 && sym_->id < 255 && math_font_available(LM_TC_SYMB))
- drawChar(pain, code2(), mi_, x, y, sym_->id);
+ x += static_cast<int>(0.25*em+0.5);
else
- drawStr(pain, LM_TC_TEX, mi_, x, y, sym_->name);
+ x += static_cast<int>(0.0833*em+0.5);
+
+ MathFontSetChanger dummy(pi.base, sym_->inset.c_str());
+ drawStr(pi, pi.base.font, x, y - h_, sym_->draw);
}
bool MathSymbolInset::isRelOp() const
-{
- return sym_->type == "mathrel";
+{
+ return sym_->extra == "mathrel";
}
bool MathSymbolInset::isScriptable() const
{
- return mi_.style == LM_ST_DISPLAY && sym_->token == LM_TK_CMEX;
+ return scriptable_;
}
bool MathSymbolInset::takesLimits() const
{
- return sym_->token == LM_TK_CMEX;
+ return
+ sym_->inset == "cmex" ||
+ sym_->inset == "lyxboldsymb" ||
+ sym_->extra == "funclim";
+}
+
+
+void MathSymbolInset::validate(LaTeXFeatures & features) const
+{
+ if (sym_->inset == "msa" || sym_->inset == "msb")
+ features.require("amssymb");
}
void MathSymbolInset::normalize(NormalStream & os) const
{
- os << "[symbol " << name() << "]";
+ os << "[symbol " << name() << ']';
}
{
if (name() == "cdot")
os << '*';
+ else if (name() == "infty")
+ os << "infinity";
+ else
+ os << name();
+}
+
+void MathSymbolInset::maximize(MaximaStream & os) const
+{
+ if (name() == "cdot")
+ os << '*';
+ else if (name() == "infty")
+ os << "INF";
else
os << name();
}
+void MathSymbolInset::mathematicize(MathematicaStream & os) const
+{
+ if ( name() == "pi") { os << "Pi"; return;}
+ if ( name() == "infty") { os << "Infinity"; return;}
+ os << name();
+}
+
+
char const * MathMLtype(string const & s)
{
if (s == "mathop")
}
-bool MathSymbolInset::match(MathInset * p) const
+bool MathSymbolInset::match(MathAtom const & at) const
{
- MathSymbolInset const * q = p->asSymbolInset();
+ MathSymbolInset const * q = at->asSymbolInset();
return q && name() == q->name();
}
void MathSymbolInset::mathmlize(MathMLStream & os) const
{
- char const * type = MathMLtype(sym_->type);
+ char const * type = MathMLtype(sym_->extra);
os << '<' << type << "> ";
if (sym_->xmlname == "x") // unknown so far
os << name();
void MathSymbolInset::write(WriteStream & os) const
-{
- os << '\\' << name() << ' ';
-}
-
-
-void MathSymbolInset::infoize(std::ostream & os) const
{
os << '\\' << name();
+ os.pendingSpace(true);
}
-void MathSymbolInset::validate(LaTeXFeatures & features) const
+void MathSymbolInset::infoize(std::ostream & os) const
{
- // if (...)
- // features.require("amssymb");
+ os << "Symbol: " << name();
}