// -*- C++ -*- /** * \file LaTeX.h * This file is part of LyX, the document processor. * Licence details can be found in the file COPYING. * * \author Lars Gullik Bjønnes * \author Angus Leeming * \author Dekel Tsur * * Full author contact details are available in file CREDITS. */ #ifndef LATEX_H #define LATEX_H #include "OutputParams.h" #include "support/FileName.h" #include "support/signals.h" #include #include namespace lyx { class DepTable; /// class TeXErrors { private: /// class Error { public: /// Error () : error_in_line(0) {} /// Error(int line, docstring const & desc, docstring const & text, std::string const & fname) : error_in_line(line), error_desc(desc), 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: /// typedef std::vector Errors; /// Errors::const_iterator begin() const { return errors.begin(); } /// 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, 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 AuxInfo { public: /// AuxInfo() {} /// support::FileName aux_file; /// std::set citations; /// std::set databases; /// std::set styles; }; /// bool operator==(AuxInfo const &, AuxInfo const &); bool operator!=(AuxInfo const &, AuxInfo const &); /** * Class to run the LaTeX compiler and needed auxiliary programs. * The main .tex file must be in the current directory. The current directory * must not change as long as an object of this class lives. * This is required by the LaTeX compiler, and we also make use of it by * various support::makeAbsPath() calls. */ class LaTeX { public: /** Return values from scanLogFile() and run() (to come) This enum should be enlarged a bit so that one could get more feedback from the LaTeX run. */ enum log_status { /// NO_ERRORS = 0, /// NO_LOGFILE = 1, /// NO_OUTPUT = 2, /// UNDEF_REF = 4, // Reference '...' on page ... undefined. /// UNDEF_CIT = 8, // Citation '...' on page ... undefined. /// RERUN = 16, // Label(s) may have changed. Rerun to get... /// TEX_ERROR = 32, /// TEX_WARNING = 64, /// LATEX_ERROR = 128, /// LATEX_WARNING = 256, /// PACKAGE_WARNING = 512, /// NO_FILE = 1024, /// NO_CHANGE = 2048, /// TOO_MANY_ERRORS = 4096, /// ERROR_RERUN = 8192, /// 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 signal message; /** cmd = the latex command, file = name of the (temporary) latex file, 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, 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 getNumErrors() const { return num_errors;} /// int scanLogFile(TeXErrors &); private: /// noncopyable LaTeX(LaTeX const &); void operator=(LaTeX const &); /// use this for running LaTeX once int startscript(); /// The dependency file. support::FileName depfile; /// 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 &); /// std::vector const scanAuxFiles(support::FileName const &, bool const only_childbibs = false); /// AuxInfo const scanAuxFile(support::FileName const &); /// void scanAuxFile(support::FileName const &, AuxInfo &); /// void updateBibtexDependencies(DepTable &, std::vector const &); /// int scanBlgFile(DepTable & head, TeXErrors & terr); /// int scanIlgFile(TeXErrors & terr, support::FileName const fn = support::FileName()); /// bool runBibTeX(std::vector const &, OutputParams const &, int & exit_code); /// 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; /// The name of the final output file. support::FileName output_file; /// OutputParams runparams; /// Do we use biber? bool biber; /// std::vector children; /// bool allow_cancel; }; } // namespace lyx #endif