]> git.lyx.org Git - lyx.git/blobdiff - src/LaTeX.h
Fix fuer #209
[lyx.git] / src / LaTeX.h
index fcd013b8dd78aa86fa8786703cd341ee30a48bbc..937870a70368e8b90d6fe4fad7284b7ba2fc0a20 100644 (file)
@@ -4,9 +4,9 @@
  * 
  *           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
  *
  * ====================================================== 
 #include "LString.h"
 #include "DepTable.h"
 #include <vector>
+#include <set>
 
 #include <boost/utility.hpp>
 
-class MiniBuffer;
+class LyXFunc;
 
 ///
 class TeXErrors {
@@ -61,9 +62,42 @@ private:
        Errors errors;
 };
 
+class Aux_Info {
+public:
+       ///
+       Aux_Info() {}
+       ///
+       string aux_file;
+       ///
+       std::set<string> citations;
+       ///
+       std::set<string> databases;
+       ///
+       std::set<string> styles;
+};
+
+
+///
+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 : public noncopyable {
+class LaTeX : boost::noncopyable {
 public:
        /** Return values from scanLogFile() and run() (to come)
            
@@ -100,6 +134,8 @@ public:
                ///
                TOO_MANY_ERRORS = 4096,
                ///
+               ERROR_RERUN = 8192,
+               ///
                ERRORS = TEX_ERROR + LATEX_ERROR,
                ///
                WARNINGS = TEX_WARNING + LATEX_WARNING + PACKAGE_WARNING
@@ -116,13 +152,17 @@ public:
        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;
@@ -131,16 +171,23 @@ protected:
        void deplog(DepTable & head);
 
        ///
-       int scanLogFile(TeXErrors &);
+       bool runMakeIndex(string const &);
 
        ///
-       bool runMakeIndex(string const &);
+       std::vector<Aux_Info> const scanAuxFiles(string const &);
+
+       ///
+       Aux_Info const scanAuxFile(string const &);
 
        ///
-       bool scanAux(DepTable &);
+       void scanAuxFile(string const &, Aux_Info &);
        
        ///
-       bool runBibTeX(string const &, DepTable &);
+       void updateBibtexDependencies(DepTable &,
+                                     std::vector<Aux_Info> const &);
+
+       ///
+       bool runBibTeX(std::vector<Aux_Info> const &);
 
        ///
        void deleteFilesOnError() const;
@@ -156,6 +203,9 @@ protected:
 
        /// used by scanLogFile
        int num_errors;
+       
+       /// The name of the final output file.
+       string output_file;
 };
 
 #endif