X-Git-Url: https://git.lyx.org/gitweb/?a=blobdiff_plain;f=src%2Foutput_latex.h;h=311b2e61b09a0aa18812b88fe93fb22478f4d23a;hb=a42f7ea7cd0e4d5d9594f363bce628451515d24b;hp=9a7de7ed69d12714ac07b5c5f162b0c97408fca7;hpb=b0097bcddbc2c99755db192c0720f693825ef319;p=lyx.git diff --git a/src/output_latex.h b/src/output_latex.h index 9a7de7ed69..311b2e61b0 100644 --- a/src/output_latex.h +++ b/src/output_latex.h @@ -14,9 +14,7 @@ #include -#include "support/docstream.h" -#include "Paragraph.h" -#include "ParIterator.h" +#include "Layout.h" #include "ParagraphList.h" @@ -25,20 +23,48 @@ namespace lyx { class Buffer; class BufferParams; class Encoding; -class Layout; class Paragraph; class OutputParams; -class TexRow; class Text; -/// Export up to \p reqargs required arguments and -/// \p optargs optional ones. If not enough required -/// ones are given, we'll output: {}. The optional ones -/// must all come first. -int latexArgInsets(Paragraph const & par, - odocstream & os, OutputParams const & runparams, - unsigned int reqargs, unsigned int optargs); +/** Register a language switch when using polyglossia or begin/end commands. + Set \p localswitch to true if a local command switch is used. + */ +void pushLanguageName(std::string const & lang, bool localswitch = false); + +/** Unregister the last language switch when using polyglossia + or begin/end commands. + */ +void popLanguageName(); + +// Check if we have an empty language stack +bool languageStackEmpty(); +/** Return a reference to the last active language opened with + polyglossia or when using begin/end commands. If none or when + using babel with only a begin command, return a reference to + an empty string. + */ +std::string const & openLanguageName(); + +/** Export optional and required arguments of the paragraph \p par. + Non-existing required arguments are output empty: {}. + */ +void latexArgInsets(Paragraph const & par, + otexstream & os, OutputParams const & runparams, + Layout::LaTeXArgMap const & latexargs, + std::string const & prefix = std::string()); +/// Same for merged environments +void latexArgInsets(ParagraphList const & pars, + ParagraphList::const_iterator pit, + otexstream & os, OutputParams const & runparams, + Layout::LaTeXArgMap const & latexargs, + std::string const & prefix = std::string()); +/// Same for InsetLayouts +void latexArgInsetsForParent(ParagraphList const & pars, otexstream & os, + OutputParams const & runparams, + Layout::LaTeXArgMap const & latexargs, + std::string const & prefix = std::string()); /** Export \p paragraphs of buffer \p buf to LaTeX. Don't use a temporary stringstream for \p os if the final output is supposed to go to a file. @@ -46,8 +72,7 @@ int latexArgInsets(Paragraph const & par, */ void latexParagraphs(Buffer const & buf, Text const & text, - odocstream & ofs, - TexRow & texrow, + otexstream & ofs, OutputParams const &, std::string const & everypar = std::string()); @@ -58,16 +83,17 @@ void latexParagraphs(Buffer const & buf, std::pair switchEncoding(odocstream & os, BufferParams const & bparams, OutputParams const &, Encoding const & newEnc, - bool force = false); + bool force = false, bool noswitchmacro = false); /// FIXME: this should not be visible. -ParagraphList::const_iterator TeXOnePar(Buffer const & buf, - Text const & text, - ParagraphList::const_iterator pit, - odocstream & os, TexRow & texrow, - OutputParams const & runparams, - std::string const & everypar = std::string(), - int start_pos = -1, int end_pos = -1); +void TeXOnePar(Buffer const & buf, + Text const & text, + pit_type pit, + otexstream & os, + OutputParams const & runparams, + std::string const & everypar = std::string(), + int start_pos = -1, int end_pos = -1, + bool const force = false); } // namespace lyx