X-Git-Url: https://git.lyx.org/gitweb/?a=blobdiff_plain;f=src%2Fmathed%2FMathParser.h;h=5be3b10275ee3e7816858141d4342e735898c6c5;hb=a746aa52146257c0e7a2d60123f63dccad5b2751;hp=30b274133eca89bec0e7a802384c26719edf514a;hpb=d12c1f4b225859b36550c82a67fbda19f1ed82b5;p=lyx.git diff --git a/src/mathed/MathParser.h b/src/mathed/MathParser.h index 30b274133e..5be3b10275 100644 --- a/src/mathed/MathParser.h +++ b/src/mathed/MathParser.h @@ -14,6 +14,7 @@ #define MATH_PARSER_H #include "support/types.h" +#include "support/docstring.h" #include #include @@ -22,45 +23,56 @@ namespace lyx { class MathAtom; -class MathArray; +class MathData; class InsetMathGrid; -class LyXLex; +class Lexer; /// class latexkeys { public: /// name of the macro or primitive - std::string name; + docstring name; /// name of a inset that handles that macro - std::string inset; - /// position of the ting in a font - std::vector draw; + docstring inset; + /** + * The string or symbol to draw. + * This is a string of length 1 if \p name is a known symbol, and + * the corresponding font is available. In this case it is + * NO UCS4 STRING! The only "character" of the string simply denotes + * the code point of the symbol in the font. Therefore you have to + * be very careful if you pass \c draw to any function that takes a + * docstring argument. + * If \p name is a known symbol, but the corresponding font is not + * available, or if it is a function name, then \c draw contains a + * regular UCS4 string (actuallay \c draw == \c name) that is painted + * on screen. + */ + docstring draw; /// operator/..., fontname e - std::string extra; - /// how is this called as XML entity? - std::string xmlname; + docstring extra; + /// how is this called as XML entity in MathML? + docstring xmlname; /// required LaTeXFeatures - std::string requires; + docstring requires; }; /// check whether this is a well-known (La)TeX macro or primitive -latexkeys const * in_word_set(std::string const & str); +latexkeys const * in_word_set(docstring const & str); /// parse formula from a string -bool mathed_parse_normal(MathAtom &, std::string const &); -/// ... a stream -bool mathed_parse_normal(MathAtom &, std::istream &); +bool mathed_parse_normal(MathAtom &, docstring const &); /// ... the LyX lexxer -bool mathed_parse_normal(MathAtom &, LyXLex &); -/// ... the LyX lexxer -void mathed_parse_normal(InsetMathGrid &, std::string const &); +bool mathed_parse_normal(MathAtom &, Lexer &); +/// parse formula from a string into a grid +void mathed_parse_normal(InsetMathGrid &, docstring const &); /// parse a single cell from a string -void mathed_parse_cell(MathArray & ar, std::string const &); -/// ... a stream -void mathed_parse_cell(MathArray & ar, std::istream &); +void mathed_parse_cell(MathData & ar, docstring const &); +/// parse a single cell from a stream. Only use this for reading from .lyx +/// file format, for the reason see Parser::tokenize(std::istream &). +void mathed_parse_cell(MathData & ar, std::istream &); void initParser();