X-Git-Url: https://git.lyx.org/gitweb/?a=blobdiff_plain;f=src%2Finsets%2FExternalTemplate.h;h=e5b6755059700b009b756ea12edea6b70cc19a47;hb=48b1e8a0aca2f3f3faa8f1f800568e47792ba9a0;hp=4259652ae7973a6c96bf9967e5c36bff41fbd53e;hpb=10cccff7c00abac8dfd1190e17ed349c4d55cee9;p=lyx.git diff --git a/src/insets/ExternalTemplate.h b/src/insets/ExternalTemplate.h index 4259652ae7..e5b6755059 100644 --- a/src/insets/ExternalTemplate.h +++ b/src/insets/ExternalTemplate.h @@ -5,6 +5,7 @@ * Licence details can be found in the file COPYING. * * \author Asger Alstrup Nielsen + * \author Angus Leeming * * Full author contact details are available in file CREDITS. */ @@ -12,48 +13,66 @@ #ifndef EXTERNALTEMPLATE_H #define EXTERNALTEMPLATE_H -#include +#include "ExternalTransforms.h" -#include -#include -#include #include -class LyXLex; - namespace lyx { + +namespace support { class FileName; } + +class Lexer; + +enum PreviewMode { + PREVIEW_OFF = 0, + PREVIEW_GRAPHICS, + PREVIEW_INSTANT +}; + namespace external { -struct Template { +class Template { +public: /// We have to have default commands for safety reasons! Template(); /// - void readTemplate(LyXLex &); + void readTemplate(Lexer &); /// void dumpFormats(std::ostream &) const; + class Option { + public: + Option(std::string const & name_, std::string const & opt_) + : name(name_), option(opt_) {} + std::string name; + std::string option; + }; + /// What is the name of this template in the LyX format? std::string lyxName; /// What will the button in the GUI say? std::string guiName; /// A short help text - std::string helpText; + docstring helpText; /** The format of the input file. Can be "*", in which case we try and * ascertain the format from the contents of the file. */ std::string inputFormat; /// A file extension regular expression for the file browser std::string fileRegExp; - /// What command should be executed to edit the file? - std::string editCommand; /// Should we do automatic production of the output? bool automaticProduction; + /// How should we preview the data in LyX? + PreviewMode preview_mode; + /// A collection of transforms that we can use to transform the data. + std::vector transformIds; /// This is the information needed to support a specific output format - struct Format { + class Format { + public: Format(); /// - void readFormat(LyXLex &); + void readFormat(Lexer &); /// The text that should be inserted into the exported file std::string product; @@ -62,9 +81,20 @@ struct Template { /// The format of this file. std::string updateFormat; /// What features does this external inset require? - std::string requirement; + std::vector requirements; /// A collection of preamble snippets identified by name. std::vector preambleNames; + /// A list of options to the basic command. + std::vector