openmw-tes3coop/apps/opencs/model/doc/runner.hpp

83 lines
1.9 KiB
C++
Raw Normal View History

2014-09-02 08:21:17 +00:00
#ifndef CSM_DOC_RUNNER_H
#define CSM_DOC_RUNNER_H
#include <vector>
#include <string>
2014-09-02 08:21:17 +00:00
#include <QObject>
#include <QProcess>
2014-09-05 11:49:34 +00:00
#include <QTextDocument>
2014-09-02 08:21:17 +00:00
#include <components/esm/debugprofile.hpp>
class QTemporaryFile;
2014-09-02 08:21:17 +00:00
namespace CSMDoc
{
class Runner : public QObject
{
Q_OBJECT
QProcess mProcess;
bool mRunning;
ESM::DebugProfile mProfile;
std::vector<std::string> mContentFiles;
std::string mStartupInstruction;
QTemporaryFile *mStartup;
2014-09-05 11:49:34 +00:00
QTextDocument mLog;
2014-09-02 08:21:17 +00:00
public:
Runner();
~Runner();
/// \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 08:21:17 +00:00
void stop();
/// \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;
void configure (const ESM::DebugProfile& profile,
const std::vector<std::string>& contentFiles,
const std::string& startupInstruction);
2014-09-05 11:49:34 +00:00
QTextDocument *getLog();
2014-09-02 08:21:17 +00:00
signals:
void runStateChanged();
2014-09-02 08:21:17 +00:00
private slots:
void finished (int exitCode, QProcess::ExitStatus exitStatus);
2014-09-05 11:49:34 +00:00
void readyReadStandardOutput();
2014-09-02 08:21:17 +00: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
SaveWatcher (Runner *runner, Operation *operation);
private slots:
void saveDone (int type, bool failed);
};
2014-09-02 08:21:17 +00:00
}
#endif