]> git.lyx.org Git - lyx.git/blobdiff - src/LaTeX.h
fix typo that put too many include paths for most people
[lyx.git] / src / LaTeX.h
index ebeb4b66495c0687a71f0c0e4f6d28ee3ac2e233..d32b126d2de4c04f40e82932fb4be62153838a69 100644 (file)
@@ -1,15 +1,15 @@
 // -*- C++ -*-
 /* This file is part of
- * ====================================================== 
- * 
- *           LyX, The Document Processor        
+ * ======================================================
+ *
+ *           LyX, The Document Processor
  *          Copyright 1995 Matthias Ettrich
- *           Copyright 1995-2000 The Lyx Team
+ *           Copyright 1995-2001 The Lyx Team
  *
- *           This file is Copyright 1996-1999
+ *           This file is Copyright 1996-2001
  *           Lars Gullik Bjønnes
  *
- * ====================================================== 
+ * ======================================================
  */
 
 #ifndef LATEX_H
 #include "LString.h"
 #include "DepTable.h"
 #include <vector>
+#include <set>
 
-using std::vector;
+#include <boost/utility.hpp>
 
-class MiniBuffer;
+class LyXFunc;
 
 ///
 class TeXErrors {
@@ -48,7 +49,7 @@ private:
        };
 public:
        ///
-       typedef vector<Error> Errors;
+       typedef std::vector<Error> Errors;
        ///
        Errors::const_iterator begin() const { return errors.begin(); }
        ///
@@ -61,51 +62,48 @@ private:
        Errors errors;
 };
 
+class Aux_Info {
+public:
+       ///
+       Aux_Info() {}
+       ///
+       string aux_file;
+       ///
+       std::set<string> citations;
+       ///
+       std::set<string> databases;
+       ///
+       std::set<string> styles;
+};
+
 
 ///
-class LaTeX {
+inline
+bool operator==(Aux_Info const & a, Aux_Info const & o)
+{
+       return a.aux_file == o.aux_file &&
+               a.citations == o.citations &&
+               a.databases == o.databases &&
+               a.styles == o.styles;
+}
+
+
+///
+inline
+bool operator!=(Aux_Info const & a, Aux_Info const & o)
+{
+       return !(a == o);
+}
+
+
+///
+class LaTeX : boost::noncopyable {
 public:
-       /** All the different files produced by TeX.
-           
-           This is the files mentioned on page 208-9 in Lamports book +
-           .ltx and .tex files.
-       */
-       enum TEX_FILES {
-               ///
-               NO_FILES = 0,
-               /// used for table of contents et.al.
-               AUX = 1,
-               /// written by BibTeX
-               BBL = 2,
-               /// LaTeX's output
-               DVI = 4,
-               /// glossary (not supported by LyX so far)
-               GLO = 8,
-               ///index
-               IDX = 16,
-               /// written by makeindex
-               IND = 32,
-               /// list of figures
-               LOF = 64,
-               /// the LaTeX log file
-               LOG = 128,
-               /// list of tables
-               LOT = 256,
-               /// table of contents
-               TOC = 512,
-               /// latex files
-               LTX = 1024,
-               /// tex files
-               TEX = 2048,
-               /// list of algorithms
-               LOA = 4096
-       };
-       
        /** 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.
-         */
+           This enum should be enlarged a bit so that one could
+           get more feedback from the LaTeX run.
+       */
        enum log_status {
                ///
                NO_ERRORS = 0,
@@ -136,69 +134,78 @@ public:
                ///
                TOO_MANY_ERRORS = 4096,
                ///
+               ERROR_RERUN = 8192,
+               ///
                ERRORS = TEX_ERROR + LATEX_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.
        */
        LaTeX(string const & cmd, string const & file, string const & path);
-       
+
+       ///
+       virtual ~LaTeX() {}
+
        /// runs LaTeX several times
-       int run(TeXErrors &, MiniBuffer *);
+       int run(TeXErrors &, LyXFunc *);
 
        ///
        int getNumErrors() { return num_errors;}
 
        /// use this for running LaTeX once
        int operator() ();
+
+       ///
+       int scanLogFile(TeXErrors &);
+
 protected:
        /// The dependency file.
        string depfile;
 
-       /// unavail
-       LaTeX(LaTeX const &);
-       /// unavail
-       LaTeX & operator= (LaTeX const &);
-       
        ///
        void deplog(DepTable & head);
 
        ///
-       void deptex(DepTable & head);
-       
+       bool runMakeIndex(string const &);
+
        ///
-       int scanLogFile(TeXErrors &);
+       std::vector<Aux_Info> const scanAuxFiles(string const &);
 
        ///
-       bool runMakeIndex(string const &);
+       Aux_Info const scanAuxFile(string const &);
 
        ///
-       bool scanAux(DepTable &);
-       
+       void scanAuxFile(string const &, Aux_Info &);
+
+       ///
+       void updateBibtexDependencies(DepTable &,
+                                     std::vector<Aux_Info> const &);
+
+       ///
+       bool runBibTeX(std::vector<Aux_Info> const &);
+
        ///
-       bool runBibTeX(string const &, DepTable &);
-       
+       void deleteFilesOnError() const;
+
        ///
        string cmd;
 
        ///
        string file;
-       
+
        ///
        string path;
-       ///
-       TEX_FILES tex_files;
-       
-       ///
-       int file_count;
 
-       // used by scanLogFile
+       /// used by scanLogFile
        int num_errors;
+
+       /// The name of the final output file.
+       string output_file;
 };
 
 #endif