X-Git-Url: https://git.lyx.org/gitweb/?a=blobdiff_plain;f=src%2Finsets%2FExternalTemplate.h;h=e5b6755059700b009b756ea12edea6b70cc19a47;hb=9762ba5d388e8a81a6e58c464b635ca4cf48cbfa;hp=c02cd865a1e5b78b00399a145b0eb862711fe812;hpb=6a6bb5a017e041e5fe3a1fbf7053a2d0d4357ae3;p=lyx.git diff --git a/src/insets/ExternalTemplate.h b/src/insets/ExternalTemplate.h index c02cd865a1..e5b6755059 100644 --- a/src/insets/ExternalTemplate.h +++ b/src/insets/ExternalTemplate.h @@ -1,92 +1,145 @@ // -*- C++ -*- -/* This file is part of* - * ====================================================== +/** + * \file ExternalTemplate.h + * This file is part of LyX, the document processor. + * Licence details can be found in the file COPYING. * - * LyX, The Document Processor - * - * Copyright 1995 Matthias Ettrich - * Copyright 1995-2000 The LyX Team. + * \author Asger Alstrup Nielsen + * \author Angus Leeming * - * ====================================================== */ + * Full author contact details are available in file CREDITS. + */ #ifndef EXTERNALTEMPLATE_H #define EXTERNALTEMPLATE_H -#ifdef __GNUG__ -#pragma interface -#endif +#include "ExternalTransforms.h" + +#include + +namespace lyx { + +namespace support { class FileName; } -#include -#include -#include "LString.h" -#include +class Lexer; -class LyXLex; +enum PreviewMode { + PREVIEW_OFF = 0, + PREVIEW_GRAPHICS, + PREVIEW_INSTANT +}; + +namespace external { + +class Template { +public: + /// We have to have default commands for safety reasons! + Template(); + /// + 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; + }; -/// -struct ExternalTemplate { /// What is the name of this template in the LyX format? - string lyxName; + std::string lyxName; /// What will the button in the GUI say? - string guiName; + std::string guiName; /// A short help text - 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 - string fileRegExp; - /// What command should be executed to view the file? - string viewCommand; - /// What command should be executed to edit the file? - string editCommand; + std::string fileRegExp; /// 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 FormatTemplate { + class Format { + public: + Format(); + /// + void readFormat(Lexer &); + /// The text that should be inserted into the exported file - string product; - /// The shell command to produce a resulting file - string updateCommand; + std::string product; + /// The filename of the resulting file + std::string updateResult; + /// The format of this file. + std::string updateFormat; /// What features does this external inset require? - string requirement; - /// What should be inserted into the preamble - string preamble; - /// - void readFormat(LyXLex &); - /// This constructor has to default a command for safety reasons! - FormatTemplate(); + std::vector requirements; + /// A collection of preamble snippets identified by name. + std::vector preambleNames; + /// A list of options to the basic command. + std::vector