/**************************************************************************** ** ** Copyright (C) 2016 Kläralvdalens Datakonsult AB, a KDAB Group company, info@kdab.com ** Contact: https://www.qt.io/licensing/ ** ** This file is part of Qt Creator. ** ** Commercial License Usage ** Licensees holding valid commercial Qt licenses may use this file in ** accordance with the commercial license agreement provided with the ** Software or, alternatively, in accordance with the terms contained in ** a written agreement between you and The Qt Company. For licensing terms ** and conditions see https://www.qt.io/terms-conditions. For further ** information use the contact form at https://www.qt.io/contact-us. ** ** GNU General Public License Usage ** Alternatively, this file may be used under the terms of the GNU ** General Public License version 3 as published by the Free Software ** Foundation with exceptions as appearing in the file LICENSE.GPL3-EXCEPT ** included in the packaging of this file. Please review the following ** information to ensure the GNU General Public License requirements will ** be met: https://www.gnu.org/licenses/gpl-3.0.html. ** ****************************************************************************/ #include "valgrindruncontrolfactory.h" #include "valgrindengine.h" #include "valgrindsettings.h" #include "valgrindplugin.h" #include "callgrindtool.h" #include "memchecktool.h" #include #include #include #include #include #include #include #include #include #include #include #include #include #include using namespace Analyzer; using namespace ProjectExplorer; using namespace Utils; namespace Valgrind { namespace Internal { ValgrindRunControlFactory::ValgrindRunControlFactory(QObject *parent) : IRunControlFactory(parent) { } bool ValgrindRunControlFactory::canRun(RunConfiguration *runConfiguration, Core::Id mode) const { Q_UNUSED(runConfiguration); return mode == CALLGRIND_RUN_MODE || mode == MEMCHECK_RUN_MODE || mode == MEMCHECK_WITH_GDB_RUN_MODE; } RunControl *ValgrindRunControlFactory::create(RunConfiguration *runConfiguration, Core::Id mode, QString *errorMessage) { Q_UNUSED(errorMessage); ApplicationLauncher::Mode localRunMode = ApplicationLauncher::Gui; Utils::Environment environment; AnalyzerStartParameters sp; QString workingDirectory; if (auto rc1 = qobject_cast(runConfiguration)) { EnvironmentAspect *aspect = runConfiguration->extraAspect(); if (aspect) environment = aspect->environment(); workingDirectory = rc1->workingDirectory(); sp.debuggee = rc1->executable(); sp.debuggeeArgs = rc1->commandLineArguments(); const IDevice::ConstPtr device = DeviceKitInformation::device(runConfiguration->target()->kit()); QTC_ASSERT(device, return 0); QTC_ASSERT(device->type() == ProjectExplorer::Constants::DESKTOP_DEVICE_TYPE, return 0); QTcpServer server; if (!server.listen(QHostAddress::LocalHost) && !server.listen(QHostAddress::LocalHostIPv6)) { qWarning() << "Cannot open port on host for profiling."; return 0; } sp.connParams.host = server.serverAddress().toString(); sp.connParams.port = server.serverPort(); localRunMode = rc1->runMode(); } else if (RemoteLinux::AbstractRemoteLinuxRunConfiguration *rc2 = qobject_cast(runConfiguration)) { sp.debuggee = rc2->remoteExecutableFilePath(); sp.connParams = DeviceKitInformation::device(rc2->target()->kit())->sshParameters(); sp.debuggeeArgs = rc2->arguments(); } else { QTC_ASSERT(false, return 0); } auto analyzerRunControl = AnalyzerManager::createRunControl(sp, runConfiguration, mode); if (auto valgrindRunControl = qobject_cast(analyzerRunControl)) { valgrindRunControl->setLocalRunMode(localRunMode); valgrindRunControl->setEnvironment(environment); valgrindRunControl->setWorkingDirectory(workingDirectory); } return analyzerRunControl; } class ValgrindRunConfigurationAspect : public IRunConfigurationAspect { public: ValgrindRunConfigurationAspect(RunConfiguration *parent) : IRunConfigurationAspect(parent) { setProjectSettings(new ValgrindProjectSettings()); setGlobalSettings(ValgrindPlugin::globalSettings()); setId(ANALYZER_VALGRIND_SETTINGS); setDisplayName(QCoreApplication::translate("Valgrind::Internal::ValgrindRunConfigurationAspect", "Valgrind Settings")); setUsingGlobalSettings(true); resetProjectToGlobalSettings(); } ValgrindRunConfigurationAspect *create(RunConfiguration *parent) const override { return new ValgrindRunConfigurationAspect(parent); } RunConfigWidget *createConfigurationWidget() override { return new AnalyzerRunConfigWidget(this); } }; IRunConfigurationAspect *ValgrindRunControlFactory::createRunConfigurationAspect(RunConfiguration *rc) { return new ValgrindRunConfigurationAspect(rc); } } // namespace Internal } // namespace Valgrind