4 * This file is part of LyX, the document processor.
5 * Licence details can be found in the file COPYING.
9 * Full author contact details are available in file CREDITS.
16 #include "outputparams.h"
24 namespace support { class FileName; }
37 Converter(std::string const & f, std::string const & t, std::string const & c,
38 std::string const & l);
54 /// The converter is latex or its derivatives
56 /// The converter is xml
58 /// Do we need to run the converter in the original directory?
60 /// This converter needs the .aux files
62 /// If the converter put the result in a directory, then result_dir
63 /// is the name of the directory
64 std::string result_dir;
65 /// If the converter put the result in a directory, then result_file
66 /// is the name of the main file in that directory
67 std::string result_file;
68 /// Command to convert the program output to a LaTeX log file format
77 typedef std::vector<int> EdgePath; // to be removed SOON
79 typedef std::vector<Converter> ConverterList;
81 typedef ConverterList::const_iterator const_iterator;
83 Converter const & get(int i) const {
84 return converterlist_[i];
87 Converter const * getConverter(std::string const & from,
88 std::string const & to) const;
90 int getNumber(std::string const & from, std::string const & to) const;
92 void add(std::string const & from, std::string const & to,
93 std::string const & command, std::string const & flags);
95 void erase(std::string const & from, std::string const & to);
99 std::vector<Format const *> const
100 getReachableTo(std::string const & target, bool clear_visited);
102 std::vector<Format const *> const
103 getReachable(std::string const & from, bool only_viewable,
105 /// Does a conversion path from format \p from to format \p to exist?
106 bool isReachable(std::string const & from, std::string const & to);
108 Graph::EdgePath const getPath(std::string const & from, std::string const & to);
110 OutputParams::FLAVOR getFlavor(Graph::EdgePath const & path);
111 /// Flags for converting files
112 enum ConversionFlags {
115 /// Use the default converter if no converter is defined
116 try_default = 1 << 0,
117 /// Get the converted file from cache if possible
121 bool convert(Buffer const * buffer,
122 support::FileName const & from_file, support::FileName const & to_file,
123 support::FileName const & orig_from,
124 std::string const & from_format, std::string const & to_format,
125 ErrorList & errorList, int conversionflags = none);
127 void update(Formats const & formats);
129 void updateLast(Formats const & formats);
131 bool formatIsUsed(std::string const & format);
133 const_iterator begin() const {
134 return converterlist_.begin();
136 const_iterator end() const {
137 return converterlist_.end();
143 std::vector<Format const *> const
144 intToFormat(std::vector<int> const & input);
146 bool scanLog(Buffer const & buffer, std::string const & command,
147 support::FileName const & filename, ErrorList & errorList);
149 bool runLaTeX(Buffer const & buffer, std::string const & command,
150 OutputParams const &, ErrorList & errorList);
152 ConverterList converterlist_;
154 std::string latex_command_;
155 /// If \p from = /path/file.ext and \p to = /path2/file2.ext2 then
156 /// this method moves each /path/file*.ext file to /path2/file2*.ext2
157 bool move(std::string const & fmt,
158 support::FileName const & from, support::FileName const & to,
164 extern Converters converters;
166 extern Converters system_converters;