]> git.lyx.org Git - features.git/blob - src/LaTeX.h
Clean-up the undo API
[features.git] / src / LaTeX.h
1 // -*- C++ -*-
2 /**
3  * \file LaTeX.h
4  * This file is part of LyX, the document processor.
5  * Licence details can be found in the file COPYING.
6  *
7  * \author Lars Gullik Bjønnes
8  * \author Angus Leeming
9  * \author Dekel Tsur
10  *
11  * Full author contact details are available in file CREDITS.
12  */
13
14 #ifndef LATEX_H
15 #define LATEX_H
16
17 #include "OutputParams.h"
18
19 #include "support/docstring.h"
20 #include "support/FileName.h"
21
22 #include <boost/signal.hpp>
23
24 #include <vector>
25 #include <set>
26
27
28 namespace lyx {
29
30 class DepTable;
31
32 ///
33 class TeXErrors {
34 private:
35         ///
36         class Error {
37         public:
38                 ///
39                 Error () : error_in_line(0) {}
40                 ///
41                 Error(int line, docstring const & desc, docstring const & text,
42                       std::string const & fname)
43                         : error_in_line(line),
44                           error_desc(desc),
45                           error_text(text),
46                           child_name(fname) {}
47                 /// what line in the TeX file the error occurred in
48                 int error_in_line;
49                 /// The kind of error
50                 docstring error_desc;
51                 /// The line/cmd that caused the error.
52                 docstring error_text;
53                 /// The name of the child where error occurred, empty otherwise.
54                 std::string child_name;
55         };
56 public:
57         ///
58         typedef std::vector<Error> Errors;
59         ///
60         Errors::const_iterator begin() const { return errors.begin(); }
61         ///
62         Errors::const_iterator end() const { return errors.end(); }
63         ///
64         void insertError(int line, docstring const & error_desc,
65                          docstring const & error_text,
66                          std::string const & child_name = empty_string());
67 private:
68         ///
69         Errors errors;
70 };
71
72
73 class AuxInfo {
74 public:
75         ///
76         AuxInfo() {}
77         ///
78         support::FileName aux_file;
79         ///
80         std::set<std::string> citations;
81         ///
82         std::set<std::string> databases;
83         ///
84         std::set<std::string> styles;
85 };
86
87
88 ///
89 bool operator==(AuxInfo const &, AuxInfo const &);
90 bool operator!=(AuxInfo const &, AuxInfo const &);
91
92
93 /**
94  * Class to run the LaTeX compiler and needed auxiliary programs.
95  * The main .tex file must be in the current directory. The current directory
96  * must not change as long as an object of this class lives.
97  * This is required by the LaTeX compiler, and we also make use of it by
98  * various support::makeAbsPath() calls.
99  */
100 class LaTeX {
101 public:
102         /** Return values from scanLogFile() and run() (to come)
103
104             This enum should be enlarged a bit so that one could
105             get more feedback from the LaTeX run.
106         */
107         enum log_status {
108                 ///
109                 NO_ERRORS = 0,
110                 ///
111                 NO_LOGFILE = 1,
112                 ///
113                 NO_OUTPUT = 2,
114                 ///
115                 UNDEF_REF = 4, // Reference '...' on page ... undefined.
116                 ///
117                 UNDEF_CIT = 8, // Citation '...' on page ... undefined.
118                 ///
119                 RERUN = 16, // Label(s) may have changed. Rerun to get...
120                 ///
121                 TEX_ERROR = 32,
122                 ///
123                 TEX_WARNING = 64,
124                 ///
125                 LATEX_ERROR = 128,
126                 ///
127                 LATEX_WARNING = 256,
128                 ///
129                 PACKAGE_WARNING = 512,
130                 ///
131                 NO_FILE = 1024,
132                 ///
133                 NO_CHANGE = 2048,
134                 ///
135                 TOO_MANY_ERRORS = 4096,
136                 ///
137                 ERROR_RERUN = 8192,
138                 ///
139                 BIBTEX_ERROR = 16384,
140                 ///
141                 NONZERO_ERROR = 32768, // the command exited with nonzero status
142                 ///
143                 //FIXME: BIBTEX_ERROR has been removed from ERRORS for now, since users were irritated
144                 //       about those errors which prevented compilation of previously compiling documents.
145                 //       Think about a "gentle" transfer to BibTeX error reporting.
146                 ERRORS = TEX_ERROR + LATEX_ERROR + NONZERO_ERROR,
147                 ///
148                 WARNINGS = TEX_WARNING + LATEX_WARNING + PACKAGE_WARNING
149         };
150
151         /// This signal emits an informative message
152         boost::signal<void(docstring)> message;
153
154
155         /**
156            cmd = the latex command, file = name of the (temporary) latex file,
157            path = name of the files original path.
158         */
159         LaTeX(std::string const & cmd, OutputParams const &,
160               support::FileName const & file,
161               std::string const & path = empty_string());
162
163         /// runs LaTeX several times
164         int run(TeXErrors &);
165
166         ///
167         int getNumErrors() { return num_errors;}
168
169         ///
170         int scanLogFile(TeXErrors &);
171
172 private:
173         /// noncopyable
174         LaTeX(LaTeX const &);
175         void operator=(LaTeX const &);
176
177         /// use this for running LaTeX once
178         int startscript();
179
180         /// The dependency file.
181         support::FileName depfile;
182
183         ///
184         void deplog(DepTable & head);
185
186         ///
187         bool runMakeIndex(std::string const &, OutputParams const &,
188                           std::string const & = std::string());
189
190         ///
191         bool runMakeIndexNomencl(support::FileName const &, 
192                                  std::string const &, std::string const &);
193
194         ///
195         std::vector<AuxInfo> const scanAuxFiles(support::FileName const &);
196
197         ///
198         AuxInfo const scanAuxFile(support::FileName const &);
199
200         ///
201         void scanAuxFile(support::FileName const &, AuxInfo &);
202
203         ///
204         void updateBibtexDependencies(DepTable &,
205                                       std::vector<AuxInfo> const &);
206
207         ///
208         int scanBlgFile(DepTable & head, TeXErrors & terr);
209
210         ///
211         bool runBibTeX(std::vector<AuxInfo> const &,
212                        OutputParams const &);
213
214         ///
215         void deleteFilesOnError() const;
216
217         ///
218         std::string cmd;
219
220         ///
221         support::FileName file;
222
223         ///
224         std::string path;
225
226         /// used by scanLogFile
227         int num_errors;
228
229         /// The name of the final output file.
230         support::FileName output_file;
231
232         ///
233         OutputParams runparams;
234         
235         /// Do we use biber?
236         bool biber;
237 };
238
239
240 } // namespace lyx
241
242 #endif