* This file is part of LyX, the document processor.
* Licence details can be found in the file COPYING.
*
- * \author Lars Gullik Bjønnes
+ * \author Lars Gullik Bjønnes
* \author Angus Leeming
* \author Dekel Tsur
*
#ifndef LATEX_H
#define LATEX_H
-#include "outputparams.h"
+#include "OutputParams.h"
-#include "support/docstring.h"
-#include "support/filename.h"
-
-#include <boost/utility.hpp>
-#include <boost/signal.hpp>
+#include "support/strfwd.h"
+#include "support/FileName.h"
+#include "support/signals.h"
#include <vector>
#include <set>
///
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(); }
///
+ Errors::const_iterator begin_ref() const { return undef_ref.begin(); }
+ ///
+ Errors::const_iterator end_ref() const { return undef_ref.end(); }
+ ///
void insertError(int line, docstring const & error_desc,
- docstring const & error_text);
+ docstring const & error_text,
+ std::string const & child_name = empty_string());
+ ///
+ void clearErrors() { errors.clear(); }
+ ///
+ void insertRef(int line, docstring const & error_desc,
+ docstring const & error_text,
+ std::string const & child_name = empty_string());
+ ///
+ void clearRefs() { undef_ref.clear(); }
private:
///
Errors errors;
+ /// For missing Citation and references
+ Errors undef_ref;
};
-class Aux_Info {
+class AuxInfo {
public:
///
- Aux_Info() {}
+ AuxInfo() {}
///
support::FileName aux_file;
///
///
-bool operator==(Aux_Info const &, Aux_Info const &);
-bool operator!=(Aux_Info const &, Aux_Info const &);
+bool operator==(AuxInfo const &, AuxInfo const &);
+bool operator!=(AuxInfo const &, AuxInfo const &);
/**
* 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
+ ///
+ INDEX_ERROR = 65536,
+ ///
+ UNDEF_UNKNOWN_REF = 131072,
+ ///
+ ERRORS = TEX_ERROR + LATEX_ERROR + NONZERO_ERROR + BIBTEX_ERROR + INDEX_ERROR,
///
WARNINGS = TEX_WARNING + LATEX_WARNING + PACKAGE_WARNING
};
/// This signal emits an informative message
- boost::signal<void(docstring)> message;
+ signals2::signal<void(docstring)> message;
/**
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 allow_cancellation = false,
+ 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 deplog(DepTable & head);
+ /// returns exit code
+ int runMakeIndex(std::string const &, OutputParams const &,
+ std::string const & = std::string());
+
+ /// returns exit code
+ int runMakeIndexNomencl(support::FileName const &,
+ std::string const &, std::string const &);
+
///
- bool runMakeIndex(std::string const &, OutputParams const &,
- std::string const & = std::string());
+ std::vector<AuxInfo> const scanAuxFiles(support::FileName const &,
+ bool const only_childbibs = false);
///
- bool runMakeIndexNomencl(support::FileName const &, OutputParams const &,
- std::string const &, std::string const &);
+ AuxInfo const scanAuxFile(support::FileName const &);
///
- std::vector<Aux_Info> const scanAuxFiles(support::FileName const &);
+ void scanAuxFile(support::FileName const &, AuxInfo &);
///
- Aux_Info const scanAuxFile(support::FileName const &);
+ void updateBibtexDependencies(DepTable &,
+ std::vector<AuxInfo> const &);
///
- void scanAuxFile(support::FileName const &, Aux_Info &);
+ int scanBlgFile(DepTable & head, TeXErrors & terr);
///
- void updateBibtexDependencies(DepTable &,
- std::vector<Aux_Info> const &);
+ int scanIlgFile(TeXErrors & terr);
///
- bool runBibTeX(std::vector<Aux_Info> const &);
+ bool runBibTeX(std::vector<AuxInfo> const &,
+ OutputParams const &, int & exit_code);
///
- 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;
+ ///
+ std::vector <std::string> children;
+ ///
+ bool allow_cancel;
};