aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorTobias Hunger <[email protected]>2013-05-06 17:11:33 +0200
committerTobias Hunger <[email protected]>2013-05-07 16:39:29 +0200
commit1ca9bab2426b00e86fa71a0e7f53c801723ad325 (patch)
tree88b05140bf25bc053d51381d1f389a339c6c45b6
parent0ef3acc9f29ce1855dbd9cda09f195001b8f4953 (diff)
Kit: Only make SDK-set KitInformation read-only
Leave the rest user-editable. Task-number: QTCREATORBUG-9030 Change-Id: I77c9ff980dd9a497bff53ee04dae7e771e4e7e82 Reviewed-by: Daniel Teske <[email protected]>
-rw-r--r--src/plugins/android/androidgdbserverkitinformation.cpp6
-rw-r--r--src/plugins/android/androidgdbserverkitinformation.h2
-rw-r--r--src/plugins/debugger/debuggerkitconfigwidget.cpp4
-rw-r--r--src/plugins/debugger/debuggerkitconfigwidget.h2
-rw-r--r--src/plugins/debugger/debuggerkitinformation.cpp2
-rw-r--r--src/plugins/projectexplorer/kit.cpp23
-rw-r--r--src/plugins/projectexplorer/kit.h6
-rw-r--r--src/plugins/projectexplorer/kitconfigwidget.h5
-rw-r--r--src/plugins/projectexplorer/kitinformation.cpp8
-rw-r--r--src/plugins/projectexplorer/kitinformationconfigwidget.cpp16
-rw-r--r--src/plugins/projectexplorer/kitinformationconfigwidget.h8
-rw-r--r--src/plugins/projectexplorer/kitmanager.cpp11
-rw-r--r--src/plugins/projectexplorer/kitmanager.h3
-rw-r--r--src/plugins/projectexplorer/kitmanagerconfigwidget.cpp8
-rw-r--r--src/plugins/projectexplorer/kitmanagerconfigwidget.h2
-rw-r--r--src/plugins/projectexplorer/kitmodel.cpp4
-rw-r--r--src/plugins/qt4projectmanager/qmakekitconfigwidget.cpp4
-rw-r--r--src/plugins/qt4projectmanager/qmakekitconfigwidget.h2
-rw-r--r--src/plugins/qt4projectmanager/qmakekitinformation.cpp2
-rw-r--r--src/plugins/qtsupport/qtkitconfigwidget.cpp4
-rw-r--r--src/plugins/qtsupport/qtkitconfigwidget.h2
-rw-r--r--src/plugins/qtsupport/qtkitinformation.cpp2
22 files changed, 86 insertions, 40 deletions
diff --git a/src/plugins/android/androidgdbserverkitinformation.cpp b/src/plugins/android/androidgdbserverkitinformation.cpp
index 5cae7ae784d..190a4abb209 100644
--- a/src/plugins/android/androidgdbserverkitinformation.cpp
+++ b/src/plugins/android/androidgdbserverkitinformation.cpp
@@ -81,7 +81,7 @@ ProjectExplorer::KitInformation::ItemList AndroidGdbServerKitInformation::toUser
ProjectExplorer::KitConfigWidget *AndroidGdbServerKitInformation::createConfigWidget(ProjectExplorer::Kit *kit) const
{
- return new AndroidGdbServerKitInformationWidget(kit);
+ return new AndroidGdbServerKitInformationWidget(kit, isSticky(kit));
}
Utils::FileName AndroidGdbServerKitInformation::gdbServer(const ProjectExplorer::Kit *kit)
@@ -109,8 +109,8 @@ Utils::FileName AndroidGdbServerKitInformation::autoDetect(ProjectExplorer::Kit
///////////////
-AndroidGdbServerKitInformationWidget::AndroidGdbServerKitInformationWidget(ProjectExplorer::Kit *kit)
- : ProjectExplorer::KitConfigWidget(kit),
+AndroidGdbServerKitInformationWidget::AndroidGdbServerKitInformationWidget(ProjectExplorer::Kit *kit, bool sticky)
+ : ProjectExplorer::KitConfigWidget(kit, sticky),
m_label(new Utils::ElidingLabel),
m_button(new QPushButton(tr("Manage...")))
{
diff --git a/src/plugins/android/androidgdbserverkitinformation.h b/src/plugins/android/androidgdbserverkitinformation.h
index e4296b748d9..d3f8b77fbc3 100644
--- a/src/plugins/android/androidgdbserverkitinformation.h
+++ b/src/plugins/android/androidgdbserverkitinformation.h
@@ -46,7 +46,7 @@ class AndroidGdbServerKitInformationWidget : public ProjectExplorer::KitConfigWi
{
Q_OBJECT
public:
- AndroidGdbServerKitInformationWidget(ProjectExplorer::Kit *kit);
+ AndroidGdbServerKitInformationWidget(ProjectExplorer::Kit *kit, bool sticky);
QString displayName() const;
QString toolTip() const;
diff --git a/src/plugins/debugger/debuggerkitconfigwidget.cpp b/src/plugins/debugger/debuggerkitconfigwidget.cpp
index 2406b3426ad..00792ccf322 100644
--- a/src/plugins/debugger/debuggerkitconfigwidget.cpp
+++ b/src/plugins/debugger/debuggerkitconfigwidget.cpp
@@ -54,8 +54,8 @@ static const char debuggingToolsWikiLinkC[] = "http://qt-project.org/wiki/Qt_Cre
// DebuggerKitConfigWidget:
// -----------------------------------------------------------------------
-DebuggerKitConfigWidget::DebuggerKitConfigWidget(ProjectExplorer::Kit *workingCopy)
- : KitConfigWidget(workingCopy),
+DebuggerKitConfigWidget::DebuggerKitConfigWidget(ProjectExplorer::Kit *workingCopy, bool sticky)
+ : KitConfigWidget(workingCopy, sticky),
m_main(new QWidget),
m_label(new Utils::ElidingLabel(m_main)),
m_autoDetectButton(new QPushButton(tr("Auto-detect"))),
diff --git a/src/plugins/debugger/debuggerkitconfigwidget.h b/src/plugins/debugger/debuggerkitconfigwidget.h
index 27f2a614da6..9a5fbc9e832 100644
--- a/src/plugins/debugger/debuggerkitconfigwidget.h
+++ b/src/plugins/debugger/debuggerkitconfigwidget.h
@@ -60,7 +60,7 @@ class DebuggerKitConfigWidget : public ProjectExplorer::KitConfigWidget
Q_OBJECT
public:
- DebuggerKitConfigWidget(ProjectExplorer::Kit *workingCopy);
+ DebuggerKitConfigWidget(ProjectExplorer::Kit *workingCopy, bool sticky);
QString displayName() const;
QString toolTip() const;
diff --git a/src/plugins/debugger/debuggerkitinformation.cpp b/src/plugins/debugger/debuggerkitinformation.cpp
index 60652509a5a..76fba76d83b 100644
--- a/src/plugins/debugger/debuggerkitinformation.cpp
+++ b/src/plugins/debugger/debuggerkitinformation.cpp
@@ -274,7 +274,7 @@ QList<ProjectExplorer::Task> DebuggerKitInformation::validateDebugger(const Proj
KitConfigWidget *DebuggerKitInformation::createConfigWidget(Kit *k) const
{
- return new Internal::DebuggerKitConfigWidget(k);
+ return new Internal::DebuggerKitConfigWidget(k, isSticky(k));
}
QString DebuggerKitInformation::userOutput(const DebuggerItem &item)
diff --git a/src/plugins/projectexplorer/kit.cpp b/src/plugins/projectexplorer/kit.cpp
index b3bb27d9800..a25add39947 100644
--- a/src/plugins/projectexplorer/kit.cpp
+++ b/src/plugins/projectexplorer/kit.cpp
@@ -105,6 +105,7 @@ public:
bool m_mustNotifyAboutDisplayName;
QHash<Core::Id, QVariant> m_data;
+ QSet<Core::Id> m_sticky;
};
} // namespace Internal
@@ -161,6 +162,7 @@ Kit *Kit::clone(bool keepName) const
k->d->m_isValid = d->m_isValid;
k->d->m_icon = d->m_icon;
k->d->m_iconPath = d->m_iconPath;
+ k->d->m_sticky = d->m_sticky;
return k;
}
@@ -174,6 +176,7 @@ void Kit::copyFrom(const Kit *k)
d->m_displayName = k->d->m_displayName;
d->m_mustNotify = true;
d->m_mustNotifyAboutDisplayName = true;
+ d->m_sticky = k->d->m_sticky;
}
bool Kit::isValid() const
@@ -337,9 +340,15 @@ void Kit::removeKey(Id key)
if (!d->m_data.contains(key))
return;
d->m_data.remove(key);
+ d->m_sticky.remove(key);
kitUpdated();
}
+bool Kit::isSticky(Core::Id id) const
+{
+ return d->m_sticky.contains(id);
+}
+
bool Kit::isDataEqual(const Kit *other) const
{
return d->m_data == other->d->m_data;
@@ -451,6 +460,7 @@ bool Kit::fromMap(const QVariantMap &data)
setIconPath(data.value(QLatin1String(ICON_KEY)).toString());
QVariantMap extra = data.value(QLatin1String(DATA_KEY)).toMap();
+ d->m_data.clear(); // remove default values
const QVariantMap::ConstIterator cend = extra.constEnd();
for (QVariantMap::ConstIterator it = extra.constBegin(); it != cend; ++it)
setValue(Id::fromString(it.key()), it.value());
@@ -468,6 +478,19 @@ void Kit::setSdkProvided(bool sdkProvided)
d->m_sdkProvided = sdkProvided;
}
+void Kit::makeSticky()
+{
+ foreach (KitInformation *ki, KitManager::instance()->kitInformation()) {
+ if (hasValue(ki->dataId()))
+ makeSticky(ki->dataId());
+ }
+}
+
+void Kit::makeSticky(Core::Id id)
+{
+ d->m_sticky.insert(id);
+}
+
void Kit::kitUpdated()
{
if (d->m_nestedBlockingLevel > 0 && !d->m_mustNotifyAboutDisplayName) {
diff --git a/src/plugins/projectexplorer/kit.h b/src/plugins/projectexplorer/kit.h
index c32baadfa61..0b1e2921581 100644
--- a/src/plugins/projectexplorer/kit.h
+++ b/src/plugins/projectexplorer/kit.h
@@ -87,6 +87,7 @@ public:
bool hasValue(Core::Id key) const;
void setValue(Core::Id key, const QVariant &value);
void removeKey(Core::Id key);
+ bool isSticky(Core::Id id) const;
bool isDataEqual(const Kit *other) const;
bool isEqual(const Kit *other) const;
@@ -99,8 +100,12 @@ public:
void copyFrom(const Kit *k);
void setAutoDetected(bool detected);
+
private:
void setSdkProvided(bool sdkProvided);
+ void makeSticky();
+ void makeSticky(Core::Id id);
+
~Kit();
// Unimplemented.
@@ -115,6 +120,7 @@ private:
Internal::KitPrivate *d;
+ friend class KitInformation;
friend class KitManager;
friend class Internal::KitModel; // needed for setAutoDetected() when cloning kits
};
diff --git a/src/plugins/projectexplorer/kitconfigwidget.h b/src/plugins/projectexplorer/kitconfigwidget.h
index 5e973b104a3..a218684e4cd 100644
--- a/src/plugins/projectexplorer/kitconfigwidget.h
+++ b/src/plugins/projectexplorer/kitconfigwidget.h
@@ -47,7 +47,7 @@ class PROJECTEXPLORER_EXPORT KitConfigWidget : public QObject
Q_OBJECT
public:
- KitConfigWidget(Kit *kit) : m_kit(kit) { }
+ KitConfigWidget(Kit *kit, bool sticky) : m_kit(kit), m_isSticky(sticky) { }
virtual QString displayName() const = 0;
virtual QString toolTip() const { return QString(); }
@@ -58,11 +58,14 @@ public:
virtual QWidget *mainWidget() const = 0;
virtual QWidget *buttonWidget() const { return 0; }
+ bool isSticky() { return m_isSticky; }
+
signals:
void dirty();
protected:
ProjectExplorer::Kit *m_kit;
+ bool m_isSticky;
};
} // namespace ProjectExplorer
diff --git a/src/plugins/projectexplorer/kitinformation.cpp b/src/plugins/projectexplorer/kitinformation.cpp
index fb3105b75fc..adaf1e1d0d5 100644
--- a/src/plugins/projectexplorer/kitinformation.cpp
+++ b/src/plugins/projectexplorer/kitinformation.cpp
@@ -86,7 +86,7 @@ QList<Task> SysRootKitInformation::validate(const Kit *k) const
KitConfigWidget *SysRootKitInformation::createConfigWidget(Kit *k) const
{
- return new Internal::SysRootInformationConfigWidget(k);
+ return new Internal::SysRootInformationConfigWidget(k, isSticky(k));
}
KitInformation::ItemList SysRootKitInformation::toUserOutput(const Kit *k) const
@@ -199,7 +199,7 @@ void ToolChainKitInformation::setup(Kit *k)
KitConfigWidget *ToolChainKitInformation::createConfigWidget(Kit *k) const
{
- return new Internal::ToolChainInformationConfigWidget(k);
+ return new Internal::ToolChainInformationConfigWidget(k, isSticky(k));
}
QString ToolChainKitInformation::displayNamePostfix(const Kit *k) const
@@ -309,7 +309,7 @@ QList<Task> DeviceTypeKitInformation::validate(const Kit *k) const
KitConfigWidget *DeviceTypeKitInformation::createConfigWidget(Kit *k) const
{
- return new Internal::DeviceTypeInformationConfigWidget(k);
+ return new Internal::DeviceTypeInformationConfigWidget(k, isSticky(k));
}
KitInformation::ItemList DeviceTypeKitInformation::toUserOutput(const Kit *k) const
@@ -405,7 +405,7 @@ void DeviceKitInformation::setup(Kit *k)
KitConfigWidget *DeviceKitInformation::createConfigWidget(Kit *k) const
{
- return new Internal::DeviceInformationConfigWidget(k);
+ return new Internal::DeviceInformationConfigWidget(k, isSticky(k));
}
QString DeviceKitInformation::displayNamePostfix(const Kit *k) const
diff --git a/src/plugins/projectexplorer/kitinformationconfigwidget.cpp b/src/plugins/projectexplorer/kitinformationconfigwidget.cpp
index 9621e7e02f5..84bcebfead0 100644
--- a/src/plugins/projectexplorer/kitinformationconfigwidget.cpp
+++ b/src/plugins/projectexplorer/kitinformationconfigwidget.cpp
@@ -55,8 +55,8 @@ namespace Internal {
// SysRootInformationConfigWidget:
// --------------------------------------------------------------------------
-SysRootInformationConfigWidget::SysRootInformationConfigWidget(Kit *k) :
- KitConfigWidget(k),
+SysRootInformationConfigWidget::SysRootInformationConfigWidget(Kit *k, bool sticky) :
+ KitConfigWidget(k, sticky),
m_ignoreChange(false)
{
m_chooser = new Utils::PathChooser;
@@ -108,8 +108,8 @@ void SysRootInformationConfigWidget::pathWasChanged()
// ToolChainInformationConfigWidget:
// --------------------------------------------------------------------------
-ToolChainInformationConfigWidget::ToolChainInformationConfigWidget(Kit *k) :
- KitConfigWidget(k), m_isReadOnly(false)
+ToolChainInformationConfigWidget::ToolChainInformationConfigWidget(Kit *k, bool sticky) :
+ KitConfigWidget(k, sticky), m_isReadOnly(false)
{
ToolChainManager *tcm = ToolChainManager::instance();
@@ -232,8 +232,8 @@ int ToolChainInformationConfigWidget::indexOf(const ToolChain *tc)
// DeviceTypeInformationConfigWidget:
// --------------------------------------------------------------------------
-DeviceTypeInformationConfigWidget::DeviceTypeInformationConfigWidget(Kit *workingCopy) :
- KitConfigWidget(workingCopy), m_isReadOnly(false), m_comboBox(new QComboBox)
+DeviceTypeInformationConfigWidget::DeviceTypeInformationConfigWidget(Kit *workingCopy, bool sticky) :
+ KitConfigWidget(workingCopy, sticky), m_isReadOnly(false), m_comboBox(new QComboBox)
{
QList<IDeviceFactory *> factories
= ExtensionSystem::PluginManager::instance()->getObjects<IDeviceFactory>();
@@ -289,8 +289,8 @@ void DeviceTypeInformationConfigWidget::currentTypeChanged(int idx)
// DeviceInformationConfigWidget:
// --------------------------------------------------------------------------
-DeviceInformationConfigWidget::DeviceInformationConfigWidget(Kit *workingCopy) :
- KitConfigWidget(workingCopy),
+DeviceInformationConfigWidget::DeviceInformationConfigWidget(Kit *workingCopy, bool sticky) :
+ KitConfigWidget(workingCopy, sticky),
m_isReadOnly(false),
m_ignoreChange(false),
m_comboBox(new QComboBox),
diff --git a/src/plugins/projectexplorer/kitinformationconfigwidget.h b/src/plugins/projectexplorer/kitinformationconfigwidget.h
index 3838c3aede9..5847a9de8b1 100644
--- a/src/plugins/projectexplorer/kitinformationconfigwidget.h
+++ b/src/plugins/projectexplorer/kitinformationconfigwidget.h
@@ -57,7 +57,7 @@ class SysRootInformationConfigWidget : public KitConfigWidget
Q_OBJECT
public:
- explicit SysRootInformationConfigWidget(Kit *k);
+ explicit SysRootInformationConfigWidget(Kit *k, bool sticky);
QString displayName() const;
void refresh();
@@ -83,7 +83,7 @@ class ToolChainInformationConfigWidget : public KitConfigWidget
Q_OBJECT
public:
- explicit ToolChainInformationConfigWidget(Kit *k);
+ explicit ToolChainInformationConfigWidget(Kit *k, bool sticky);
QString displayName() const;
void refresh();
@@ -117,7 +117,7 @@ class DeviceTypeInformationConfigWidget : public KitConfigWidget
Q_OBJECT
public:
- explicit DeviceTypeInformationConfigWidget(Kit *workingCopy);
+ explicit DeviceTypeInformationConfigWidget(Kit *workingCopy, bool sticky);
QWidget *mainWidget() const;
QString displayName() const;
@@ -142,7 +142,7 @@ class DeviceInformationConfigWidget : public KitConfigWidget
Q_OBJECT
public:
- explicit DeviceInformationConfigWidget(Kit *workingCopy);
+ explicit DeviceInformationConfigWidget(Kit *workingCopy, bool sticky);
QWidget *mainWidget() const;
QWidget *buttonWidget() const;
diff --git a/src/plugins/projectexplorer/kitmanager.cpp b/src/plugins/projectexplorer/kitmanager.cpp
index 122dc06340d..4f83acf79f8 100644
--- a/src/plugins/projectexplorer/kitmanager.cpp
+++ b/src/plugins/projectexplorer/kitmanager.cpp
@@ -183,6 +183,7 @@ void KitManager::restoreKits()
foreach (Kit *k, system.kits) {
k->setAutoDetected(true);
k->setSdkProvided(true);
+ k->makeSticky();
k->setup();
}
@@ -215,8 +216,11 @@ void KitManager::restoreKits()
// Overwrite settings that the SDK sets to those values:
foreach (const KitInformation *ki, kitInformation()) {
- if (current->hasValue(ki->dataId()))
+ // Copy sticky settings over:
+ if (current->isSticky(ki->dataId())) {
toStore->setValue(ki->dataId(), current->value(ki->dataId()));
+ toStore->makeSticky(ki->dataId());
+ }
}
delete current;
@@ -570,6 +574,11 @@ QString KitInformation::displayNamePostfix(const Kit *k) const
return QString();
}
+bool KitInformation::isSticky(const Kit *k) const
+{
+ return k->isSticky(dataId());
+}
+
void KitInformation::notifyAboutUpdate(Kit *k)
{
KitManager::instance()->notifyAboutUpdate(k);
diff --git a/src/plugins/projectexplorer/kitmanager.h b/src/plugins/projectexplorer/kitmanager.h
index b13ef5288a0..27dfe46f410 100644
--- a/src/plugins/projectexplorer/kitmanager.h
+++ b/src/plugins/projectexplorer/kitmanager.h
@@ -47,6 +47,7 @@ class Task;
class IOutputParser;
class Kit;
class KitConfigWidget;
+class KitManager;
namespace Internal {
class KitManagerConfigWidget;
@@ -91,6 +92,8 @@ public:
virtual QString displayNamePostfix(const Kit *k) const;
+ bool isSticky(const Kit *k) const;
+
protected:
void notifyAboutUpdate(Kit *k);
};
diff --git a/src/plugins/projectexplorer/kitmanagerconfigwidget.cpp b/src/plugins/projectexplorer/kitmanagerconfigwidget.cpp
index 750b3fc479f..5afe809c741 100644
--- a/src/plugins/projectexplorer/kitmanagerconfigwidget.cpp
+++ b/src/plugins/projectexplorer/kitmanagerconfigwidget.cpp
@@ -201,10 +201,12 @@ void KitManagerConfigWidget::updateVisibility()
}
}
-void KitManagerConfigWidget::makeReadOnly()
+void KitManagerConfigWidget::makeStickySubWidgetsReadOnly()
{
- foreach (KitConfigWidget *w, m_widgets)
- w->makeReadOnly();
+ foreach (KitConfigWidget *w, m_widgets) {
+ if (w->isSticky())
+ w->makeReadOnly();
+ }
m_iconButton->setEnabled(false);
m_nameEdit->setEnabled(false);
}
diff --git a/src/plugins/projectexplorer/kitmanagerconfigwidget.h b/src/plugins/projectexplorer/kitmanagerconfigwidget.h
index 2ef5ad3b109..1fcf346dc0c 100644
--- a/src/plugins/projectexplorer/kitmanagerconfigwidget.h
+++ b/src/plugins/projectexplorer/kitmanagerconfigwidget.h
@@ -63,7 +63,7 @@ public:
bool hasWarning() const;
QString validityMessage() const;
void addConfigWidget(ProjectExplorer::KitConfigWidget *widget);
- void makeReadOnly();
+ void makeStickySubWidgetsReadOnly();
Kit *workingCopy() const;
bool configures(ProjectExplorer::Kit *k) const;
diff --git a/src/plugins/projectexplorer/kitmodel.cpp b/src/plugins/projectexplorer/kitmodel.cpp
index 3b49bfbcf67..0b363001cd8 100644
--- a/src/plugins/projectexplorer/kitmodel.cpp
+++ b/src/plugins/projectexplorer/kitmodel.cpp
@@ -59,8 +59,8 @@ public:
widget = KitManager::instance()->createConfigWidget(k);
if (widget) {
- if (k && k->isAutoDetected())
- widget->makeReadOnly();
+ if (k)
+ widget->makeStickySubWidgetsReadOnly();
widget->setVisible(false);
}
}
diff --git a/src/plugins/qt4projectmanager/qmakekitconfigwidget.cpp b/src/plugins/qt4projectmanager/qmakekitconfigwidget.cpp
index fe4814b3393..f50a27a5860 100644
--- a/src/plugins/qt4projectmanager/qmakekitconfigwidget.cpp
+++ b/src/plugins/qt4projectmanager/qmakekitconfigwidget.cpp
@@ -38,8 +38,8 @@
namespace Qt4ProjectManager {
namespace Internal {
-QmakeKitConfigWidget::QmakeKitConfigWidget(ProjectExplorer::Kit *k) :
- ProjectExplorer::KitConfigWidget(k),
+QmakeKitConfigWidget::QmakeKitConfigWidget(ProjectExplorer::Kit *k, bool sticky) :
+ ProjectExplorer::KitConfigWidget(k, sticky),
m_lineEdit(new QLineEdit),
m_ignoreChange(false)
{
diff --git a/src/plugins/qt4projectmanager/qmakekitconfigwidget.h b/src/plugins/qt4projectmanager/qmakekitconfigwidget.h
index 02e63bc0155..99c09403c12 100644
--- a/src/plugins/qt4projectmanager/qmakekitconfigwidget.h
+++ b/src/plugins/qt4projectmanager/qmakekitconfigwidget.h
@@ -44,7 +44,7 @@ class QmakeKitConfigWidget : public ProjectExplorer::KitConfigWidget
Q_OBJECT
public:
- explicit QmakeKitConfigWidget(ProjectExplorer::Kit *k);
+ explicit QmakeKitConfigWidget(ProjectExplorer::Kit *k, bool sticky);
QWidget *mainWidget() const;
QString displayName() const;
diff --git a/src/plugins/qt4projectmanager/qmakekitinformation.cpp b/src/plugins/qt4projectmanager/qmakekitinformation.cpp
index 9e955066911..94e212e1f2d 100644
--- a/src/plugins/qt4projectmanager/qmakekitinformation.cpp
+++ b/src/plugins/qt4projectmanager/qmakekitinformation.cpp
@@ -112,7 +112,7 @@ void QmakeKitInformation::setup(ProjectExplorer::Kit *k)
ProjectExplorer::KitConfigWidget *
QmakeKitInformation::createConfigWidget(ProjectExplorer::Kit *k) const
{
- return new Internal::QmakeKitConfigWidget(k);
+ return new Internal::QmakeKitConfigWidget(k, isSticky(k));
}
ProjectExplorer::KitInformation::ItemList QmakeKitInformation::toUserOutput(const ProjectExplorer::Kit *k) const
diff --git a/src/plugins/qtsupport/qtkitconfigwidget.cpp b/src/plugins/qtsupport/qtkitconfigwidget.cpp
index c057d62d591..ca6013f68ea 100644
--- a/src/plugins/qtsupport/qtkitconfigwidget.cpp
+++ b/src/plugins/qtsupport/qtkitconfigwidget.cpp
@@ -44,8 +44,8 @@
namespace QtSupport {
namespace Internal {
-QtKitConfigWidget::QtKitConfigWidget(ProjectExplorer::Kit *k) :
- KitConfigWidget(k)
+QtKitConfigWidget::QtKitConfigWidget(ProjectExplorer::Kit *k, bool sticky) :
+ KitConfigWidget(k, sticky)
{
m_combo = new QComboBox;
m_combo->addItem(tr("None"), -1);
diff --git a/src/plugins/qtsupport/qtkitconfigwidget.h b/src/plugins/qtsupport/qtkitconfigwidget.h
index 4e5b3476d11..9ecae415a3b 100644
--- a/src/plugins/qtsupport/qtkitconfigwidget.h
+++ b/src/plugins/qtsupport/qtkitconfigwidget.h
@@ -45,7 +45,7 @@ class QtKitConfigWidget : public ProjectExplorer::KitConfigWidget
Q_OBJECT
public:
- explicit QtKitConfigWidget(ProjectExplorer::Kit *k);
+ explicit QtKitConfigWidget(ProjectExplorer::Kit *k, bool sticky);
QString displayName() const;
diff --git a/src/plugins/qtsupport/qtkitinformation.cpp b/src/plugins/qtsupport/qtkitinformation.cpp
index 766c9ea5d32..8389dd485f1 100644
--- a/src/plugins/qtsupport/qtkitinformation.cpp
+++ b/src/plugins/qtsupport/qtkitinformation.cpp
@@ -108,7 +108,7 @@ void QtKitInformation::fix(ProjectExplorer::Kit *k)
ProjectExplorer::KitConfigWidget *QtKitInformation::createConfigWidget(ProjectExplorer::Kit *k) const
{
- return new Internal::QtKitConfigWidget(k);
+ return new Internal::QtKitConfigWidget(k, isSticky(k));
}
QString QtKitInformation::displayNamePostfix(const ProjectExplorer::Kit *k) const