summaryrefslogtreecommitdiff
path: root/src/plugins/qt4projectmanager/qt-desktop/qt4runconfiguration.cpp
diff options
context:
space:
mode:
Diffstat (limited to 'src/plugins/qt4projectmanager/qt-desktop/qt4runconfiguration.cpp')
-rw-r--r--src/plugins/qt4projectmanager/qt-desktop/qt4runconfiguration.cpp161
1 files changed, 100 insertions, 61 deletions
diff --git a/src/plugins/qt4projectmanager/qt-desktop/qt4runconfiguration.cpp b/src/plugins/qt4projectmanager/qt-desktop/qt4runconfiguration.cpp
index 044b5680c2..98ab43b34f 100644
--- a/src/plugins/qt4projectmanager/qt-desktop/qt4runconfiguration.cpp
+++ b/src/plugins/qt4projectmanager/qt-desktop/qt4runconfiguration.cpp
@@ -35,7 +35,6 @@
#include "makestep.h"
#include "qt4nodes.h"
#include "qt4project.h"
-#include "qt4target.h"
#include "qt4buildconfiguration.h"
#include "qt4projectmanagerconstants.h"
#include "qmakestep.h"
@@ -48,16 +47,20 @@
#include <coreplugin/helpmanager.h>
#include <projectexplorer/buildstep.h>
#include <projectexplorer/environmentwidget.h>
-#include <projectexplorer/toolchain.h>
+#include <projectexplorer/target.h>
+#include <projectexplorer/projectexplorerconstants.h>
#include <utils/qtcassert.h>
#include <utils/qtcprocess.h>
#include <utils/pathchooser.h>
#include <utils/detailswidget.h>
#include <utils/stringutils.h>
#include <utils/persistentsettings.h>
+#include <qtsupport/customexecutablerunconfiguration.h>
#include <qtsupport/qtoutputformatter.h>
+#include <qtsupport/qtsupportconstants.h>
#include <qtsupport/baseqtversion.h>
#include <qtsupport/profilereader.h>
+#include <qtsupport/qtprofileinformation.h>
#include <QFormLayout>
#include <QInputDialog>
@@ -76,7 +79,6 @@ using Utils::PersistentSettingsReader;
using Utils::PersistentSettingsWriter;
namespace {
-const char * const QT4_RC_ID("Qt4ProjectManager.Qt4RunConfiguration");
const char * const QT4_RC_PREFIX("Qt4ProjectManager.Qt4RunConfiguration.");
const char * const COMMAND_LINE_ARGUMENTS_KEY("Qt4ProjectManager.Qt4RunConfiguration.CommandLineArguments");
@@ -89,7 +91,7 @@ const char * const USER_WORKING_DIRECTORY_KEY("Qt4ProjectManager.Qt4RunConfigura
QString pathFromId(Core::Id id)
{
- QString idstr = QString::fromUtf8(id.name());
+ QString idstr = id.toString();
const QString prefix = QLatin1String(QT4_RC_PREFIX);
if (!idstr.startsWith(prefix))
return QString();
@@ -102,19 +104,21 @@ QString pathFromId(Core::Id id)
// Qt4RunConfiguration
//
-Qt4RunConfiguration::Qt4RunConfiguration(Qt4BaseTarget *parent, const QString &proFilePath) :
- LocalApplicationRunConfiguration(parent, Core::Id(QT4_RC_ID)),
- m_proFilePath(proFilePath),
+Qt4RunConfiguration::Qt4RunConfiguration(ProjectExplorer::Target *parent, Core::Id id) :
+ LocalApplicationRunConfiguration(parent, id),
+ m_proFilePath(pathFromId(id)),
m_runMode(Gui),
m_isUsingDyldImageSuffix(false),
- m_baseEnvironmentBase(Qt4RunConfiguration::BuildEnvironmentBase),
- m_parseSuccess(parent->qt4Project()->validParse(m_proFilePath)),
- m_parseInProgress(parent->qt4Project()->parseInProgress(m_proFilePath))
+ m_baseEnvironmentBase(Qt4RunConfiguration::BuildEnvironmentBase)
{
+ Qt4Project *project = static_cast<Qt4Project *>(parent->project());
+ m_parseSuccess = project->validParse(m_proFilePath);
+ m_parseInProgress = project->parseInProgress(m_proFilePath);
+
ctor();
}
-Qt4RunConfiguration::Qt4RunConfiguration(Qt4BaseTarget *parent, Qt4RunConfiguration *source) :
+Qt4RunConfiguration::Qt4RunConfiguration(ProjectExplorer::Target *parent, Qt4RunConfiguration *source) :
LocalApplicationRunConfiguration(parent, source),
m_commandLineArguments(source->m_commandLineArguments),
m_proFilePath(source->m_proFilePath),
@@ -133,11 +137,6 @@ Qt4RunConfiguration::~Qt4RunConfiguration()
{
}
-Qt4BaseTarget *Qt4RunConfiguration::qt4Target() const
-{
- return static_cast<Qt4BaseTarget *>(target());
-}
-
bool Qt4RunConfiguration::isEnabled() const
{
return m_parseSuccess && !m_parseInProgress;
@@ -150,7 +149,7 @@ QString Qt4RunConfiguration::disabledReason() const
.arg(QFileInfo(m_proFilePath).fileName());
if (!m_parseSuccess)
- return qt4Target()->qt4Project()->disabledReasonForRunConfiguration(m_proFilePath);
+ return static_cast<Qt4Project *>(target()->project())->disabledReasonForRunConfiguration(m_proFilePath);
return QString();
}
@@ -182,10 +181,22 @@ void Qt4RunConfiguration::ctor()
{
setDefaultDisplayName(defaultDisplayName());
- connect(qt4Target(), SIGNAL(environmentChanged()),
+ QtSupport::BaseQtVersion *version = QtSupport::QtProfileInformation::qtVersion(target()->profile());
+ m_forcedGuiMode = (version && version->type() == QtSupport::Constants::SIMULATORQT);
+
+ connect(target(), SIGNAL(environmentChanged()),
this, SIGNAL(baseEnvironmentChanged()));
- connect(qt4Target()->qt4Project(), SIGNAL(proFileUpdated(Qt4ProjectManager::Qt4ProFileNode*,bool,bool)),
+ connect(target()->project(), SIGNAL(proFileUpdated(Qt4ProjectManager::Qt4ProFileNode*,bool,bool)),
this, SLOT(proFileUpdated(Qt4ProjectManager::Qt4ProFileNode*,bool,bool)));
+ connect(target(), SIGNAL(profileChanged()),
+ this, SLOT(profileChanged()));
+}
+
+void Qt4RunConfiguration::profileChanged()
+{
+ QtSupport::BaseQtVersion *version = QtSupport::QtProfileInformation::qtVersion(target()->profile());
+ m_forcedGuiMode = (version && version->type() == QtSupport::Constants::SIMULATORQT);
+ emit runModeChanged(runMode()); // Always emit
}
//////
@@ -251,7 +262,7 @@ Qt4RunConfigurationWidget::Qt4RunConfigurationWidget(Qt4RunConfiguration *qt4Run
m_useTerminalCheck = new QCheckBox(tr("Run in terminal"), this);
m_useTerminalCheck->setChecked(m_qt4RunConfiguration->runMode() == ProjectExplorer::LocalApplicationRunConfiguration::Console);
toplayout->addRow(QString(), m_useTerminalCheck);
- m_useTerminalCheck->setVisible(qt4RunConfiguration->target()->id() != Core::Id(Constants::QT_SIMULATOR_TARGET_ID));
+ m_useTerminalCheck->setVisible(!m_qt4RunConfiguration->forcedGuiMode());
#ifdef Q_OS_MAC
m_usingDyldImageSuffix = new QCheckBox(tr("Use debug version of frameworks (DYLD_IMAGE_SUFFIX=_debug)"), this);
@@ -431,8 +442,10 @@ void Qt4RunConfigurationWidget::commandLineArgumentsChanged(const QString &args)
void Qt4RunConfigurationWidget::runModeChanged(LocalApplicationRunConfiguration::RunMode runMode)
{
- if (!m_ignoreChange)
+ if (!m_ignoreChange) {
+ m_useTerminalCheck->setVisible(!m_qt4RunConfiguration->forcedGuiMode());
m_useTerminalCheck->setChecked(runMode == LocalApplicationRunConfiguration::Console);
+ }
}
void Qt4RunConfigurationWidget::usingDyldImageSuffixChanged(bool state)
@@ -496,15 +509,15 @@ bool Qt4RunConfiguration::fromMap(const QVariantMap &map)
m_userEnvironmentChanges = Utils::EnvironmentItem::fromStringList(map.value(QLatin1String(USER_ENVIRONMENT_CHANGES_KEY)).toStringList());
m_baseEnvironmentBase = static_cast<BaseEnvironmentBase>(map.value(QLatin1String(BASE_ENVIRONMENT_BASE_KEY), static_cast<int>(Qt4RunConfiguration::BuildEnvironmentBase)).toInt());
- m_parseSuccess = qt4Target()->qt4Project()->validParse(m_proFilePath);
- m_parseInProgress = qt4Target()->qt4Project()->parseInProgress(m_proFilePath);
+ m_parseSuccess = static_cast<Qt4Project *>(target()->project())->validParse(m_proFilePath);
+ m_parseInProgress = static_cast<Qt4Project *>(target()->project())->parseInProgress(m_proFilePath);
return RunConfiguration::fromMap(map);
}
QString Qt4RunConfiguration::executable() const
{
- Qt4Project *pro = qt4Target()->qt4Project();
+ Qt4Project *pro = static_cast<Qt4Project *>(target()->project());
TargetInformation ti = pro->rootQt4ProjectNode()->targetInformation(m_proFilePath);
if (!ti.valid)
return QString();
@@ -513,9 +526,16 @@ QString Qt4RunConfiguration::executable() const
LocalApplicationRunConfiguration::RunMode Qt4RunConfiguration::runMode() const
{
+ if (m_forcedGuiMode)
+ return LocalApplicationRunConfiguration::Gui;
return m_runMode;
}
+bool Qt4RunConfiguration::forcedGuiMode() const
+{
+ return m_forcedGuiMode;
+}
+
bool Qt4RunConfiguration::isUsingDyldImageSuffix() const
{
return m_isUsingDyldImageSuffix;
@@ -540,7 +560,7 @@ QString Qt4RunConfiguration::baseWorkingDirectory() const
return m_userWorkingDirectory;
// else what the pro file reader tells us
- Qt4Project *pro = qt4Target()->qt4Project();
+ Qt4Project *pro = static_cast<Qt4Project *>(target()->project());
TargetInformation ti = pro->rootQt4ProjectNode()->targetInformation(m_proFilePath);
if (!ti.valid)
return QString();
@@ -575,7 +595,8 @@ Utils::Environment Qt4RunConfiguration::baseEnvironment() const
// Nothing
} else if (m_baseEnvironmentBase == Qt4RunConfiguration::SystemEnvironmentBase) {
env = Utils::Environment::systemEnvironment();
- } else if (m_baseEnvironmentBase == Qt4RunConfiguration::BuildEnvironmentBase) {
+ } else if (m_baseEnvironmentBase == Qt4RunConfiguration::BuildEnvironmentBase
+ && target()->activeBuildConfiguration()) {
env = target()->activeBuildConfiguration()->environment();
}
if (m_isUsingDyldImageSuffix) {
@@ -585,7 +606,7 @@ Utils::Environment Qt4RunConfiguration::baseEnvironment() const
// The user could be linking to a library found via a -L/some/dir switch
// to find those libraries while actually running we explicitly prepend those
// dirs to the library search path
- const Qt4ProFileNode *node = qt4Target()->qt4Project()->rootQt4ProjectNode()->findProFileFor(m_proFilePath);
+ const Qt4ProFileNode *node = static_cast<Qt4Project *>(target()->project())->rootQt4ProjectNode()->findProFileFor(m_proFilePath);
if (node) {
const QStringList libDirectories = node->variableValue(LibDirectoriesVar);
if (!libDirectories.isEmpty()) {
@@ -600,7 +621,7 @@ Utils::Environment Qt4RunConfiguration::baseEnvironment() const
} // libDirectories
} // node
- QtSupport::BaseQtVersion *qtVersion = qt4Target()->activeQt4BuildConfiguration()->qtVersion();
+ QtSupport::BaseQtVersion *qtVersion = QtSupport::QtProfileInformation::qtVersion(target()->profile());
if (qtVersion)
env.prependOrSetLibrarySearchPath(qtVersion->versionInfo().value(QLatin1String("QT_INSTALL_LIBS")));
return env;
@@ -656,7 +677,7 @@ QString Qt4RunConfiguration::proFilePath() const
QString Qt4RunConfiguration::dumperLibrary() const
{
- QtSupport::BaseQtVersion *version = qt4Target()->activeQt4BuildConfiguration()->qtVersion();
+ QtSupport::BaseQtVersion *version = QtSupport::QtProfileInformation::qtVersion(target()->profile());
if (version)
return version->gdbDebuggingHelperLibrary();
return QString();
@@ -664,7 +685,7 @@ QString Qt4RunConfiguration::dumperLibrary() const
QStringList Qt4RunConfiguration::dumperLibraryLocations() const
{
- QtSupport::BaseQtVersion *version = qt4Target()->activeQt4BuildConfiguration()->qtVersion();
+ QtSupport::BaseQtVersion *version = QtSupport::QtProfileInformation::qtVersion(target()->profile());
if (version)
return version->debuggingHelperLibraryLocations();
return QStringList();
@@ -695,7 +716,7 @@ Qt4RunConfiguration::BaseEnvironmentBase Qt4RunConfiguration::baseEnvironmentBas
Utils::OutputFormatter *Qt4RunConfiguration::createOutputFormatter() const
{
- return new QtSupport::QtOutputFormatter(qt4Target()->qt4Project());
+ return new QtSupport::QtOutputFormatter(target()->project());
}
///
@@ -704,50 +725,50 @@ Utils::OutputFormatter *Qt4RunConfiguration::createOutputFormatter() const
///
Qt4RunConfigurationFactory::Qt4RunConfigurationFactory(QObject *parent) :
- ProjectExplorer::IRunConfigurationFactory(parent)
-{
-}
+ QmakeRunConfigurationFactory(parent)
+{ setObjectName(QLatin1String("Qt4RunConfigurationFactory")); }
Qt4RunConfigurationFactory::~Qt4RunConfigurationFactory()
-{
-}
+{ }
bool Qt4RunConfigurationFactory::canCreate(ProjectExplorer::Target *parent, const Core::Id id) const
{
- Qt4BaseTarget *t = qobject_cast<Qt4BaseTarget *>(parent);
- if (!t)
+ if (!canHandle(parent))
return false;
- if (t->id() != Core::Id(Constants::DESKTOP_TARGET_ID)
- && t->id() != Core::Id(Constants::QT_SIMULATOR_TARGET_ID))
- return false;
- return t->qt4Project()->hasApplicationProFile(pathFromId(id));
+ Qt4Project *project = static_cast<Qt4Project *>(parent->project());
+ return project->hasApplicationProFile(pathFromId(id));
}
ProjectExplorer::RunConfiguration *Qt4RunConfigurationFactory::create(ProjectExplorer::Target *parent, const Core::Id id)
{
if (!canCreate(parent, id))
return 0;
- Qt4BaseTarget *t = static_cast<Qt4BaseTarget *>(parent);
- return new Qt4RunConfiguration(t, pathFromId(id));
+
+ Qt4RunConfiguration *rc = new Qt4RunConfiguration(parent, id);
+ QList<Qt4ProFileNode *> profiles = static_cast<Qt4Project *>(parent->project())->applicationProFiles();
+ foreach (Qt4ProFileNode *node, profiles) {
+ if (node->path() != rc->proFilePath())
+ continue;
+ rc->setRunMode(node->variableValue(ConfigVar).contains(QLatin1String("console"))
+ ? ProjectExplorer::LocalApplicationRunConfiguration::Console
+ : ProjectExplorer::LocalApplicationRunConfiguration::Gui);
+ break;
+ }
+ return rc;
}
bool Qt4RunConfigurationFactory::canRestore(ProjectExplorer::Target *parent, const QVariantMap &map) const
{
- if (!qobject_cast<Qt4BaseTarget *>(parent))
- return false;
- if (parent->id() != Core::Id(Constants::DESKTOP_TARGET_ID)
- && parent->id() != Core::Id(Constants::QT_SIMULATOR_TARGET_ID))
+ if (!canHandle(parent))
return false;
- QString id = QString::fromLatin1(ProjectExplorer::idFromMap(map).name());
- return id.startsWith(QLatin1String(QT4_RC_ID));
+ return ProjectExplorer::idFromMap(map).toString().startsWith(QLatin1String(QT4_RC_PREFIX));
}
ProjectExplorer::RunConfiguration *Qt4RunConfigurationFactory::restore(ProjectExplorer::Target *parent, const QVariantMap &map)
{
if (!canRestore(parent, map))
return 0;
- Qt4BaseTarget *t = static_cast<Qt4BaseTarget *>(parent);
- Qt4RunConfiguration *rc = new Qt4RunConfiguration(t, QString());
+ Qt4RunConfiguration *rc = new Qt4RunConfiguration(parent, ProjectExplorer::idFromMap(map));
if (rc->fromMap(map))
return rc;
@@ -764,23 +785,20 @@ ProjectExplorer::RunConfiguration *Qt4RunConfigurationFactory::clone(ProjectExpl
{
if (!canClone(parent, source))
return 0;
- Qt4BaseTarget *t = static_cast<Qt4BaseTarget *>(parent);
Qt4RunConfiguration *old = static_cast<Qt4RunConfiguration *>(source);
- return new Qt4RunConfiguration(t, old);
+ return new Qt4RunConfiguration(parent, old);
}
QList<Core::Id> Qt4RunConfigurationFactory::availableCreationIds(ProjectExplorer::Target *parent) const
{
QList<Core::Id> result;
- Qt4BaseTarget *t = qobject_cast<Qt4BaseTarget *>(parent);
- if (!t)
+ if (!canHandle(parent))
return result;
- if (t->id() != Core::Id(Constants::DESKTOP_TARGET_ID)
- && t->id() != Core::Id(Constants::QT_SIMULATOR_TARGET_ID))
- return result;
- QStringList proFiles = t->qt4Project()->applicationProFilePathes(QLatin1String(QT4_RC_PREFIX));
+
+ Qt4Project *project = static_cast<Qt4Project *>(parent->project());
+ QStringList proFiles = project->applicationProFilePathes(QLatin1String(QT4_RC_PREFIX));
foreach (const QString &pf, proFiles)
- result << Core::Id(pf.toUtf8().constData());
+ result << Core::Id(pf);
return result;
}
@@ -788,3 +806,24 @@ QString Qt4RunConfigurationFactory::displayNameForId(const Core::Id id) const
{
return QFileInfo(pathFromId(id)).completeBaseName();
}
+
+bool Qt4RunConfigurationFactory::canHandle(ProjectExplorer::Target *t) const
+{
+ if (!t->project()->supportsProfile(t->profile()))
+ return false;
+ if (!qobject_cast<Qt4Project *>(t->project()))
+ return false;
+ Core::Id devType = ProjectExplorer::DeviceTypeProfileInformation::deviceTypeId(t->profile());
+ return devType == Core::Id(ProjectExplorer::Constants::DESKTOP_DEVICE_TYPE);
+}
+
+QList<ProjectExplorer::RunConfiguration *> Qt4RunConfigurationFactory::runConfigurationsForNode(ProjectExplorer::Target *t, ProjectExplorer::Node *n)
+{
+ QList<ProjectExplorer::RunConfiguration *> result;
+ foreach (ProjectExplorer::RunConfiguration *rc, t->runConfigurations())
+ if (Qt4RunConfiguration *qt4c = qobject_cast<Qt4RunConfiguration *>(rc))
+ if (qt4c->proFilePath() == n->path())
+ result << rc;
+ return result;
+
+}