2014-02-15 14:19:35 +01:00
|
|
|
#include "JProfiler.h"
|
|
|
|
|
|
|
|
#include <QDir>
|
|
|
|
#include <QMessageBox>
|
|
|
|
|
|
|
|
#include "settingsobject.h"
|
|
|
|
#include "logic/MinecraftProcess.h"
|
2014-02-15 22:26:44 +01:00
|
|
|
#include "logic/BaseInstance.h"
|
2014-02-15 14:19:35 +01:00
|
|
|
#include "MultiMC.h"
|
|
|
|
|
2014-03-30 20:11:05 +02:00
|
|
|
JProfiler::JProfiler(InstancePtr instance, QObject *parent) : BaseProfiler(instance, parent)
|
2014-02-15 14:19:35 +01:00
|
|
|
{
|
|
|
|
}
|
|
|
|
|
|
|
|
void JProfiler::beginProfilingImpl(MinecraftProcess *process)
|
|
|
|
{
|
|
|
|
int port = MMC->settings()->get("JProfilerPort").toInt();
|
|
|
|
QProcess *profiler = new QProcess(this);
|
2014-02-15 18:15:41 +01:00
|
|
|
profiler->setArguments(QStringList() << "-d" << QString::number(pid(process)) << "--gui"
|
2014-02-15 14:19:35 +01:00
|
|
|
<< "-p" << QString::number(port));
|
|
|
|
profiler->setProgram(QDir(MMC->settings()->get("JProfilerPath").toString())
|
|
|
|
.absoluteFilePath("bin/jpenable"));
|
|
|
|
connect(profiler, &QProcess::started, [this, port]()
|
|
|
|
{ emit readyToLaunch(tr("Listening on port: %1").arg(port)); });
|
2014-02-16 08:54:52 +01:00
|
|
|
connect(profiler,
|
|
|
|
static_cast<void (QProcess::*)(int, QProcess::ExitStatus)>(&QProcess::finished),
|
|
|
|
[this](int exit, QProcess::ExitStatus status)
|
|
|
|
{
|
2014-02-16 09:30:38 +01:00
|
|
|
if (status == QProcess::CrashExit)
|
2014-02-16 08:54:52 +01:00
|
|
|
{
|
|
|
|
emit abortLaunch(tr("Profiler aborted"));
|
|
|
|
}
|
2014-02-16 09:30:38 +01:00
|
|
|
if (m_profilerProcess)
|
|
|
|
{
|
|
|
|
m_profilerProcess->deleteLater();
|
|
|
|
m_profilerProcess = 0;
|
|
|
|
}
|
2014-02-16 08:54:52 +01:00
|
|
|
});
|
2014-02-15 14:19:35 +01:00
|
|
|
profiler->start();
|
2014-02-16 09:30:38 +01:00
|
|
|
m_profilerProcess = profiler;
|
2014-02-15 14:19:35 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
void JProfilerFactory::registerSettings(SettingsObject *settings)
|
|
|
|
{
|
|
|
|
settings->registerSetting("JProfilerPath");
|
|
|
|
settings->registerSetting("JProfilerPort", 42042);
|
|
|
|
}
|
|
|
|
|
2014-03-30 20:11:05 +02:00
|
|
|
BaseExternalTool *JProfilerFactory::createTool(InstancePtr instance, QObject *parent)
|
2014-02-15 14:19:35 +01:00
|
|
|
{
|
|
|
|
return new JProfiler(instance, parent);
|
|
|
|
}
|
|
|
|
|
2014-02-15 22:26:44 +01:00
|
|
|
bool JProfilerFactory::check(QString *error)
|
|
|
|
{
|
|
|
|
return check(MMC->settings()->get("JProfilerPath").toString(), error);
|
|
|
|
}
|
|
|
|
|
2014-02-15 14:19:35 +01:00
|
|
|
bool JProfilerFactory::check(const QString &path, QString *error)
|
|
|
|
{
|
2014-02-15 22:26:44 +01:00
|
|
|
if (path.isEmpty())
|
|
|
|
{
|
|
|
|
*error = QObject::tr("Empty path");
|
|
|
|
return false;
|
|
|
|
}
|
2014-02-15 14:19:35 +01:00
|
|
|
QDir dir(path);
|
|
|
|
if (!dir.exists())
|
|
|
|
{
|
|
|
|
*error = QObject::tr("Path does not exist");
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
if (!dir.exists("bin") || !dir.exists("bin/jprofiler") || !dir.exists("bin/agent.jar"))
|
|
|
|
{
|
|
|
|
*error = QObject::tr("Invalid JProfiler install");
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
return true;
|
|
|
|
}
|