/************************************************************************** ** ** This file is part of Qt Creator ** ** Copyright (c) 2010 Nokia Corporation and/or its subsidiary(-ies). ** ** Contact: Nokia Corporation (qt-info@nokia.com) ** ** Commercial Usage ** ** Licensees holding valid Qt Commercial licenses may use this file in ** accordance with the Qt Commercial License Agreement provided with the ** Software or, alternatively, in accordance with the terms contained in ** a written agreement between you and Nokia. ** ** GNU Lesser General Public License Usage ** ** Alternatively, this file may be used under the terms of the GNU Lesser ** General Public License version 2.1 as published by the Free Software ** Foundation and appearing in the file LICENSE.LGPL included in the ** packaging of this file. Please review the following information to ** ensure the GNU Lesser General Public License version 2.1 requirements ** will be met: http://www.gnu.org/licenses/old-licenses/lgpl-2.1.html. ** ** If you are unsure which license is appropriate for your use, please ** contact the sales department at http://qt.nokia.com/contact. ** **************************************************************************/ #include "debuggerrunner.h" #include <projectexplorer/debugginghelper.h> #include <projectexplorer/environment.h> #include <projectexplorer/project.h> #include <projectexplorer/projectexplorerconstants.h> #include <projectexplorer/target.h> #include <projectexplorer/buildconfiguration.h> #include <utils/qtcassert.h> #include <coreplugin/icore.h> #include <QtCore/QDebug> #include <QtCore/QDir> #include <QtCore/QFileInfo> #include <QtGui/QTextDocument> namespace Debugger { namespace Internal { using ProjectExplorer::BuildConfiguration; using ProjectExplorer::RunConfiguration; using ProjectExplorer::RunControl; using ProjectExplorer::LocalApplicationRunConfiguration; //////////////////////////////////////////////////////////////////////// // // DebuggerRunControlFactory // //////////////////////////////////////////////////////////////////////// // A factory to create DebuggerRunControls DebuggerRunControlFactory::DebuggerRunControlFactory(DebuggerManager *manager) : m_manager(manager) {} bool DebuggerRunControlFactory::canRun(RunConfiguration *runConfiguration, const QString &mode) const { // return mode == ProjectExplorer::Constants::DEBUGMODE; return mode == ProjectExplorer::Constants::DEBUGMODE && qobject_cast<LocalApplicationRunConfiguration *>(runConfiguration); } QString DebuggerRunControlFactory::displayName() const { return tr("Debug"); } RunControl *DebuggerRunControlFactory::create(const DebuggerStartParametersPtr &sp) { return new DebuggerRunControl(m_manager, sp); } RunControl *DebuggerRunControlFactory::create(RunConfiguration *runConfiguration, const QString &mode) { QTC_ASSERT(mode == ProjectExplorer::Constants::DEBUGMODE, return 0); LocalApplicationRunConfiguration *rc = qobject_cast<LocalApplicationRunConfiguration *>(runConfiguration); QTC_ASSERT(rc, return 0); return new DebuggerRunControl(m_manager, rc); } QWidget *DebuggerRunControlFactory::createConfigurationWidget(RunConfiguration *runConfiguration) { // NBS TODO: Add GDB-specific configuration widget Q_UNUSED(runConfiguration) return 0; } //////////////////////////////////////////////////////////////////////// // // DebuggerRunControl // //////////////////////////////////////////////////////////////////////// DebuggerRunControl::DebuggerRunControl(DebuggerManager *manager, LocalApplicationRunConfiguration *runConfiguration) : RunControl(runConfiguration, ProjectExplorer::Constants::DEBUGMODE), m_startParameters(new DebuggerStartParameters()), m_manager(manager), m_running(false) { init(); if (!runConfiguration) return; m_startParameters->startMode = StartInternal; m_startParameters->executable = runConfiguration->executable(); m_startParameters->environment = runConfiguration->environment().toStringList(); m_startParameters->workingDirectory = runConfiguration->workingDirectory(); m_startParameters->processArgs = runConfiguration->commandLineArguments(); switch (m_startParameters->toolChainType) { case ProjectExplorer::ToolChain::UNKNOWN: case ProjectExplorer::ToolChain::INVALID: m_startParameters->toolChainType = runConfiguration->toolChainType(); break; default: break; } if (runConfiguration->target()->project()) { BuildConfiguration *bc = runConfiguration->target()->activeBuildConfiguration(); if (bc) m_startParameters->buildDirectory = bc->buildDirectory(); } m_startParameters->useTerminal = runConfiguration->runMode() == LocalApplicationRunConfiguration::Console; m_startParameters->dumperLibrary = runConfiguration->dumperLibrary(); m_startParameters->dumperLibraryLocations = runConfiguration->dumperLibraryLocations(); QString qmakePath = ProjectExplorer::DebuggingHelperLibrary::findSystemQt( runConfiguration->environment()); if (!qmakePath.isEmpty()) { QProcess proc; QStringList args; args.append(QLatin1String("-query")); args.append(QLatin1String("QT_INSTALL_HEADERS")); proc.start(qmakePath, args); proc.waitForFinished(); QByteArray ba = proc.readAllStandardOutput().trimmed(); QFileInfo fi(QString::fromLocal8Bit(ba) + "/.."); m_startParameters->qtInstallPath = fi.absoluteFilePath(); } } DebuggerRunControl::DebuggerRunControl(DebuggerManager *manager, const DebuggerStartParametersPtr &startParameters) : RunControl(0, ProjectExplorer::Constants::DEBUGMODE), m_startParameters(startParameters), m_manager(manager), m_running(false) { init(); if (m_startParameters->environment.empty()) m_startParameters->environment = ProjectExplorer::Environment().toStringList(); m_startParameters->useTerminal = false; } QString DebuggerRunControl::displayName() const { return tr("Core file: \"%1\"").arg(m_startParameters->coreFile); } void DebuggerRunControl::setCustomEnvironment(ProjectExplorer::Environment env) { m_startParameters->environment = env.toStringList(); } void DebuggerRunControl::init() { connect(m_manager, SIGNAL(debuggingFinished()), this, SLOT(debuggingFinished()), Qt::QueuedConnection); connect(m_manager, SIGNAL(applicationOutputAvailable(QString, bool)), this, SLOT(slotAddToOutputWindowInline(QString, bool)), Qt::QueuedConnection); connect(m_manager, SIGNAL(messageAvailable(QString, bool)), this, SLOT(slotMessageAvailable(QString, bool))); connect(m_manager, SIGNAL(inferiorPidChanged(qint64)), this, SLOT(bringApplicationToForeground(qint64)), Qt::QueuedConnection); connect(this, SIGNAL(stopRequested()), m_manager, SLOT(exitDebugger())); } void DebuggerRunControl::start() { m_running = true; QString errorMessage; QString settingsCategory; QString settingsPage; if (m_manager->checkDebugConfiguration(startParameters()->toolChainType, &errorMessage, &settingsCategory, &settingsPage)) { m_manager->startNewDebugger(m_startParameters); emit started(); } else { appendMessage(this, errorMessage, true); emit finished(); Core::ICore::instance()->showWarningWithOptions(tr("Debugger"), errorMessage, QString(), settingsCategory, settingsPage); } } void DebuggerRunControl::slotAddToOutputWindowInline(const QString &data, bool onStdErr) { emit addToOutputWindowInline(this, data, onStdErr); } void DebuggerRunControl::slotMessageAvailable(const QString &data, bool isError) { emit appendMessage(this, data, isError); } void DebuggerRunControl::stop() { m_running = false; emit stopRequested(); } void DebuggerRunControl::debuggingFinished() { m_running = false; emit finished(); } bool DebuggerRunControl::isRunning() const { return m_running; } } // namespace Internal } // namespace Debugger