X-Git-Url: https://git.lyx.org/gitweb/?a=blobdiff_plain;f=src%2Ftex2lyx%2Ftex2lyx.h;h=4850eeea8826ccc09402eba68efdcc9b9a3e6fba;hb=28f43b18963a5088529d4ac7c165fa95e62fd02b;hp=b6ff734132440bd98c5249bd0b4fb8b443895390;hpb=b38d210152d3297af0e152d1ee432f71d7797abb;p=lyx.git diff --git a/src/tex2lyx/tex2lyx.h b/src/tex2lyx/tex2lyx.h index b6ff734132..4850eeea88 100644 --- a/src/tex2lyx/tex2lyx.h +++ b/src/tex2lyx/tex2lyx.h @@ -4,7 +4,7 @@ * This file is part of LyX, the document processor. * Licence details can be found in the file COPYING. * - * \author André Pönitz + * \author André Pönitz * \author Jean-Marc Lasgouttes * * Full author contact details are available in file CREDITS. @@ -13,45 +13,59 @@ #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 Context; -/// in preamble.C -LyXTextClass const parse_preamble(Parser & p, std::ostream & os, std::string const & forceclass); +/// A trivial subclass, just to give us a public default constructor +class TeX2LyXDocClass : public DocumentClass +{}; + +/// in preamble.cpp +void parse_preamble(Parser & p, std::ostream & os, + std::string const & forceclass, TeX2LyXDocClass & tc); /// used packages with options extern std::map > used_packages; +/// in text.cpp +std::string translate_len(std::string const &); -/// in text.C void parse_text(Parser & p, std::ostream & os, unsigned flags, bool outer, Context & context); -//std::string parse_text(Parser & p, unsigned flags, const bool outer, -// Context & context); - -/// parses a subdocument, usually useful in insets (whence the name) +/*! + * 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 & context); + bool outer, Context const & context); -/// in math.C +/// in math.cpp void parse_math(Parser & p, std::ostream & os, unsigned flags, mode_type mode); -/// in table.C +/// in table.cpp void handle_tabular(Parser & p, std::ostream & os, bool is_long_tabular, - Context & context); + Context & context); -/// in tex2lyx.C +/// 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, @@ -69,7 +83,7 @@ char const * const * is_known(std::string const &, char const * const *); * \param o2 wether \newcommand had a second optional parameter */ void add_known_command(std::string const & command, std::string const & o1, - bool o2); + bool o2); // Access to environment stack extern std::vector active_environments; @@ -89,6 +103,8 @@ extern CommandMap known_commands; 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(); @@ -104,6 +120,9 @@ extern std::string getParentFilePath(); * contains a preamble. * \return true if the conversion was successful, else false. */ -bool tex2lyx(std::string const & infilename, std::string const & outfilename); +bool tex2lyx(std::string const & infilename, support::FileName const & outfilename); + + +} // namespace lyx #endif