2014-09-02 10:21:17 +02:00
|
|
|
#ifndef CSM_DOC_RUNNER_H
|
|
|
|
#define CSM_DOC_RUNNER_H
|
|
|
|
|
2014-09-06 12:24:09 +02:00
|
|
|
#include <vector>
|
|
|
|
#include <string>
|
|
|
|
|
2014-09-13 20:48:24 +02:00
|
|
|
#include <boost/filesystem/path.hpp>
|
|
|
|
|
2014-09-02 10:21:17 +02:00
|
|
|
#include <QObject>
|
|
|
|
#include <QProcess>
|
2014-09-05 13:49:34 +02:00
|
|
|
#include <QTextDocument>
|
2014-09-02 10:21:17 +02:00
|
|
|
|
2014-09-05 11:03:16 +02:00
|
|
|
#include <components/esm/debugprofile.hpp>
|
|
|
|
|
2014-09-05 11:40:01 +02:00
|
|
|
class QTemporaryFile;
|
|
|
|
|
2014-09-02 10:21:17 +02:00
|
|
|
namespace CSMDoc
|
|
|
|
{
|
2015-03-14 12:00:24 +01:00
|
|
|
class OperationHolder;
|
|
|
|
|
2014-09-02 10:21:17 +02:00
|
|
|
class Runner : public QObject
|
|
|
|
{
|
|
|
|
Q_OBJECT
|
|
|
|
|
|
|
|
QProcess mProcess;
|
2014-09-02 11:56:35 +02:00
|
|
|
bool mRunning;
|
2014-09-05 11:03:16 +02:00
|
|
|
ESM::DebugProfile mProfile;
|
2014-09-06 12:24:09 +02:00
|
|
|
std::vector<std::string> mContentFiles;
|
2014-09-05 11:40:01 +02:00
|
|
|
std::string mStartupInstruction;
|
|
|
|
QTemporaryFile *mStartup;
|
2014-09-05 13:49:34 +02:00
|
|
|
QTextDocument mLog;
|
2014-09-13 20:48:24 +02:00
|
|
|
boost::filesystem::path mProjectPath;
|
2014-09-02 10:21:17 +02:00
|
|
|
|
|
|
|
public:
|
|
|
|
|
2014-09-13 20:48:24 +02:00
|
|
|
Runner (const boost::filesystem::path& projectPath);
|
2014-09-02 10:21:17 +02:00
|
|
|
|
2014-09-03 20:06:49 +02:00
|
|
|
~Runner();
|
|
|
|
|
2014-09-03 19:56:52 +02:00
|
|
|
/// \param delayed Flag as running but do not start the OpenMW process yet (the
|
|
|
|
/// process must be started by another call of start with delayed==false)
|
|
|
|
void start (bool delayed = false);
|
2014-09-02 10:21:17 +02:00
|
|
|
|
|
|
|
void stop();
|
|
|
|
|
2014-09-02 11:56:35 +02:00
|
|
|
/// \note Running state is entered when the start function is called. This
|
|
|
|
/// is not necessarily identical to the moment the child process is started.
|
|
|
|
bool isRunning() const;
|
|
|
|
|
2014-09-05 11:40:01 +02:00
|
|
|
void configure (const ESM::DebugProfile& profile,
|
2014-09-06 12:24:09 +02:00
|
|
|
const std::vector<std::string>& contentFiles,
|
2014-09-05 11:40:01 +02:00
|
|
|
const std::string& startupInstruction);
|
2014-09-05 11:03:16 +02:00
|
|
|
|
2014-09-05 13:49:34 +02:00
|
|
|
QTextDocument *getLog();
|
|
|
|
|
2014-09-02 10:21:17 +02:00
|
|
|
signals:
|
|
|
|
|
2014-09-02 11:56:35 +02:00
|
|
|
void runStateChanged();
|
2014-09-02 10:21:17 +02:00
|
|
|
|
|
|
|
private slots:
|
|
|
|
|
|
|
|
void finished (int exitCode, QProcess::ExitStatus exitStatus);
|
2014-09-05 13:49:34 +02:00
|
|
|
|
|
|
|
void readyReadStandardOutput();
|
2014-09-02 10:21:17 +02:00
|
|
|
};
|
2014-09-03 19:56:52 +02:00
|
|
|
|
|
|
|
class Operation;
|
|
|
|
|
|
|
|
/// \brief Watch for end of save operation and restart or stop runner
|
|
|
|
class SaveWatcher : public QObject
|
|
|
|
{
|
|
|
|
Q_OBJECT
|
|
|
|
|
|
|
|
Runner *mRunner;
|
|
|
|
|
|
|
|
public:
|
|
|
|
|
|
|
|
/// *this attaches itself to runner
|
2015-03-14 12:00:24 +01:00
|
|
|
SaveWatcher (Runner *runner, OperationHolder *operation);
|
2014-09-03 19:56:52 +02:00
|
|
|
|
|
|
|
private slots:
|
|
|
|
|
|
|
|
void saveDone (int type, bool failed);
|
|
|
|
};
|
2014-09-02 10:21:17 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
#endif
|