aboutsummaryrefslogtreecommitdiffstats
path: root/src/plugins/valgrind/callgrindengine.cpp
diff options
context:
space:
mode:
authorhjk <hjk@qt.io>2017-06-20 18:01:25 +0200
committerhjk <hjk@qt.io>2017-06-22 08:42:34 +0000
commitfe3facb015099a27900dea8dd8ddcfce7a519ca9 (patch)
treeee944c44f7e6b492be3057cd95bedd7a5d835aaa /src/plugins/valgrind/callgrindengine.cpp
parentacc9da0861d9c5054a797fea526c372583c34527 (diff)
Valgrind: Dissolve CallGrindRunner
Basically merge with CallGrindToolRunner, to which there was a 1:1 relationship. Change-Id: Iebd9325c36e82b966f873d380395065e087958e4 Reviewed-by: Christian Stenger <christian.stenger@qt.io>
Diffstat (limited to 'src/plugins/valgrind/callgrindengine.cpp')
-rw-r--r--src/plugins/valgrind/callgrindengine.cpp79
1 files changed, 69 insertions, 10 deletions
diff --git a/src/plugins/valgrind/callgrindengine.cpp b/src/plugins/valgrind/callgrindengine.cpp
index 500e84a5ac..cadbf9cf4f 100644
--- a/src/plugins/valgrind/callgrindengine.cpp
+++ b/src/plugins/valgrind/callgrindengine.cpp
@@ -38,17 +38,34 @@
using namespace Debugger;
using namespace Valgrind;
using namespace Valgrind::Internal;
+using namespace Valgrind::Callgrind;
CallgrindToolRunner::CallgrindToolRunner(ProjectExplorer::RunControl *runControl)
: ValgrindToolRunner(runControl)
{
setDisplayName("CallgrindToolRunner");
- connect(&m_runner, &Callgrind::CallgrindRunner::finished,
+ m_runner.setToolName("callgrind");
+
+ connect(&m_runner, &ValgrindRunner::finished,
this, &CallgrindToolRunner::slotFinished);
- connect(m_runner.parser(), &Callgrind::Parser::parserDataReady,
+ connect(&m_parser, &Callgrind::Parser::parserDataReady,
this, &CallgrindToolRunner::slotFinished);
- connect(&m_runner, &Callgrind::CallgrindRunner::statusMessage,
- this, &Debugger::showPermanentStatusMessage);
+
+ connect(&m_controller, &CallgrindController::finished,
+ this, &CallgrindToolRunner::controllerFinished);
+ connect(&m_controller, &CallgrindController::localParseDataAvailable,
+ this, &CallgrindToolRunner::localParseDataAvailable);
+ connect(&m_controller, &CallgrindController::statusMessage,
+ this, &CallgrindToolRunner::showStatusMessage);
+
+ connect(&m_runner, &ValgrindRunner::extraStart, this, [this] {
+ m_controller.setValgrindProcess(m_runner.valgrindProcess());
+ });
+
+ connect(&m_runner, &ValgrindRunner::extraProcessFinished, this, [this] {
+ triggerParse();
+ m_controller.setValgrindProcess(nullptr);
+ });
}
QStringList CallgrindToolRunner::toolArguments() const
@@ -97,7 +114,7 @@ void CallgrindToolRunner::start()
void CallgrindToolRunner::dump()
{
- m_runner.controller()->run(Callgrind::CallgrindController::Dump);
+ m_controller.run(CallgrindController::Dump);
}
void CallgrindToolRunner::setPaused(bool paused)
@@ -108,7 +125,7 @@ void CallgrindToolRunner::setPaused(bool paused)
m_markAsPaused = paused;
// call controller only if it is attached to a valgrind process
- if (m_runner.controller()->valgrindProcess()) {
+ if (m_controller.valgrindProcess()) {
if (paused)
pause();
else
@@ -126,25 +143,67 @@ void CallgrindToolRunner::setToggleCollectFunction(const QString &toggleCollectF
void CallgrindToolRunner::reset()
{
- m_runner.controller()->run(Callgrind::CallgrindController::ResetEventCounters);
+ m_controller.run(Callgrind::CallgrindController::ResetEventCounters);
}
void CallgrindToolRunner::pause()
{
- m_runner.controller()->run(Callgrind::CallgrindController::Pause);
+ m_controller.run(Callgrind::CallgrindController::Pause);
}
void CallgrindToolRunner::unpause()
{
- m_runner.controller()->run(Callgrind::CallgrindController::UnPause);
+ m_controller.run(Callgrind::CallgrindController::UnPause);
}
Callgrind::ParseData *CallgrindToolRunner::takeParserData()
{
- return m_runner.parser()->takeData();
+ return m_parser.takeData();
}
void CallgrindToolRunner::slotFinished()
{
emit parserDataReady(this);
}
+
+void CallgrindToolRunner::showStatusMessage(const QString &message)
+{
+ Debugger::showPermanentStatusMessage(message);
+}
+
+void CallgrindToolRunner::triggerParse()
+{
+ m_controller.getLocalDataFile();
+}
+
+void CallgrindToolRunner::localParseDataAvailable(const QString &file)
+{
+ // parse the callgrind file
+ QTC_ASSERT(!file.isEmpty(), return);
+ QFile outputFile(file);
+ QTC_ASSERT(outputFile.exists(), return);
+ if (outputFile.open(QIODevice::ReadOnly)) {
+ showStatusMessage(tr("Parsing Profile Data..."));
+ m_parser.parse(&outputFile);
+ } else {
+ qWarning() << "Could not open file for parsing:" << outputFile.fileName();
+ }
+}
+
+void CallgrindToolRunner::controllerFinished(CallgrindController::Option option)
+{
+ switch (option)
+ {
+ case CallgrindController::Pause:
+ m_paused = true;
+ break;
+ case CallgrindController::UnPause:
+ m_paused = false;
+ break;
+ case CallgrindController::Dump:
+ triggerParse();
+ break;
+ default:
+ break; // do nothing
+ }
+}