X-Git-Url: https://git.lyx.org/gitweb/?a=blobdiff_plain;f=src%2Ftex2lyx%2Ftex2lyx.h;h=913060977c578e73d0f05112538921b889352fbe;hb=116740d7e35b3f9e54e87afdc7aa00ad62364947;hp=d2b296d4719f373485d05d7e4b6101927433b372;hpb=dd750828d5f3be742a6d33cbda85ee312e5c6b6e;p=lyx.git diff --git a/src/tex2lyx/tex2lyx.h b/src/tex2lyx/tex2lyx.h index d2b296d471..913060977c 100644 --- a/src/tex2lyx/tex2lyx.h +++ b/src/tex2lyx/tex2lyx.h @@ -1,39 +1,67 @@ +// -*- C++ -*- +/** + * \file tex2lyx.h + * This file is part of LyX, the document processor. + * Licence details can be found in the file COPYING. + * + * \author André Pönitz + * \author Jean-Marc Lasgouttes + * + * Full author contact details are available in file CREDITS. + */ + #ifndef TEX2LYX_H #define TEX2LYX_H -#include "texparser.h" -#include "lyxtextclass.h" +#include "Parser.h" +#include "TextClass.h" #include #include #include +#include + + +namespace lyx { + +namespace support { class FileName; } -class LyXTextClass; +class Context; -LyXTextClass const parse_preamble(Parser & p, std::ostream & os); +/// in preamble.cpp +TextClass const parse_preamble(Parser & p, std::ostream & os, std::string const & forceclass); + +/// used packages with options +extern std::map > used_packages; +extern LayoutPtr captionlayout; + +/// in text.cpp +std::string translate_len(std::string const &); void parse_text(Parser & p, std::ostream & os, unsigned flags, bool outer, - LyXTextClass const & textclass, - LyXLayout_ptr layout_ptr = LyXLayout_ptr()); + Context & context); -void parse_text_in_inset(Parser & p, std::ostream & os, unsigned flags, - bool outer, LyXTextClass const & textclass, - LyXLayout_ptr layout = LyXLayout_ptr()); +/*! + * Parses a subdocument, usually useful in insets (whence the name). + * + * It ignores \c context.need_layout and \c context.need_end_layout and + * starts and ends always a new layout. + * Therefore this may only be used to parse text in insets or table cells. + */ +void parse_text_in_inset(Parser & p, std::ostream & os, unsigned flags, + bool outer, Context const & context); -void parse_table(Parser & p, std::ostream & os, unsigned flags); +/// in math.cpp void parse_math(Parser & p, std::ostream & os, unsigned flags, mode_type mode); -void handle_tabular(Parser & p, std::ostream & os, - LyXTextClass const & textclass); -// Helper -std::string parse_text(Parser & p, unsigned flags, const bool outer, - LyXTextClass const & textclass, - LyXLayout_ptr layout_ptr = LyXLayout_ptr()); +/// in table.cpp +void handle_tabular(Parser & p, std::ostream & os, bool is_long_tabular, + Context & context); -void check_end_layout(std::ostream & os); -void handle_comment(Parser & p); + +/// in tex2lyx.cpp std::string const trim(std::string const & a, char const * p = " \t\n\r"); void split(std::string const & s, std::vector & result, @@ -42,10 +70,55 @@ std::string join(std::vector const & input, char const * delim); bool is_math_env(std::string const & name); -char const ** is_known(std::string const & str, char const ** what); +char const * const * is_known(std::string const &, char const * const *); + +/*! + * Adds the command \p command to the list of known commands. + * \param o1 first optional parameter to the latex command \newcommand + * (with brackets), or the empty string if there were no optional arguments. + * \param o2 wether \newcommand had a second optional parameter + */ +void add_known_command(std::string const & command, std::string const & o1, + bool o2); // Access to environment stack extern std::vector active_environments; std::string active_environment(); +enum ArgumentType { + required, + verbatim, + optional +}; + +typedef std::map > CommandMap; + +/// Known TeX commands with arguments that get parsed into ERT. +extern CommandMap known_commands; +/// Known TeX environments with arguments that get parsed into ERT. +extern CommandMap known_environments; +/// Known TeX math environments with arguments that get parsed into LyX mathed. +extern CommandMap known_math_environments; +/// +extern bool noweb_mode; + +/// path of the master .tex file +extern std::string getMasterFilePath(); +/// path of the currently processed .tex file +extern std::string getParentFilePath(); + + +/*! + * Reads tex input from \a infilename and writes lyx output to \a outfilename. + * Uses some common settings for the preamble, so this should only + * be used more than once for included documents. + * Caution: Overwrites the existing preamble settings if the new document + * contains a preamble. + * \return true if the conversion was successful, else false. + */ +bool tex2lyx(std::string const & infilename, support::FileName const & outfilename); + + +} // namespace lyx + #endif