prepare proper handling of {...} blocks

git-svn-id: svn://svn.lyx.org/lyx/lyx-devel/trunk@2488 a592a061-630c-0410-9148-cb99ea01b6c8
This commit is contained in:
André Pönitz 2001-08-10 14:08:00 +00:00
parent 57920ce17b
commit e729656153
4 changed files with 96 additions and 12 deletions

View File

@ -68,6 +68,8 @@ libmathed_la_SOURCES = \
math_parser.h \ math_parser.h \
math_rootinset.C \ math_rootinset.C \
math_rootinset.h \ math_rootinset.h \
math_scopeinset.C \
math_scopeinset.h \
math_scriptinset.C \ math_scriptinset.C \
math_scriptinset.h \ math_scriptinset.h \
math_sizeinset.C \ math_sizeinset.C \

View File

@ -3,18 +3,20 @@
#include "math_parser.h" #include "math_parser.h"
#include <algorithm> #include <algorithm>
bool operator<(const latexkeys & a, const latexkeys & b)
{
return string(a.name) < string(b.name);
}
namespace { namespace {
// This lists needs to remain sorted all the time! // This lists needs to remain sorted all the time!
latexkeys wordlist[] = latexkeys wordlist[] =
{ {
//{"displaystyle", LM_TK_STY, LM_ST_DISPLAY, LMB_NONE},
//{"oint", LM_TK_BIGSYM, LM_oint, LMB_NONE}, //{"oint", LM_TK_BIGSYM, LM_oint, LMB_NONE},
//{"pmod", LM_TK_SYM, 0, LMB_NONE}, //{"pmod", LM_TK_SYM, 0, LMB_NONE},
//{"scriptscriptstyle", LM_TK_STY, LM_ST_SCRIPTSCRIPT, LMB_NONE},
//{"scriptstyle", LM_TK_STY, LM_ST_SCRIPT, LMB_NONE},
//{"textstyle", LM_TK_STY, LM_ST_TEXT, LMB_NONE},
{"!", LM_TK_SPACE, 0, LMB_NONE}, {"!", LM_TK_SPACE, 0, LMB_NONE},
{"#", LM_TK_SPECIAL, '#', LMB_NONE}, {"#", LM_TK_SPECIAL, '#', LMB_NONE},
{"$", LM_TK_SPECIAL, '$', LMB_NONE}, {"$", LM_TK_SPECIAL, '$', LMB_NONE},
@ -51,7 +53,7 @@ latexkeys wordlist[] =
{"Vert", LM_TK_NOGLYPH, LM_Vert, LMB_NONE}, {"Vert", LM_TK_NOGLYPH, LM_Vert, LMB_NONE},
{"Xi", LM_TK_SYM, LM_Xi, LMB_NONE}, {"Xi", LM_TK_SYM, LM_Xi, LMB_NONE},
{"[", LM_TK_BEGIN, LM_OT_EQUATION, LMB_NONE}, {"[", LM_TK_BEGIN, LM_OT_EQUATION, LMB_NONE},
{"\\", LM_TK_NEWLINE, static_cast<unsigned>(-1), LMB_NONE}, {"\\", LM_TK_NEWLINE, static_cast<unsigned>(-1), LMB_NONE}, // -1 needed in mathed_parse_lines!
{"]", LM_TK_END, LM_OT_EQUATION, LMB_NONE}, {"]", LM_TK_END, LM_OT_EQUATION, LMB_NONE},
{"_", LM_TK_SPECIAL, '_', LMB_NONE}, {"_", LM_TK_SPECIAL, '_', LMB_NONE},
{"acute", LM_TK_DECORATION, LM_acute, LMB_NONE}, {"acute", LM_TK_DECORATION, LM_acute, LMB_NONE},
@ -112,6 +114,7 @@ latexkeys wordlist[] =
{"diamond", LM_TK_SYM, LM_diamond, LMB_OPERATOR}, {"diamond", LM_TK_SYM, LM_diamond, LMB_OPERATOR},
{"diamondsuit", LM_TK_SYM, LM_diamondsuit, LMB_NONE}, {"diamondsuit", LM_TK_SYM, LM_diamondsuit, LMB_NONE},
{"dim", LM_TK_FUNC, 0, LMB_NONE}, {"dim", LM_TK_FUNC, 0, LMB_NONE},
//{"displaystyle", LM_TK_STY, LM_ST_DISPLAY, LMB_NONE},
{"div", LM_TK_SYM, LM_div, LMB_OPERATOR}, {"div", LM_TK_SYM, LM_div, LMB_OPERATOR},
{"dot", LM_TK_DECORATION, LM_dot, LMB_NONE}, {"dot", LM_TK_DECORATION, LM_dot, LMB_NONE},
{"doteq", LM_TK_NOGLYPH, 0, LMB_RELATION}, {"doteq", LM_TK_NOGLYPH, 0, LMB_RELATION},
@ -233,6 +236,8 @@ latexkeys wordlist[] =
{"rightharpoondown", LM_TK_NOGLYPH, 0, LMB_NONE}, {"rightharpoondown", LM_TK_NOGLYPH, 0, LMB_NONE},
{"rightharpoonup", LM_TK_NOGLYPH, 0, LMB_NONE}, {"rightharpoonup", LM_TK_NOGLYPH, 0, LMB_NONE},
{"rightleftharpoons", LM_TK_NOGLYPH, 0, LMB_NONE}, {"rightleftharpoons", LM_TK_NOGLYPH, 0, LMB_NONE},
//{"scriptscriptstyle", LM_TK_STY, LM_ST_SCRIPTSCRIPT, LMB_NONE},
//{"scriptstyle", LM_TK_STY, LM_ST_SCRIPT, LMB_NONE},
{"searrow", LM_TK_NOGLYPH, 0, LMB_NONE}, {"searrow", LM_TK_NOGLYPH, 0, LMB_NONE},
{"sec", LM_TK_FUNC, 0, LMB_NONE}, {"sec", LM_TK_FUNC, 0, LMB_NONE},
{"setminus", LM_TK_NOGLYPH, 0, LMB_OPERATOR}, {"setminus", LM_TK_NOGLYPH, 0, LMB_OPERATOR},
@ -265,6 +270,7 @@ latexkeys wordlist[] =
{"tanh", LM_TK_FUNC, 0, LMB_NONE}, {"tanh", LM_TK_FUNC, 0, LMB_NONE},
{"tau", LM_TK_SYM, LM_tau, LMB_NONE}, {"tau", LM_TK_SYM, LM_tau, LMB_NONE},
{"textrm", LM_TK_FONT, LM_TC_TEXTRM, LMB_NONE}, {"textrm", LM_TK_FONT, LM_TC_TEXTRM, LMB_NONE},
//{"textstyle", LM_TK_STY, LM_ST_TEXT, LMB_NONE},
{"theta", LM_TK_SYM, LM_theta, LMB_NONE}, {"theta", LM_TK_SYM, LM_theta, LMB_NONE},
{"tilde", LM_TK_DECORATION, LM_tilde, LMB_NONE}, {"tilde", LM_TK_DECORATION, LM_tilde, LMB_NONE},
{"times", LM_TK_SYM, LM_times, LMB_OPERATOR}, {"times", LM_TK_SYM, LM_times, LMB_OPERATOR},
@ -297,16 +303,9 @@ latexkeys wordlist[] =
{"{", LM_TK_SPECIAL, '{', LMB_NONE}, {"{", LM_TK_SPECIAL, '{', LMB_NONE},
{"|", LM_TK_UNDEF, '|', LMB_NONE}, {"|", LM_TK_UNDEF, '|', LMB_NONE},
{"}", LM_TK_SPECIAL, '}', LMB_NONE} {"}", LM_TK_SPECIAL, '}', LMB_NONE}
// -1 needed in mathed_parse_lines!
}; };
bool operator<(const latexkeys & a, const latexkeys & b)
{
return string(a.name) < string(b.name);
}
// the "Initializer": Its default constructor is executed on loading and // the "Initializer": Its default constructor is executed on loading and
// sorts the list. Not exactly needed as long as the list is kept sorted // sorts the list. Not exactly needed as long as the list is kept sorted
// but who knows... // but who knows...

View File

@ -0,0 +1,54 @@
#ifdef __GNUG__
#pragma implementation
#endif
#include "math_scopeinset.h"
#include "LColor.h"
#include "Painter.h"
#include "support/LOstream.h"
MathScopeInset::MathScopeInset()
: MathNestInset(1)
{}
MathInset * MathScopeInset::clone() const
{
return new MathScopeInset(*this);
}
void MathScopeInset::metrics(MathStyles st) const
{
xcell(0).metrics(st);
size_ = st;
ascent_ = xcell(0).ascent() + 2;
descent_ = xcell(0).descent() + 2;
width_ = xcell(0).width() + 4;
}
void MathScopeInset::draw(Painter & pain, int x, int y) const
{
xo(x);
yo(y);
xcell(0).draw(pain, x + 2, y);
pain.rectangle(x, y - ascent_, width_, height(), LColor::mathline);
}
void MathScopeInset::write(std::ostream & os, bool fragile) const
{
os << '{';
cell(0).write(os, fragile);
os << '}';
}
void MathScopeInset::writeNormal(std::ostream & os) const
{
os << "[scope ";
cell(0).writeNormal(os);
os << "] ";
}

View File

@ -0,0 +1,29 @@
// -*- C++ -*-
#ifndef MATH_SCOPEINSET_H
#define MATH_SCOPEINSET_H
#include "math_nestinset.h"
#ifdef __GNUG__
#pragma interface
#endif
/** An inset for new scopes (i.e. {....} blocks in LaTeX)
\author André Pönitz
*/
class MathScopeInset : public MathNestInset {
public:
///
MathScopeInset();
///
MathInset * clone() const;
///
void draw(Painter &, int x, int y) const;
///
void write(std::ostream &, bool fragile) const;
///
void writeNormal(std::ostream &) const;
///
void metrics(MathStyles st) const;
};
#endif