MultiMC5/api/logic/tools/JProfiler.cpp

117 lines
2.8 KiB
C++
Raw Normal View History

#include "JProfiler.h"
#include <QDir>
2015-02-09 00:51:14 +00:00
#include "settings/SettingsObject.h"
#include "launch/LaunchTask.h"
2015-02-09 00:51:14 +00:00
#include "BaseInstance.h"
2015-04-06 18:52:59 +00:00
class JProfiler : public BaseProfiler
{
Q_OBJECT
public:
JProfiler(SettingsObjectPtr settings, InstancePtr instance, QObject *parent = 0);
private slots:
void profilerStarted();
void profilerFinished(int exit, QProcess::ExitStatus status);
protected:
void beginProfilingImpl(std::shared_ptr<LaunchTask> process);
2015-04-06 18:52:59 +00:00
private:
int listeningPort = 0;
};
2015-02-09 00:51:14 +00:00
JProfiler::JProfiler(SettingsObjectPtr settings, InstancePtr instance,
QObject *parent)
: BaseProfiler(settings, instance, parent)
{
}
2015-04-06 18:52:59 +00:00
void JProfiler::profilerStarted()
{
emit readyToLaunch(tr("Listening on port: %1").arg(listeningPort));
}
void JProfiler::profilerFinished(int exit, QProcess::ExitStatus status)
{
if (status == QProcess::CrashExit)
{
emit abortLaunch(tr("Profiler aborted"));
}
if (m_profilerProcess)
{
m_profilerProcess->deleteLater();
m_profilerProcess = 0;
}
}
void JProfiler::beginProfilingImpl(std::shared_ptr<LaunchTask> process)
{
2015-04-06 18:52:59 +00:00
listeningPort = globalSettings->get("JProfilerPort").toInt();
QProcess *profiler = new QProcess(this);
2015-04-06 18:52:59 +00:00
QStringList profilerArgs =
{
"-d", QString::number(process->pid()),
2015-04-06 18:52:59 +00:00
"--gui",
"-p", QString::number(listeningPort)
};
auto basePath = globalSettings->get("JProfilerPath").toString();
#ifdef Q_OS_WIN
2015-04-06 18:52:59 +00:00
QString profilerProgram = QDir(basePath).absoluteFilePath("bin/jpenable.exe");
#else
2015-04-06 18:52:59 +00:00
QString profilerProgram = QDir(basePath).absoluteFilePath("bin/jpenable");
#endif
2015-04-06 18:52:59 +00:00
profiler->setArguments(profilerArgs);
profiler->setProgram(profilerProgram);
connect(profiler, SIGNAL(started()), SLOT(profilerStarted()));
connect(profiler, SIGNAL(finished(int, QProcess::ExitStatus)), SLOT(profilerFinished(int,QProcess::ExitStatus)));
2014-02-16 08:30:38 +00:00
m_profilerProcess = profiler;
2015-04-06 18:52:59 +00:00
profiler->start();
}
2015-02-09 00:51:14 +00:00
void JProfilerFactory::registerSettings(SettingsObjectPtr settings)
{
settings->registerSetting("JProfilerPath");
settings->registerSetting("JProfilerPort", 42042);
2015-02-09 00:51:14 +00:00
globalSettings = settings;
}
2014-03-30 18:11:05 +00:00
BaseExternalTool *JProfilerFactory::createTool(InstancePtr instance, QObject *parent)
{
2015-02-09 00:51:14 +00:00
return new JProfiler(globalSettings, instance, parent);
}
bool JProfilerFactory::check(QString *error)
{
2015-02-09 00:51:14 +00:00
return check(globalSettings->get("JProfilerPath").toString(), error);
}
bool JProfilerFactory::check(const QString &path, QString *error)
{
if (path.isEmpty())
{
*error = QObject::tr("Empty path");
return false;
}
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/jprofiler.exe")) || !dir.exists("bin/agent.jar"))
{
*error = QObject::tr("Invalid JProfiler install");
return false;
}
return true;
}
2015-04-06 18:52:59 +00:00
#include "JProfiler.moc"