summaryrefslogtreecommitdiff
path: root/src/plugins/qt4projectmanager/qt4projectconfigwidget.cpp
diff options
context:
space:
mode:
authorTobias Hunger <tobias.hunger@nokia.com>2012-04-24 15:49:09 +0200
committerTobias Hunger <tobias.hunger@nokia.com>2012-06-21 12:08:12 +0200
commit24314562165588b56a318b3b8a846bf5deda7c41 (patch)
treeb5dcf951e76d003c2623011b0e91994e06e7e061 /src/plugins/qt4projectmanager/qt4projectconfigwidget.cpp
parent8c77b8c9d7b25d0c89003c8c4a54e8da5bfb7edd (diff)
downloadqt-creator-24314562165588b56a318b3b8a846bf5deda7c41.tar.gz
Profile introduction
Introduce Profiles to store sets of values that describe a system/device. These profiles are held by a target, getting rid of much of the information stored in the Build-/Run-/DeployConfigurations, greatly simplifying those. This is a squash of the wip/profile branch which has been on gerrit for a while, rebased to current master. Change-Id: I25956c8dd4d1962b2134bfaa8a8076ae3909460f Reviewed-by: Daniel Teske <daniel.teske@nokia.com>
Diffstat (limited to 'src/plugins/qt4projectmanager/qt4projectconfigwidget.cpp')
-rw-r--r--src/plugins/qt4projectmanager/qt4projectconfigwidget.cpp476
1 files changed, 106 insertions, 370 deletions
diff --git a/src/plugins/qt4projectmanager/qt4projectconfigwidget.cpp b/src/plugins/qt4projectmanager/qt4projectconfigwidget.cpp
index 0f24693b1f..7318f21849 100644
--- a/src/plugins/qt4projectmanager/qt4projectconfigwidget.cpp
+++ b/src/plugins/qt4projectmanager/qt4projectconfigwidget.cpp
@@ -35,25 +35,24 @@
#include "makestep.h"
#include "qmakestep.h"
#include "qt4project.h"
-#include "qt4target.h"
#include "qt4projectmanagerconstants.h"
#include "qt4projectmanager.h"
#include "qt4buildconfiguration.h"
-#include "qt4basetargetfactory.h"
#include "ui_qt4projectconfigwidget.h"
#include <coreplugin/icore.h>
#include <coreplugin/idocument.h>
-#include <projectexplorer/toolchainmanager.h>
+#include <projectexplorer/target.h>
#include <projectexplorer/toolchain.h>
#include <projectexplorer/task.h>
#include <projectexplorer/projectexplorerconstants.h>
#include <projectexplorer/buildconfiguration.h>
#include <qtsupport/qtversionfactory.h>
#include <qtsupport/baseqtversion.h>
-#include <qtsupport/qtversionmanager.h>
+#include <qtsupport/qtprofileinformation.h>
#include <qtsupport/qtsupportconstants.h>
+#include <qtsupport/qtversionmanager.h>
#include <utils/qtcassert.h>
#include <utils/qtcprocess.h>
#include <extensionsystem/pluginmanager.h>
@@ -70,7 +69,7 @@ using namespace Qt4ProjectManager;
using namespace Qt4ProjectManager::Internal;
using namespace ProjectExplorer;
-Qt4ProjectConfigWidget::Qt4ProjectConfigWidget(Qt4BaseTarget *target)
+Qt4ProjectConfigWidget::Qt4ProjectConfigWidget(ProjectExplorer::Target *target)
: BuildConfigWidget(),
m_buildConfiguration(0),
m_ignoreChange(false)
@@ -89,7 +88,6 @@ Qt4ProjectConfigWidget::Qt4ProjectConfigWidget(Qt4BaseTarget *target)
m_ui->shadowBuildDirEdit->setPromptDialogTitle(tr("Shadow Build Directory"));
m_ui->shadowBuildDirEdit->setExpectedKind(Utils::PathChooser::ExistingDirectory);
- m_ui->shadowBuildDirEdit->setBaseDirectory(target->qt4Project()->projectDirectory());
connect(m_ui->shadowBuildCheckBox, SIGNAL(clicked(bool)),
this, SLOT(shadowBuildClicked(bool)));
@@ -100,32 +98,11 @@ Qt4ProjectConfigWidget::Qt4ProjectConfigWidget(Qt4BaseTarget *target)
connect(m_ui->shadowBuildDirEdit, SIGNAL(changed(QString)),
this, SLOT(shadowBuildEdited()));
- connect(m_ui->qtVersionComboBox, SIGNAL(currentIndexChanged(QString)),
- this, SLOT(qtVersionSelected(QString)));
-
- connect(m_ui->toolChainComboBox, SIGNAL(activated(int)),
- this, SLOT(toolChainSelected(int)));
-
- connect(m_ui->importLabel, SIGNAL(linkActivated(QString)),
- this, SLOT(importLabelClicked()));
-
- connect(m_ui->manageQtVersionPushButtons, SIGNAL(clicked()),
- this, SLOT(manageQtVersions()));
-
- connect(m_ui->manageToolChainPushButton, SIGNAL(clicked()),
- this, SLOT(manageToolChains()));
-
- connect(target->qt4Project(), SIGNAL(environmentChanged()),
- this, SLOT(environmentChanged()));
-
- connect(target->qt4Project(), SIGNAL(buildDirectoryInitialized()),
- this, SLOT(updateImportLabel()));
-
- connect(target->qt4Project(), SIGNAL(proFileUpdated(Qt4ProjectManager::Qt4ProFileNode*,bool,bool)),
- this, SLOT(proFileUpdated(Qt4ProjectManager::Qt4ProFileNode*,bool,bool)));
-
- connect(ProjectExplorer::ToolChainManager::instance(), SIGNAL(toolChainsChanged()),
- this, SLOT(updateToolChainCombo()));
+ Qt4Project *project = qobject_cast<Qt4Project *>(target->project());
+ if (project) {
+ connect(project, SIGNAL(environmentChanged()), this, SLOT(environmentChanged()));
+ connect(project, SIGNAL(buildDirectoryInitialized()), this, SLOT(updateProblemLabel()));
+ }
}
Qt4ProjectConfigWidget::~Qt4ProjectConfigWidget()
@@ -135,30 +112,9 @@ Qt4ProjectConfigWidget::~Qt4ProjectConfigWidget()
void Qt4ProjectConfigWidget::updateDetails()
{
- QtSupport::BaseQtVersion *version = m_buildConfiguration->qtVersion();
-
- QString versionString;
- if (version)
- versionString = version->displayName();
-
- if (!version || !version->isValid()) {
- // Not a valid qt version
- m_detailsContainer->setSummaryText(
- tr("using <font color=\"#ff0000\">invalid</font> Qt Version: <b>%1</b><br>"
- "%2")
- .arg(versionString,
- version ? version->invalidReason() : tr("No Qt Version found.")));
- } else {
- // Qt Version, Build Directory and tool chain
- m_detailsContainer->setSummaryText(
- tr("using Qt version: <b>%1</b><br>"
- "with tool chain <b>%2</b><br>"
- "building in <b>%3</b>")
- .arg(versionString,
- m_buildConfiguration->toolChain() ? m_buildConfiguration->toolChain()->displayName() :
- tr("<Invalid tool chain>"),
- QDir::toNativeSeparators(m_buildConfiguration->buildDirectory())));
- }
+ m_detailsContainer->setSummaryText(
+ tr("building in <b>%3</b>")
+ .arg(QDir::toNativeSeparators(m_buildConfiguration->buildDirectory())));
}
void Qt4ProjectConfigWidget::environmentChanged()
@@ -166,28 +122,6 @@ void Qt4ProjectConfigWidget::environmentChanged()
m_ui->shadowBuildDirEdit->setEnvironment(m_buildConfiguration->environment());
}
-void Qt4ProjectConfigWidget::updateShadowBuildUi()
-{
- QtSupport::BaseQtVersion *version = m_buildConfiguration->qtVersion();
- m_ui->shadowBuildCheckBox->setEnabled(version && version->supportsShadowBuilds());
- bool isShadowbuilding = m_buildConfiguration->shadowBuild();
- m_ui->shadowBuildDirEdit->setEnabled(isShadowbuilding && version && version->supportsShadowBuilds());
- m_browseButton->setEnabled(isShadowbuilding && version && version->supportsShadowBuilds());
- m_ui->shadowBuildDirEdit->setPath(m_buildConfiguration->shadowBuildDirectory());
-}
-
-void Qt4ProjectConfigWidget::manageQtVersions()
-{
- Core::ICore::showOptionsDialog(QLatin1String(ProjectExplorer::Constants::PROJECTEXPLORER_SETTINGS_CATEGORY),
- QLatin1String(QtSupport::Constants::QTVERSION_SETTINGS_PAGE_ID));
-}
-
-void Qt4ProjectConfigWidget::manageToolChains()
-{
- Core::ICore::showOptionsDialog(QLatin1String(ProjectExplorer::Constants::PROJECTEXPLORER_SETTINGS_CATEGORY),
- QLatin1String(ProjectExplorer::Constants::TOOLCHAIN_SETTINGS_PAGE_ID));
-}
-
QString Qt4ProjectConfigWidget::displayName() const
{
return tr("General");
@@ -203,95 +137,20 @@ void Qt4ProjectConfigWidget::init(ProjectExplorer::BuildConfiguration *bc)
if (m_buildConfiguration) {
disconnect(m_buildConfiguration, SIGNAL(buildDirectoryChanged()),
this, SLOT(buildDirectoryChanged()));
- disconnect(m_buildConfiguration, SIGNAL(qtVersionChanged()),
- this, SLOT(qtVersionChanged()));
disconnect(m_buildConfiguration, SIGNAL(qmakeBuildConfigurationChanged()),
- this, SLOT(updateImportLabel()));
- disconnect(m_buildConfiguration, SIGNAL(toolChainChanged()),
- this, SLOT(toolChainChanged()));
+ this, SLOT(updateProblemLabel()));
}
m_buildConfiguration = static_cast<Qt4BuildConfiguration *>(bc);
m_ui->shadowBuildDirEdit->setEnvironment(m_buildConfiguration->environment());
connect(m_buildConfiguration, SIGNAL(buildDirectoryChanged()),
this, SLOT(buildDirectoryChanged()));
- connect(m_buildConfiguration, SIGNAL(qtVersionChanged()),
- this, SLOT(qtVersionChanged()));
connect(m_buildConfiguration, SIGNAL(qmakeBuildConfigurationChanged()),
- this, SLOT(updateImportLabel()));
- connect(m_buildConfiguration, SIGNAL(toolChainChanged()),
- this, SLOT(toolChainChanged()));
+ this, SLOT(updateProblemLabel()));
- qtVersionsChanged();
- QtSupport::QtVersionManager *vm = QtSupport::QtVersionManager::instance();
- connect(vm, SIGNAL(qtVersionsChanged(QList<int>,QList<int>,QList<int>)),
- this, SLOT(qtVersionsChanged()));
+ m_ui->shadowBuildDirEdit->setBaseDirectory(m_buildConfiguration->target()->project()->projectDirectory());
- bool shadowBuild = m_buildConfiguration->shadowBuild();
- m_ui->shadowBuildCheckBox->setChecked(shadowBuild);
- m_ui->shadowBuildCheckBox->setEnabled(m_buildConfiguration->qtVersion()
- && m_buildConfiguration->qtVersion()->supportsShadowBuilds());
-
- updateShadowBuildUi();
- updateImportLabel();
- updateToolChainCombo();
- updateDetails();
-
- connect(ToolChainManager::instance(), SIGNAL(toolChainAdded(ProjectExplorer::ToolChain*)),
- this, SLOT(updateToolChainCombo()));
- connect(ToolChainManager::instance(), SIGNAL(toolChainRemoved(ProjectExplorer::ToolChain*)),
- this, SLOT(updateToolChainCombo()));
-}
-
-void Qt4ProjectConfigWidget::qtVersionChanged()
-{
- if (m_ignoreChange)
- return;
-
- int versionId = -1;
- if (m_buildConfiguration->qtVersion())
- versionId = m_buildConfiguration->qtVersion()->uniqueId();
- int comboBoxIndex = m_ui->qtVersionComboBox->findData(QVariant(versionId), Qt::UserRole);
- m_ui->qtVersionComboBox->setCurrentIndex(comboBoxIndex);
-
- updateShadowBuildUi();
- updateImportLabel();
- updateToolChainCombo();
- updateDetails();
-}
-
-void Qt4ProjectConfigWidget::qtVersionsChanged()
-{
- m_ignoreChange = true;
- QtSupport::QtVersionManager *vm = QtSupport::QtVersionManager::instance();
-
- m_ui->qtVersionComboBox->clear();
- QtSupport::BaseQtVersion *qtVersion = m_buildConfiguration->qtVersion();
-
- QList<QtSupport::BaseQtVersion *> validVersions = vm->versionsForTargetId(m_buildConfiguration->target()->id());
- if (!validVersions.isEmpty()) {
- for (int i = 0; i < validVersions.size(); ++i) {
- const QtSupport::BaseQtVersion *version = validVersions.at(i);
- m_ui->qtVersionComboBox->addItem(version->displayName(),
- version->uniqueId());
-
- if (version == qtVersion) {
- m_ui->qtVersionComboBox->setCurrentIndex(i);
- m_ui->qtVersionComboBox->setToolTip(version->toHtml(false));
- }
- }
- }
- if (!qtVersion || !qtVersion->isValid()) {
- m_ui->qtVersionComboBox->addItem(tr("Invalid Qt version"), -1);
- m_ui->qtVersionComboBox->setCurrentIndex(m_ui->qtVersionComboBox->count() - 1);
- }
- m_ui->qtVersionComboBox->setEnabled(m_ui->qtVersionComboBox->count() > 1);
- m_ignoreChange = false;
-
- updateToolChainCombo();
- updateShadowBuildUi();
- updateDetails();
- updateImportLabel();
+ buildDirectoryChanged();
}
void Qt4ProjectConfigWidget::buildDirectoryChanged()
@@ -299,8 +158,13 @@ void Qt4ProjectConfigWidget::buildDirectoryChanged()
if (m_ignoreChange)
return;
m_ui->shadowBuildDirEdit->setPath(m_buildConfiguration->shadowBuildDirectory());
+ bool shadowBuild = m_buildConfiguration->shadowBuild();
+ m_ui->shadowBuildCheckBox->setChecked(shadowBuild);
+ m_ui->shadowBuildDirEdit->setEnabled(shadowBuild);
+ m_browseButton->setEnabled(shadowBuild);
+
updateDetails();
- updateImportLabel();
+ updateProblemLabel();
}
void Qt4ProjectConfigWidget::onBeforeBeforeShadowBuildDirBrowsed()
@@ -321,7 +185,7 @@ void Qt4ProjectConfigWidget::shadowBuildClicked(bool checked)
m_ignoreChange = false;
updateDetails();
- updateImportLabel();
+ updateProblemLabel();
}
void Qt4ProjectConfigWidget::shadowBuildEdited()
@@ -335,238 +199,110 @@ void Qt4ProjectConfigWidget::shadowBuildEdited()
// if the directory already exists
// check if we have a build in there and
// offer to import it
- updateImportLabel();
+ updateProblemLabel();
updateDetails();
}
-void Qt4ProjectConfigWidget::updateImportLabel()
+void Qt4ProjectConfigWidget::updateProblemLabel()
{
- bool visible = false;
- bool targetMatches = false;
+ bool targetMismatch = false;
bool incompatibleBuild = false;
- bool couldnotparse = false;
+ bool allGood = false;
+
+ ProjectExplorer::Profile *p = m_buildConfiguration->target()->profile();
+ const QString proFileName = m_buildConfiguration->target()->project()->document()->fileName();
+
+ QtSupport::BaseQtVersion *version = QtSupport::QtProfileInformation::qtVersion(p);
+ if (!version) {
+ m_ui->problemLabel->setVisible(true);
+ m_ui->warningLabel->setVisible(true);
+ m_ui->problemLabel->setText(tr("This target can not build this project since it does not define a "
+ "Qt version."));
+ return;
+ }
- QtSupport::QtVersionManager *vm = QtSupport::QtVersionManager::instance();
// we only show if we actually have a qmake and makestep
if (m_buildConfiguration->qmakeStep() && m_buildConfiguration->makeStep()) {
- QString makefile = m_buildConfiguration->buildDirectory();
+ QString makefile = m_buildConfiguration->buildDirectory() + QLatin1Char('/');
if (m_buildConfiguration->makefile().isEmpty())
- makefile.append(QLatin1String("/Makefile"));
+ makefile.append(QLatin1String("Makefile"));
else
makefile.append(m_buildConfiguration->makefile());
- Utils::FileName qmakePath = QtSupport::QtVersionManager::findQMakeBinaryFromMakefile(makefile);
- QtSupport::BaseQtVersion *version = m_buildConfiguration->qtVersion();
- // check that there's a makefile
- if (!qmakePath.isEmpty()) {
- // Is it from the same build?
- QtSupport::QtVersionManager::MakefileCompatible mc =
- QtSupport::QtVersionManager::makefileIsFor(makefile, m_buildConfiguration->target()->project()->document()->fileName());
- if (mc == QtSupport::QtVersionManager::DifferentProject) {
- incompatibleBuild = true;
- } else if (mc == QtSupport::QtVersionManager::SameProject) {
- if (qmakePath != (version ? version->qmakeCommand() : Utils::FileName())) {
- // and that the qmake path is different from the current version
- // import enable
- visible = true;
- QtSupport::BaseQtVersion *newVersion = vm->qtVersionForQMakeBinary(qmakePath);
- bool mustDelete(false);
- if (!newVersion) {
- newVersion = QtSupport::QtVersionFactory::createQtVersionFromQMakePath(qmakePath);
- mustDelete = true;
- }
- targetMatches = newVersion ? newVersion->supportsTargetId(m_buildConfiguration->target()->id()) : false;
- if (mustDelete)
- delete newVersion;
- } else {
- // check that the qmake flags, arguments match
- visible = !m_buildConfiguration->compareToImportFrom(makefile);
- targetMatches = true;
- }
- } else if (mc == QtSupport::QtVersionManager::CouldNotParse) {
- couldnotparse = true;
- }
+ switch (m_buildConfiguration->compareToImportFrom(makefile)) {
+ case Qt4BuildConfiguration::MakefileMatches:
+ allGood = true;
+ break;
+ case Qt4BuildConfiguration::MakefileMissing:
+ allGood = true;
+ break;
+ case Qt4BuildConfiguration::MakefileIncompatible:
+ incompatibleBuild = true;
+ break;
+ case Qt4BuildConfiguration::MakefileForWrongProject:
+ targetMismatch = true;
+ break;
}
}
- QString buildDirectory = m_buildConfiguration->target()->project()->projectDirectory();;
- if (m_buildConfiguration->shadowBuild())
- buildDirectory = m_buildConfiguration->buildDirectory();
- QList<ProjectExplorer::Task> issues;
- if (QtSupport::BaseQtVersion *version = m_buildConfiguration->qtVersion()) {
- issues = version->reportIssues(m_buildConfiguration->target()->project()->document()->fileName(),
- buildDirectory);
- foreach (Qt4BaseTargetFactory *factory,
- Qt4BaseTargetFactory::qt4BaseTargetFactoriesForIds(version->supportedTargetIds().toList()))
- issues.append(factory->reportIssues(m_buildConfiguration->target()->project()->document()->fileName()));
+ QString shadowBuildWarning;
+ if (!version->supportsShadowBuilds() && m_buildConfiguration->shadowBuild()) {
+ shadowBuildWarning =tr("The qt version %1 does not support shadow builds, building might fail.")
+ .arg(version->displayName())
+ + QLatin1String("<br>");
+ }
+ if (allGood) {
+ QString buildDirectory = m_buildConfiguration->target()->project()->projectDirectory();;
+ if (m_buildConfiguration->shadowBuild())
+ buildDirectory = m_buildConfiguration->buildDirectory();
+ QList<ProjectExplorer::Task> issues;
+ issues = version->reportIssues(proFileName, buildDirectory);
qSort(issues);
- }
- if (incompatibleBuild) {
+ if (issues.isEmpty() && shadowBuildWarning.isEmpty()) {
+ m_ui->problemLabel->setVisible(false);
+ m_ui->warningLabel->setVisible(false);
+ } else {
+ m_ui->problemLabel->setVisible(true);
+ m_ui->warningLabel->setVisible(true);
+ QString text = QLatin1String("<nobr>") + shadowBuildWarning;
+ foreach (const ProjectExplorer::Task &task, issues) {
+ QString type;
+ switch (task.type) {
+ case ProjectExplorer::Task::Error:
+ type = tr("Error:");
+ type += QLatin1Char(' ');
+ break;
+ case ProjectExplorer::Task::Warning:
+ type = tr("Warning:");
+ type += QLatin1Char(' ');
+ break;
+ case ProjectExplorer::Task::Unknown:
+ default:
+ break;
+ }
+ if (!text.endsWith(QLatin1String("br>")))
+ text.append(QLatin1String("<br>"));
+ text.append(type + task.description);
+ }
+ m_ui->problemLabel->setText(text);
+ }
+ } else if (targetMismatch) {
m_ui->problemLabel->setVisible(true);
m_ui->warningLabel->setVisible(true);
- m_ui->importLabel->setVisible(false);
- m_ui->problemLabel->setText(tr("A build for a different project exists in %1, which will be overwritten.",
- "%1 build directory").
- arg(m_ui->shadowBuildDirEdit->path()));
- } else if (!issues.isEmpty()) {
+ m_ui->problemLabel->setText(shadowBuildWarning + tr("A build for a different project exists in %1, which will be overwritten.",
+ "%1 build directory")
+ .arg(m_ui->shadowBuildDirEdit->path()));
+ } else if (incompatibleBuild) {
+ m_ui->warningLabel->setVisible(true);
m_ui->problemLabel->setVisible(true);
+ m_ui->problemLabel->setText(shadowBuildWarning +tr("An incompatible build exists in %1, which will be overwritten.",
+ "%1 build directory")
+ .arg(m_ui->shadowBuildDirEdit->path()));
+ } else if (shadowBuildWarning.isEmpty()) {
m_ui->warningLabel->setVisible(true);
- m_ui->importLabel->setVisible(visible);
- QString text = QLatin1String("<nobr>");
- foreach (const ProjectExplorer::Task &task, issues) {
- QString type;
- switch (task.type) {
- case ProjectExplorer::Task::Error:
- type = tr("Error:");
- type += QLatin1Char(' ');
- break;
- case ProjectExplorer::Task::Warning:
- type = tr("Warning:");
- type += QLatin1Char(' ');
- break;
- case ProjectExplorer::Task::Unknown:
- default:
- break;
- }
- if (!text.endsWith(QLatin1String("br>")))
- text.append(QLatin1String("<br>"));
- text.append(type + task.description);
- }
- m_ui->problemLabel->setText(text);
- } else if (targetMatches) {
- m_ui->problemLabel->setVisible(false);
- m_ui->warningLabel->setVisible(false);
- m_ui->importLabel->setVisible(visible);
- } else if (couldnotparse) {
- m_ui->problemLabel->setVisible(false);
- m_ui->warningLabel->setVisible(false);
- m_ui->importLabel->setVisible(false);
- } else { // target did not match
- m_ui->warningLabel->setVisible(visible);
- m_ui->problemLabel->setVisible(visible);
- m_ui->problemLabel->setText(tr("An incompatible build exists in %1, which will be overwritten.",
- "%1 build directory").
- arg(m_ui->shadowBuildDirEdit->path()));
- m_ui->importLabel->setVisible(false);
- }
-}
-
-void Qt4ProjectConfigWidget::importLabelClicked()
-{
- if (!m_buildConfiguration->qmakeStep() || !m_buildConfiguration->makeStep())
- return;
-
- // We do the importing via a single shot timer due to QTCREATORBUG-2723
- // Adding a qtversion might trigger a supportedTargetIds changed signal
- // which results in a recreation of all the widgets on the page
- // That means also "this" gets deleted
- QTimer::singleShot(0, m_buildConfiguration, SLOT(importFromBuildDirectory()));
-}
-
-void Qt4ProjectConfigWidget::qtVersionSelected(const QString &)
-{
- if (m_ignoreChange)
- return;
-
- int newQtVersionId = m_ui->qtVersionComboBox->itemData(m_ui->qtVersionComboBox->currentIndex()).toInt();
-
- if (m_ui->qtVersionComboBox->itemData(m_ui->qtVersionComboBox->count() - 1).toInt() == -1)
- m_ui->qtVersionComboBox->removeItem(m_ui->qtVersionComboBox->count() - 1);
-
- QtSupport::QtVersionManager *vm = QtSupport::QtVersionManager::instance();
- QtSupport::BaseQtVersion *newQtVersion = vm->version(newQtVersionId);
-
- if (newQtVersion) {
- const QString qtVersionName = newQtVersion->displayName();
- QString defaultConfigName = (m_buildConfiguration->buildType() & BuildConfiguration::Debug) ?
- //: Name of a debug build configuration to created by a project wizard, %1 being the Qt version name. We recommend not translating it.
- tr("%1 Debug").arg(qtVersionName) :
- //: Name of a release build configuration to created by a project wizard, %1 being the Qt version name. We recommend not translating it.
- tr("%1 Release").arg(qtVersionName);
-
- // make name unique
- QStringList displayNames;
- foreach (const BuildConfiguration *bc, m_buildConfiguration->target()->buildConfigurations()) {
- if (bc != m_buildConfiguration)
- displayNames << bc->displayName();
- }
- defaultConfigName = Project::makeUnique(defaultConfigName, displayNames);
-
- m_buildConfiguration->setDefaultDisplayName(defaultConfigName);
- }
-
- m_ignoreChange = true;
- m_buildConfiguration->setQtVersion(newQtVersion);
- m_ignoreChange = false;
-
- m_ui->qtVersionComboBox->setToolTip(newQtVersion ? newQtVersion->toHtml(false) : QString());
-
- updateShadowBuildUi();
- updateToolChainCombo();
- updateImportLabel();
- updateDetails();
-}
-
-void Qt4ProjectConfigWidget::toolChainChanged()
-{
- if (m_ignoreChange)
- return;
- bool foundTc = false;
- for (int i = 0; i < m_ui->toolChainComboBox->count(); ++i) {
- ProjectExplorer::ToolChain *tc =
- static_cast<ProjectExplorer::ToolChain *>(m_ui->toolChainComboBox->itemData(i, Qt::UserRole).value<void *>());
- if (tc == m_buildConfiguration->toolChain()) {
- m_ignoreChange = true;
- m_ui->toolChainComboBox->setCurrentIndex(i);
- m_ignoreChange = false;
- foundTc = true;
- break;
- }
- }
- if (foundTc) {
- int index = m_ui->toolChainComboBox->findData(qVariantFromValue(static_cast<void *>(0)));
- if (index >= 0)
- m_ui->toolChainComboBox->removeItem(index);
- } else {
- m_ignoreChange = true;
- m_ui->toolChainComboBox->addItem(tr("<No tool chain selected>"), qVariantFromValue(static_cast<void *>(0)));
- m_ui->toolChainComboBox->setCurrentIndex(m_ui->toolChainComboBox->count() - 1);
- m_ignoreChange = false;
+ m_ui->problemLabel->setVisible(true);
+ m_ui->problemLabel->setText(shadowBuildWarning);
}
}
-
-void Qt4ProjectConfigWidget::proFileUpdated(Qt4ProjectManager::Qt4ProFileNode * /*node*/, bool success, bool parseInProgress)
-{
- if (!success || parseInProgress)
- return;
- updateToolChainCombo();
-}
-
-void Qt4ProjectConfigWidget::updateToolChainCombo()
-{
- m_ui->toolChainComboBox->clear();
- QList<ProjectExplorer::ToolChain *> toolchains =
- m_buildConfiguration->qt4Target()->possibleToolChains(m_buildConfiguration);
-
- foreach (ProjectExplorer::ToolChain *toolchain, toolchains)
- m_ui->toolChainComboBox->addItem(toolchain->displayName(),
- qVariantFromValue(static_cast<void *>(toolchain)));
- m_ui->toolChainComboBox->setEnabled(toolchains.size() > 1);
- toolChainChanged();
-}
-
-void Qt4ProjectConfigWidget::toolChainSelected(int index)
-{
- if (m_ignoreChange)
- return;
- ProjectExplorer::ToolChain *selectedToolChain =
- static_cast<ProjectExplorer::ToolChain *>(
- m_ui->toolChainComboBox->itemData(index,
- Qt::UserRole).value<void *>());
- m_ignoreChange = true;
- m_buildConfiguration->setToolChain(selectedToolChain);
- m_ignoreChange = false;
- updateDetails();
-}