X-Git-Url: https://git.lyx.org/gitweb/?a=blobdiff_plain;f=src%2FOutputParams.h;h=e492a991b1dae5517af84917371f5188baad76e5;hb=410c716bf703dae98c2064d555b9e2b7678555ee;hp=4fb9b74840707ecfd411aa0a2cd185519f40dd53;hpb=26ce1446043890246e8442c76c0e00589a33f6f2;p=lyx.git diff --git a/src/OutputParams.h b/src/OutputParams.h index 4fb9b74840..e492a991b1 100644 --- a/src/OutputParams.h +++ b/src/OutputParams.h @@ -12,10 +12,8 @@ #ifndef OUTPUTPARAMS_H #define OUTPUTPARAMS_H -#include -#include "support/types.h" -#include +#include "support/shared_ptr.h" #include "Changes.h" @@ -27,16 +25,26 @@ class ExportData; class Font; class Language; - class OutputParams { public: enum FLAVOR { + DVILUATEX, LATEX, + LUATEX, PDFLATEX, XETEX, XML, HTML, - TEXT + TEXT, + LYX + }; + + enum MathFlavor { + NotApplicable, + MathAsMathML, + MathAsHTML, + MathAsImages, + MathAsLaTeX }; enum TableCell { @@ -58,6 +66,13 @@ public: compile the file. */ FLAVOR flavor; + /// is it some flavor of LaTeX? + bool isLaTeX() const; + /// does this flavour support full unicode? + bool isFullUnicode() const; + + /// Same, but for math output, which only matter is XHTML output. + MathFlavor math_flavor; /** Are we to write a 'nice' LaTeX file or not. This esentially seems to mean whether InsetInclude, InsetGraphics @@ -66,6 +81,12 @@ public: */ bool nice; + /** Is this a real child (i.e., compiled as a child)? + This depends on wherefrom we export the buffer. Even children + that have a master can be compiled standalone. + */ + mutable bool is_child; + /** moving_arg == true means that the environment in which the inset is typeset is a moving argument. The inset should take care about fragile commands by preceding the latex with \\protect. @@ -126,6 +147,10 @@ public: */ bool use_babel; + /** Do we use polyglossia (instead of babel)? + */ + bool use_polyglossia; + /** Are we generating multiple indices? */ bool use_indices; @@ -155,7 +180,7 @@ public: This is a hack: Make it possible to add stuff to constant OutputParams instances. */ - boost::shared_ptr exportdata; + shared_ptr exportdata; /** Whether we are inside a comment inset. Insets that are including * external files like InsetGraphics, InsetInclude and InsetExternal @@ -180,6 +205,11 @@ public: */ bool inIndexEntry; + /** Whether we are inside an IPA inset. + * Needed for proper IPA output. + */ + bool inIPA; + /** Whether we are inside an inset that is logically deleted. * A value > 0 indicates a deleted inset. */ @@ -193,13 +223,19 @@ public: /** allow output of only part of the top-level paragraphs * par_begin: beginning paragraph */ - pit_type par_begin; + mutable pit_type par_begin; /** allow output of only part of the top-level paragraphs * par_end: par_end-1 is the ending paragraph * if par_begin=par_end, output all paragraphs */ - pit_type par_end; + mutable pit_type par_end; + + /// Id of the last paragraph before an inset + mutable int lastid; + + /// Last position in the last paragraph before an inset + mutable int lastpos; /// is this the last paragraph in the current buffer/inset? bool isLastPar; @@ -211,7 +247,7 @@ public: bool dryrun; /// Should we output verbatim or escape LaTeX's special chars? - bool verbatim; + bool pass_thru; /// Should we output captions? bool html_disable_captions; @@ -225,8 +261,17 @@ public: /// Are we generating this material for inclusion in a TOC-like entity? bool for_toc; + /// Are we generating this material for inclusion in a tooltip? + bool for_tooltip; + + /// Are we generating this material for use by advanced search? + bool for_search; + /// Include all children notwithstanding the use of \includeonly bool includeall; + + /// Explicit output folder, if any is desired + std::string export_folder; };