2014-09-02 10:21:17 +02:00
|
|
|
|
|
|
|
#include "runner.hpp"
|
|
|
|
|
2014-09-05 11:40:01 +02:00
|
|
|
#include <QTemporaryFile>
|
|
|
|
#include <QTextStream>
|
|
|
|
|
2014-09-03 19:56:52 +02:00
|
|
|
#include "operation.hpp"
|
2014-09-02 10:21:17 +02:00
|
|
|
|
2014-09-05 11:40:01 +02:00
|
|
|
CSMDoc::Runner::Runner() : mRunning (false), mStartup (0)
|
2014-09-02 10:21:17 +02:00
|
|
|
{
|
|
|
|
connect (&mProcess, SIGNAL (finished (int, QProcess::ExitStatus)),
|
|
|
|
this, SLOT (finished (int, QProcess::ExitStatus)));
|
2014-09-05 11:03:16 +02:00
|
|
|
|
2014-09-05 13:49:34 +02:00
|
|
|
connect (&mProcess, SIGNAL (readyReadStandardOutput()),
|
|
|
|
this, SLOT (readyReadStandardOutput()));
|
|
|
|
|
|
|
|
mProcess.setProcessChannelMode (QProcess::MergedChannels);
|
|
|
|
|
2014-09-05 11:03:16 +02:00
|
|
|
mProfile.blank();
|
2014-09-02 10:21:17 +02:00
|
|
|
}
|
|
|
|
|
2014-09-03 20:06:49 +02:00
|
|
|
CSMDoc::Runner::~Runner()
|
|
|
|
{
|
|
|
|
if (mRunning)
|
|
|
|
{
|
|
|
|
disconnect (&mProcess, 0, this, 0);
|
|
|
|
mProcess.kill();
|
|
|
|
mProcess.waitForFinished();
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2014-09-03 19:56:52 +02:00
|
|
|
void CSMDoc::Runner::start (bool delayed)
|
2014-09-02 10:21:17 +02:00
|
|
|
{
|
2014-09-05 11:40:01 +02:00
|
|
|
if (mStartup)
|
|
|
|
{
|
|
|
|
delete mStartup;
|
|
|
|
mStartup = 0;
|
|
|
|
}
|
|
|
|
|
2014-09-03 19:56:52 +02:00
|
|
|
if (!delayed)
|
|
|
|
{
|
2014-09-05 13:49:34 +02:00
|
|
|
mLog.clear();
|
|
|
|
|
2014-09-03 19:56:52 +02:00
|
|
|
QString path = "openmw";
|
2014-09-02 10:21:17 +02:00
|
|
|
#ifdef Q_OS_WIN
|
2014-09-03 19:56:52 +02:00
|
|
|
path.append(QString(".exe"));
|
2014-09-02 10:21:17 +02:00
|
|
|
#elif defined(Q_OS_MAC)
|
2014-09-03 19:56:52 +02:00
|
|
|
QDir dir(QCoreApplication::applicationDirPath());
|
|
|
|
path = dir.absoluteFilePath(name);
|
2014-09-02 10:21:17 +02:00
|
|
|
#else
|
2014-09-03 19:56:52 +02:00
|
|
|
path.prepend(QString("./"));
|
2014-09-02 10:21:17 +02:00
|
|
|
#endif
|
|
|
|
|
2014-09-05 11:40:01 +02:00
|
|
|
mStartup = new QTemporaryFile (this);
|
|
|
|
mStartup->open();
|
|
|
|
|
|
|
|
{
|
|
|
|
QTextStream stream (mStartup);
|
|
|
|
|
|
|
|
if (!mStartupInstruction.empty())
|
|
|
|
stream << QString::fromUtf8 (mStartupInstruction.c_str()) << '\n';
|
|
|
|
|
|
|
|
stream << QString::fromUtf8 (mProfile.mScriptText.c_str());
|
|
|
|
}
|
|
|
|
|
|
|
|
mStartup->close();
|
|
|
|
|
2014-09-05 11:03:16 +02:00
|
|
|
QStringList arguments;
|
|
|
|
arguments << "--skip-menu";
|
|
|
|
|
|
|
|
if (mProfile.mFlags & ESM::DebugProfile::Flag_BypassNewGame)
|
|
|
|
arguments << "--new-game=0";
|
|
|
|
else
|
|
|
|
arguments << "--new-game=1";
|
|
|
|
|
2014-09-05 11:40:01 +02:00
|
|
|
arguments << ("--script-run="+mStartup->fileName());
|
|
|
|
|
2014-09-06 12:24:09 +02:00
|
|
|
for (std::vector<std::string>::const_iterator iter (mContentFiles.begin());
|
|
|
|
iter!=mContentFiles.end(); ++iter)
|
|
|
|
{
|
|
|
|
arguments << QString::fromUtf8 (("--content="+*iter).c_str());
|
|
|
|
}
|
|
|
|
|
2014-09-05 11:03:16 +02:00
|
|
|
mProcess.start (path, arguments);
|
2014-09-03 19:56:52 +02:00
|
|
|
}
|
|
|
|
|
2014-09-02 11:56:35 +02:00
|
|
|
mRunning = true;
|
|
|
|
emit runStateChanged();
|
2014-09-02 10:21:17 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
void CSMDoc::Runner::stop()
|
|
|
|
{
|
2014-09-05 11:40:01 +02:00
|
|
|
delete mStartup;
|
|
|
|
mStartup = 0;
|
|
|
|
|
2014-09-03 19:56:52 +02:00
|
|
|
if (mProcess.state()==QProcess::NotRunning)
|
|
|
|
{
|
|
|
|
mRunning = false;
|
|
|
|
emit runStateChanged();
|
|
|
|
}
|
|
|
|
else
|
|
|
|
mProcess.kill();
|
2014-09-02 10:21:17 +02:00
|
|
|
}
|
|
|
|
|
2014-09-02 11:56:35 +02:00
|
|
|
bool CSMDoc::Runner::isRunning() const
|
|
|
|
{
|
|
|
|
return mRunning;
|
|
|
|
}
|
|
|
|
|
2014-09-05 11:40:01 +02:00
|
|
|
void CSMDoc::Runner::configure (const ESM::DebugProfile& profile,
|
2014-09-06 12:24:09 +02:00
|
|
|
const std::vector<std::string>& contentFiles, const std::string& startupInstruction)
|
2014-09-05 11:03:16 +02:00
|
|
|
{
|
|
|
|
mProfile = profile;
|
2014-09-06 12:24:09 +02:00
|
|
|
mContentFiles = contentFiles;
|
2014-09-05 11:40:01 +02:00
|
|
|
mStartupInstruction = startupInstruction;
|
2014-09-05 11:03:16 +02:00
|
|
|
}
|
|
|
|
|
2014-09-02 10:21:17 +02:00
|
|
|
void CSMDoc::Runner::finished (int exitCode, QProcess::ExitStatus exitStatus)
|
|
|
|
{
|
2014-09-02 11:56:35 +02:00
|
|
|
mRunning = false;
|
|
|
|
emit runStateChanged();
|
2014-09-02 10:21:17 +02:00
|
|
|
}
|
2014-09-03 19:56:52 +02:00
|
|
|
|
2014-09-05 13:49:34 +02:00
|
|
|
QTextDocument *CSMDoc::Runner::getLog()
|
|
|
|
{
|
|
|
|
return &mLog;
|
|
|
|
}
|
|
|
|
|
|
|
|
void CSMDoc::Runner::readyReadStandardOutput()
|
|
|
|
{
|
|
|
|
mLog.setPlainText (
|
|
|
|
mLog.toPlainText() + QString::fromUtf8 (mProcess.readAllStandardOutput()));
|
|
|
|
}
|
|
|
|
|
2014-09-03 19:56:52 +02:00
|
|
|
|
|
|
|
CSMDoc::SaveWatcher::SaveWatcher (Runner *runner, Operation *operation)
|
|
|
|
: QObject (runner), mRunner (runner)
|
|
|
|
{
|
|
|
|
connect (operation, SIGNAL (done (int, bool)), this, SLOT (saveDone (int, bool)));
|
|
|
|
}
|
|
|
|
|
|
|
|
void CSMDoc::SaveWatcher::saveDone (int type, bool failed)
|
|
|
|
{
|
|
|
|
if (failed)
|
|
|
|
mRunner->stop();
|
|
|
|
else
|
|
|
|
mRunner->start();
|
|
|
|
|
|
|
|
deleteLater();
|
|
|
|
}
|