]> git.lyx.org Git - lyx.git/blobdiff - src/mathed/math_parser.h
enable direct input of #1...#9; some whitespace changes
[lyx.git] / src / mathed / math_parser.h
index 3320fa7cfb3afb3167473d72c4a7f4c5aa079c2b..d641de67f4937bfa8c7357a88c0a97b172ddc556 100644 (file)
 #endif
 
 #include "LString.h"
+#include "math_defs.h"
 
-#include "symbol_def.h"
-
+class MathAtom;
 class MathArray;
-class MathInset;
 class LyXLex;
 
 ///
 enum MathTokenEnum
 {
        ///
-       LM_TK_BOP = 256,
+       LM_TK_SYM = 256,
        ///
-       LM_TK_ALPHA,
+       LM_TK_BOX,
        ///
-       LM_TK_STR,
+       LM_TK_CHOOSE,
        ///
-       LM_TK_SYM,
+       LM_TK_BINOM,
        ///
-       LM_TK_FRAC,
+       LM_TK_ATOP,
        ///
-       LM_TK_CHOOSE,
+       LM_TK_OVER,
+       ///
+       LM_TK_FRAC,
        ///
        LM_TK_SQRT,
        ///
-       LM_TK_BEGIN,
+       LM_TK_ROOT,
        ///
-       LM_TK_END,
+       LM_TK_LEFTEQN,
        ///
-       LM_TK_NEWLINE,
-       ///
-       LM_TK_UNDEF,
+       LM_TK_BEGIN,
        ///
+       LM_TK_END,
+       /// mathcal, mathrm...
+       LM_TK_OLDFONT,
+       /// cal,...
        LM_TK_FONT,
        ///
        LM_TK_LEFT,
        ///
        LM_TK_RIGHT,
        ///
-       LM_TK_ACCENT,
-       ///
-       LM_TK_WIDE,
+       LM_TK_DECORATION,
        ///
        LM_TK_FUNC,
        ///
        LM_TK_FUNCLIM,
        ///
-       LM_TK_BIGSYM,
+       LM_TK_CMR,
+       ///
+       LM_TK_CMSY,
+       ///
+       LM_TK_CMM,
+       ///
+       LM_TK_CMEX,
+       ///
+       LM_TK_MSA,
+       ///
+       LM_TK_MSB,
        ///
        LM_TK_LABEL,
        ///
@@ -83,13 +94,9 @@ enum MathTokenEnum
        ///
        LM_TK_LIMIT,
        ///
-       LM_TK_STY,
-       ///
-       LM_TK_PMOD,
+       LM_TK_PROTECT,
        ///
-       LM_TK_BMOD,
-       ///
-       LM_TK_MACRO,
+       LM_TK_STY,
        ///
        LM_TK_SPECIAL,
        ///
@@ -97,29 +104,53 @@ enum MathTokenEnum
        ///
        LM_TK_NEWCOMMAND,
        ///
+       LM_TK_MATH,
+       ///
+       LM_TK_NOT,
+       ///
+       LM_TK_KERN,
+       ///
        LM_TK_STACK
 };
 
 
 ///
 struct latexkeys {
-       ///
-       char const * name;
-       ///
-       short token;
-       ///
+       /// name of the macro or primitive
+       string name;
+       /// one of the categories above
+       MathTokenEnum token;
+       /// an id within a category if needed (only for spaces?)
        unsigned int id;
+       /// which font to use (optional)
+       unsigned int latex_font_id;
+       /// operator/...
+       string type;
+       /// how is this called as XML entity?
+       string xmlname;
 };
 
 
-///
+/// check whether this is a well-known (La)TeX macro or primitive
 latexkeys const * in_word_set(string const & str);
 
-///
-latexkeys const * lm_get_key_by_id(unsigned int id, short tc);
+/// parse formula from a string
+bool mathed_parse_normal(MathAtom &, string const &);
+/// ... a stream
+bool mathed_parse_normal(MathAtom &, std::istream &);
+/// ... the LyX lexxer
+bool mathed_parse_normal(MathAtom &, LyXLex &);
 
+/// parse a macro definition from a string, enter it into the macro table
+string mathed_parse_macro(string const &);
+/// ... a stream
+string mathed_parse_macro(std::istream &);
+/// ... the LyX lexxer
+string mathed_parse_macro(LyXLex &);
 
-MathInset * mathed_parse(std::istream &);
-MathInset * mathed_parse(LyXLex &);
+/// parse a single cell from a string
+void mathed_parse_cell(MathArray & ar, string const &);
+/// ... a stream
+void mathed_parse_cell(MathArray & ar, std::istream &);
 
 #endif