]> git.lyx.org Git - lyx.git/blobdiff - src/insets/ExternalTemplate.h
* src/LyXAction.C: mark goto-clear-bookmark as working without buffer
[lyx.git] / src / insets / ExternalTemplate.h
index 4259652ae7973a6c96bf9967e5c36bff41fbd53e..45f1b348ff66f8307acbdd83a497247de8876d42 100644 (file)
@@ -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.
  */
 #ifndef EXTERNALTEMPLATE_H
 #define EXTERNALTEMPLATE_H
 
+#include "ExternalTransforms.h"
+
 #include <boost/utility.hpp>
 
-#include <iosfwd>
-#include <map>
-#include <string>
-#include <vector>
+namespace lyx {
 
 class LyXLex;
 
-namespace lyx {
 namespace external {
 
-struct Template {
+class Template {
+public:
        /// We have to have default commands for safety reasons!
        Template();
        ///
@@ -32,6 +32,14 @@ struct Template {
        ///
        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?
@@ -44,13 +52,14 @@ struct Template {
        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;
+       /// A collection of transforms that we can use to transform the data.
+       std::vector<TransformID> transformIds;
 
        /// This is the information needed to support a specific output format
-       struct Format {
+       class Format {
+       public:
                Format();
                ///
                void readFormat(LyXLex &);
@@ -62,9 +71,20 @@ struct Template {
                /// The format of this file.
                std::string updateFormat;
                /// What features does this external inset require?
-               std::string requirement;
+               std::vector<std::string> requirements;
                /// A collection of preamble snippets identified by name.
                std::vector<std::string> preambleNames;
+               /// A list of options to the basic command.
+               std::vector<Option> options;
+
+               /// The factory functions for each supported transformation.
+               std::map<TransformID, TransformStore> command_transformers;
+               std::map<TransformID, TransformStore> option_transformers;
+
+               typedef std::map<std::string,
+                                std::vector<std::string> > FileMap;
+               /// Referenced files for some formats
+               FileMap referencedFiles;
        };
        ///
        typedef std::map<std::string, Format> Formats;
@@ -72,7 +92,6 @@ struct Template {
        Formats formats;
 };
 
-
 /**
  *  A singleton class that manages the external inset templates
  */