// -*- C++ -*- /** * \file MathParser.h * This file is part of LyX, the document processor. * Licence details can be found in the file COPYING. * * \author Alejandro Aguilar Sierra * \author André Pönitz * * Full author contact details are available in file CREDITS. */ #ifndef MATH_PARSER_H #define MATH_PARSER_H #include "MathParser_flags.h" #include "support/docstring.h" namespace lyx { class Buffer; class MathAtom; class MathData; class InsetMathGrid; class Lexer; /// class latexkeys { public: /// latexkeys() : hidden(false) {} /// char const * MathMLtype() const; /// name of the macro or primitive docstring name; /// name of a inset that handles that macro std::string 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 docstring extra; /// how is this called as XML entity in MathML? docstring xmlname; /// required LaTeXFeatures std::string requires; /// Should this macro be hidden from autocompletion (since it requires /// user preamble code)? bool hidden; }; /// check whether this is a well-known (La)TeX macro or primitive latexkeys const * in_word_set(docstring const & str); /// parse formula from a string bool mathed_parse_normal(Buffer * buf, MathAtom &, docstring const &, Parse::flags f = Parse::NORMAL); /// parse formula from the LyX lexxer bool mathed_parse_normal(Buffer * buf, MathAtom &, Lexer &, Parse::flags f = Parse::NORMAL); /// parse formula from a string into a grid bool mathed_parse_normal(InsetMathGrid &, docstring const &, Parse::flags f = Parse::NORMAL); /// parse a single cell from a string bool mathed_parse_cell(MathData & ar, docstring const &, Parse::flags f = Parse::NORMAL); /// parse a single cell from a stream. Only use this for reading from .lyx /// file format, for the reason see Parser::tokenize(std::istream &). bool mathed_parse_cell(MathData & ar, std::istream &, Parse::flags f = Parse::NORMAL); void initParser(); } // namespace lyx #endif