#include "support/docstring.h"
#include "support/FileName.h"
-#include <boost/noncopyable.hpp>
#include <boost/signal.hpp>
#include <vector>
///
Error () : error_in_line(0) {}
///
- Error(int line, docstring const & desc, docstring const & text)
+ Error(int line, docstring const & desc, docstring const & text,
+ std::string const & fname)
: error_in_line(line),
error_desc(desc),
- error_text(text) {}
- /// what line in the TeX file the error occured in
+ error_text(text),
+ child_name(fname) {}
+ /// what line in the TeX file the error occurred in
int error_in_line;
/// The kind of error
docstring error_desc;
/// The line/cmd that caused the error.
docstring error_text;
+ /// The name of the child where error occurred, empty otherwise.
+ std::string child_name;
};
public:
///
Errors::const_iterator end() const { return errors.end(); }
///
void insertError(int line, docstring const & error_desc,
- docstring const & error_text);
+ docstring const & error_text,
+ std::string const & child_name = empty_string());
private:
///
Errors errors;
* This is required by the LaTeX compiler, and we also make use of it by
* various support::makeAbsPath() calls.
*/
-class LaTeX : boost::noncopyable {
+class LaTeX {
public:
/** Return values from scanLogFile() and run() (to come)
///
ERROR_RERUN = 8192,
///
- ERRORS = TEX_ERROR + LATEX_ERROR,
+ BIBTEX_ERROR = 16384,
+ ///
+ NONZERO_ERROR = 32768, // the command exited with nonzero status
+ ///
+ ERRORS = TEX_ERROR + LATEX_ERROR + NONZERO_ERROR + BIBTEX_ERROR,
///
WARNINGS = TEX_WARNING + LATEX_WARNING + PACKAGE_WARNING
};
/**
cmd = the latex command, file = name of the (temporary) latex file,
- path = name of the files original path.
+ path = name of the files original path,
+ clean_start = This forces a fresh run by deleting the files in the temp
+ dir. We set this e.g. if there was an error on previous
+ preview, which is good if the user installed a package
+ or changed certain document settings (#9061).
*/
LaTeX(std::string const & cmd, OutputParams const &,
- support::FileName const & file);
+ support::FileName const & file,
+ std::string const & path = empty_string(),
+ std::string const & lpath = empty_string(),
+ bool const clean_start = false);
/// runs LaTeX several times
int run(TeXErrors &);
int scanLogFile(TeXErrors &);
private:
+ /// noncopyable
+ LaTeX(LaTeX const &);
+ void operator=(LaTeX const &);
+
/// use this for running LaTeX once
int startscript();
void scanAuxFile(support::FileName const &, AuxInfo &);
///
- void updateBibtexDependencies(DepTable &, std::vector<AuxInfo> const &);
+ void updateBibtexDependencies(DepTable &,
+ std::vector<AuxInfo> const &);
+
+ ///
+ int scanBlgFile(DepTable & head, TeXErrors & terr);
///
bool runBibTeX(std::vector<AuxInfo> const &,
- OutputParams const &, bool biber);
+ OutputParams const &);
///
- void deleteFilesOnError() const;
+ void removeAuxiliaryFiles() const;
///
std::string cmd;
///
support::FileName file;
+ /// The document directory path.
+ std::string path;
+
+ /// Extra path, possibly relative to the document directory path.
+ std::string lpath;
+
/// used by scanLogFile
int num_errors;
///
OutputParams runparams;
+
+ /// Do we use biber?
+ bool biber;
};