]> git.lyx.org Git - lyx.git/blobdiff - src/LaTeX.h
Fix text direction issue for InsetInfo in RTL context
[lyx.git] / src / LaTeX.h
index e82af858d6fe23ec30b29c8122fb4a9fd7640e7f..a57cebc83bcc2ff5ac874e37f17efb361d1bbac2 100644 (file)
@@ -18,9 +18,7 @@
 
 #include "support/docstring.h"
 #include "support/FileName.h"
-
-#include <boost/noncopyable.hpp>
-#include <boost/signal.hpp>
+#include "support/signals.h"
 
 #include <vector>
 #include <set>
@@ -45,7 +43,7 @@ private:
                          error_desc(desc),
                          error_text(text),
                          child_name(fname) {}
-               /// what line in the TeX file the error occured in
+               /// what line in the TeX file the error occurred in
                int error_in_line;
                /// The kind of error
                docstring error_desc;
@@ -65,6 +63,8 @@ public:
        void insertError(int line, docstring const & error_desc,
                         docstring const & error_text,
                         std::string const & child_name = empty_string());
+       ///
+       void clearErrors() { errors.clear(); }
 private:
        ///
        Errors errors;
@@ -98,7 +98,7 @@ 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)
 
@@ -137,22 +137,33 @@ public:
                ///
                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
        };
 
        /// 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,
-             std::string const & path = empty_string());
+             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 &);
@@ -164,6 +175,10 @@ public:
        int scanLogFile(TeXErrors &);
 
 private:
+       /// noncopyable
+       LaTeX(LaTeX const &);
+       void operator=(LaTeX const &);
+
        /// use this for running LaTeX once
        int startscript();
 
@@ -173,16 +188,17 @@ private:
        ///
        void deplog(DepTable & head);
 
-       ///
-       bool runMakeIndex(std::string const &, OutputParams const &,
+       /// returns exit code
+       int runMakeIndex(std::string const &, OutputParams const &,
                          std::string const & = std::string());
 
-       ///
-       bool runMakeIndexNomencl(support::FileName const &, 
+       /// returns exit code
+       int runMakeIndexNomencl(support::FileName const &, 
                                 std::string const &, std::string const &);
 
        ///
-       std::vector<AuxInfo> const scanAuxFiles(support::FileName const &);
+       std::vector<AuxInfo> const scanAuxFiles(support::FileName const &,
+                                               bool const only_childbibs = false);
 
        ///
        AuxInfo const scanAuxFile(support::FileName const &);
@@ -195,14 +211,14 @@ private:
                                      std::vector<AuxInfo> const &);
 
        ///
-       void scanBlgFile(DepTable & head);
+       int scanBlgFile(DepTable & head, TeXErrors & terr);
 
        ///
        bool runBibTeX(std::vector<AuxInfo> const &,
-                      OutputParams const &);
+                      OutputParams const &, int & exit_code);
 
        ///
-       void deleteFilesOnError() const;
+       void removeAuxiliaryFiles() const;
 
        ///
        std::string cmd;
@@ -210,9 +226,12 @@ private:
        ///
        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;
 
@@ -221,9 +240,13 @@ private:
 
        ///
        OutputParams runparams;
-       
+
        /// Do we use biber?
        bool biber;
+       ///
+       std::vector <std::string> children;
+       ///
+       bool allow_cancel;
 };