// -*- 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
#define LATEX_H
-#ifdef __GNUG__
-#pragma interface
-#endif
-
+#include "latexrunparams.h"
#include "LString.h"
#include "DepTable.h"
#include <vector>
+#include <set>
-class MiniBuffer;
+#include <boost/utility.hpp>
+
+class LyXFunc;
///
class TeXErrors {
};
+class Aux_Info {
+public:
+ ///
+ Aux_Info() {}
+ ///
+ string aux_file;
+ ///
+ std::set<string> citations;
+ ///
+ std::set<string> databases;
+ ///
+ std::set<string> styles;
+};
+
+
///
-class LaTeX {
+bool operator==(Aux_Info const &, Aux_Info const &);
+bool operator!=(Aux_Info const &, Aux_Info const &);
+
+
+///
+class LaTeX : boost::noncopyable {
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.
*/
///
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);
-
+ LaTeX(string const & cmd, LatexRunParams const &,
+ string const & file, string const & path);
+
/// runs LaTeX several times
- int run(TeXErrors &, MiniBuffer *);
+ int run(TeXErrors &, LyXFunc *);
///
int getNumErrors() { return num_errors;}
+ ///
+ int scanLogFile(TeXErrors &);
+
+private:
/// use this for running LaTeX once
- int operator() ();
-protected:
+ int startscript();
+
/// The dependency file.
string depfile;
- /// unavail
- LaTeX(LaTeX const &);
- /// unavail
- LaTeX & operator= (LaTeX const &);
-
///
void deplog(DepTable & head);
///
- int scanLogFile(TeXErrors &);
+ bool runMakeIndex(string const &);
///
- bool runMakeIndex(string const &);
+ std::vector<Aux_Info> const scanAuxFiles(string const &);
///
- bool scanAux(DepTable &);
-
+ Aux_Info const scanAuxFile(string const &);
+
///
- bool runBibTeX(string const &, DepTable &);
+ void scanAuxFile(string const &, Aux_Info &);
+
+ ///
+ void updateBibtexDependencies(DepTable &,
+ std::vector<Aux_Info> const &);
+
+ ///
+ bool runBibTeX(std::vector<Aux_Info> const &);
///
void deleteFilesOnError() const;
-
+
///
string cmd;
///
string file;
-
+
///
string path;
/// used by scanLogFile
int num_errors;
+
+ /// The name of the final output file.
+ string output_file;
+
+ ///
+ LatexRunParams runparams;
};
#endif