// -*- C++ -*-
-/* This file is part of
- * ======================================================
- *
- * LyX, The Document Processor
- * Copyright 1995 Matthias Ettrich
- * Copyright 1995-2000 The Lyx Team
+/**
+ * \file LaTeX.h
+ * This file is part of LyX, the document processor.
+ * Licence details can be found in the file COPYING.
*
- * This file is Copyright 1996-1999
- * Lars Gullik Bjønnes
+ * \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
-#ifdef __GNUG__
-#pragma interface
-#endif
-
+#include "latexrunparams.h"
#include "LString.h"
-#include "DepTable.h"
#include <vector>
#include <set>
#include <boost/utility.hpp>
+#include <boost/signals/signal1.hpp>
-class MiniBuffer;
+class DepTable;
///
class TeXErrors {
Errors errors;
};
+
class Aux_Info {
public:
///
std::set<string> databases;
///
std::set<string> styles;
- ///
- friend
- bool operator==(Aux_Info const & a, Aux_Info const & o);
};
///
-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;
-}
+bool operator==(Aux_Info const &, Aux_Info const &);
+bool operator!=(Aux_Info const &, Aux_Info const &);
///
-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)
-
+
This enum should be enlarged a bit so that one could
get more feedback from the LaTeX run.
*/
///
WARNINGS = TEX_WARNING + LATEX_WARNING + PACKAGE_WARNING
};
-
+
+ /// This signal emits an informative message
+ boost::signal1<void, string> message;
+
/**
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);
- ///
- virtual ~LaTeX() {}
-
/// runs LaTeX several times
- int run(TeXErrors &, MiniBuffer *);
+ int run(TeXErrors &);
///
int getNumErrors() { return num_errors;}
- /// use this for running LaTeX once
- int operator() ();
-
///
int scanLogFile(TeXErrors &);
-protected:
+private:
+ /// use this for running LaTeX once
+ int startscript();
+
/// The dependency file.
string depfile;
///
void scanAuxFile(string const &, Aux_Info &);
-
+
///
void updateBibtexDependencies(DepTable &,
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