forked from qt-creator/qt-creator
iOS: Rename signing settings widget and make independent from qmake
The build settings widget for the signing settings should not depend on qmake specifics. Move these to the build configuration. Change-Id: Ie5feba577304fae9bde3ed01530250d02be982e1 Reviewed-by: Cristian Adam <cristian.adam@qt.io>
This commit is contained in:
@@ -61,11 +61,12 @@ const char autoManagedSigningKey[] = "Ios.AutoManagedSigning";
|
|||||||
|
|
||||||
const int IdentifierRole = Qt::UserRole+1;
|
const int IdentifierRole = Qt::UserRole+1;
|
||||||
|
|
||||||
|
class IosSigningSettingsWidget : public NamedWidget
|
||||||
class IosBuildSettingsWidget : public NamedWidget
|
|
||||||
{
|
{
|
||||||
public:
|
public:
|
||||||
explicit IosBuildSettingsWidget(IosBuildConfiguration *iosBuildConfiguration);
|
explicit IosSigningSettingsWidget(BuildConfiguration *buildConfiguration,
|
||||||
|
BoolAspect *autoManagedSigning,
|
||||||
|
StringAspect *signingIdentifier);
|
||||||
|
|
||||||
bool isSigningAutomaticallyManaged() const;
|
bool isSigningAutomaticallyManaged() const;
|
||||||
|
|
||||||
@@ -83,7 +84,8 @@ private:
|
|||||||
void updateWarningText();
|
void updateWarningText();
|
||||||
|
|
||||||
private:
|
private:
|
||||||
IosBuildConfiguration *m_bc = nullptr;
|
BoolAspect *m_autoManagedSigning = nullptr;
|
||||||
|
StringAspect *m_signingIdentifier = nullptr;
|
||||||
QString m_lastProfileSelection;
|
QString m_lastProfileSelection;
|
||||||
QString m_lastTeamSelection;
|
QString m_lastTeamSelection;
|
||||||
const bool m_isDevice;
|
const bool m_isDevice;
|
||||||
@@ -96,10 +98,13 @@ private:
|
|||||||
Utils::InfoLabel *m_warningLabel;
|
Utils::InfoLabel *m_warningLabel;
|
||||||
};
|
};
|
||||||
|
|
||||||
IosBuildSettingsWidget::IosBuildSettingsWidget(IosBuildConfiguration *bc)
|
IosSigningSettingsWidget::IosSigningSettingsWidget(BuildConfiguration *buildConfiguration,
|
||||||
: NamedWidget(IosBuildConfiguration::tr("iOS Settings")),
|
BoolAspect *autoManagedSigning,
|
||||||
m_bc(bc),
|
StringAspect *signingIdentifier)
|
||||||
m_isDevice(DeviceTypeKitAspect::deviceTypeId(bc->kit())
|
: NamedWidget(IosBuildConfiguration::tr("iOS Settings"))
|
||||||
|
, m_autoManagedSigning(autoManagedSigning)
|
||||||
|
, m_signingIdentifier(signingIdentifier)
|
||||||
|
, m_isDevice(DeviceTypeKitAspect::deviceTypeId(buildConfiguration->kit())
|
||||||
== Constants::IOS_DEVICE_TYPE)
|
== Constants::IOS_DEVICE_TYPE)
|
||||||
{
|
{
|
||||||
auto detailsWidget = new Utils::DetailsWidget(this);
|
auto detailsWidget = new Utils::DetailsWidget(this);
|
||||||
@@ -126,7 +131,7 @@ IosBuildSettingsWidget::IosBuildSettingsWidget(IosBuildConfiguration *bc)
|
|||||||
m_autoSignCheckbox->setSizePolicy(sizePolicy2);
|
m_autoSignCheckbox->setSizePolicy(sizePolicy2);
|
||||||
m_autoSignCheckbox->setChecked(true);
|
m_autoSignCheckbox->setChecked(true);
|
||||||
m_autoSignCheckbox->setText(IosBuildConfiguration::tr("Automatically manage signing"));
|
m_autoSignCheckbox->setText(IosBuildConfiguration::tr("Automatically manage signing"));
|
||||||
m_autoSignCheckbox->setChecked(bc->m_autoManagedSigning->value());
|
m_autoSignCheckbox->setChecked(m_autoManagedSigning->value());
|
||||||
m_autoSignCheckbox->setEnabled(m_isDevice);
|
m_autoSignCheckbox->setEnabled(m_isDevice);
|
||||||
|
|
||||||
m_signEntityLabel = new QLabel(container);
|
m_signEntityLabel = new QLabel(container);
|
||||||
@@ -137,7 +142,7 @@ IosBuildSettingsWidget::IosBuildSettingsWidget(IosBuildConfiguration *bc)
|
|||||||
|
|
||||||
m_signEntityLabel->setText(IosBuildConfiguration::tr("Development team:"));
|
m_signEntityLabel->setText(IosBuildConfiguration::tr("Development team:"));
|
||||||
|
|
||||||
connect(m_qmakeDefaults, &QPushButton::clicked, this, &IosBuildSettingsWidget::onReset);
|
connect(m_qmakeDefaults, &QPushButton::clicked, this, &IosSigningSettingsWidget::onReset);
|
||||||
|
|
||||||
m_infoLabel->hide();
|
m_infoLabel->hide();
|
||||||
|
|
||||||
@@ -147,13 +152,19 @@ IosBuildSettingsWidget::IosBuildSettingsWidget(IosBuildConfiguration *bc)
|
|||||||
detailsWidget->setWidget(container);
|
detailsWidget->setWidget(container);
|
||||||
|
|
||||||
if (m_isDevice) {
|
if (m_isDevice) {
|
||||||
connect(IosConfigurations::instance(), &IosConfigurations::provisioningDataChanged,
|
connect(IosConfigurations::instance(),
|
||||||
this, &IosBuildSettingsWidget::populateDevelopmentTeams);
|
&IosConfigurations::provisioningDataChanged,
|
||||||
connect(m_signEntityCombo, QOverload<int>::of(&QComboBox::currentIndexChanged),
|
this,
|
||||||
this, &IosBuildSettingsWidget::onSigningEntityComboIndexChanged);
|
&IosSigningSettingsWidget::populateDevelopmentTeams);
|
||||||
connect(m_autoSignCheckbox, &QCheckBox::toggled,
|
connect(m_signEntityCombo,
|
||||||
this, &IosBuildSettingsWidget::configureSigningUi);
|
QOverload<int>::of(&QComboBox::currentIndexChanged),
|
||||||
const QString signingIdentifier = bc->m_signingIdentifier->value();
|
this,
|
||||||
|
&IosSigningSettingsWidget::onSigningEntityComboIndexChanged);
|
||||||
|
connect(m_autoSignCheckbox,
|
||||||
|
&QCheckBox::toggled,
|
||||||
|
this,
|
||||||
|
&IosSigningSettingsWidget::configureSigningUi);
|
||||||
|
const QString signingIdentifier = m_signingIdentifier->value();
|
||||||
configureSigningUi(m_autoSignCheckbox->isChecked());
|
configureSigningUi(m_autoSignCheckbox->isChecked());
|
||||||
setDefaultSigningIdentfier(signingIdentifier);
|
setDefaultSigningIdentfier(signingIdentifier);
|
||||||
}
|
}
|
||||||
@@ -178,7 +189,7 @@ IosBuildSettingsWidget::IosBuildSettingsWidget(IosBuildConfiguration *bc)
|
|||||||
verticalLayout->addWidget(m_warningLabel);
|
verticalLayout->addWidget(m_warningLabel);
|
||||||
}
|
}
|
||||||
|
|
||||||
void IosBuildSettingsWidget::setDefaultSigningIdentfier(const QString &identifier) const
|
void IosSigningSettingsWidget::setDefaultSigningIdentfier(const QString &identifier) const
|
||||||
{
|
{
|
||||||
if (identifier.isEmpty()) {
|
if (identifier.isEmpty()) {
|
||||||
m_signEntityCombo->setCurrentIndex(0);
|
m_signEntityCombo->setCurrentIndex(0);
|
||||||
@@ -204,12 +215,12 @@ void IosBuildSettingsWidget::setDefaultSigningIdentfier(const QString &identifie
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
bool IosBuildSettingsWidget::isSigningAutomaticallyManaged() const
|
bool IosSigningSettingsWidget::isSigningAutomaticallyManaged() const
|
||||||
{
|
{
|
||||||
return m_autoSignCheckbox->isChecked() && m_signEntityCombo->currentIndex() > 0;
|
return m_autoSignCheckbox->isChecked() && m_signEntityCombo->currentIndex() > 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
void IosBuildSettingsWidget::onSigningEntityComboIndexChanged()
|
void IosSigningSettingsWidget::onSigningEntityComboIndexChanged()
|
||||||
{
|
{
|
||||||
QString identifier = selectedIdentifier();
|
QString identifier = selectedIdentifier();
|
||||||
(m_autoSignCheckbox->isChecked() ? m_lastTeamSelection : m_lastProfileSelection) = identifier;
|
(m_autoSignCheckbox->isChecked() ? m_lastTeamSelection : m_lastProfileSelection) = identifier;
|
||||||
@@ -219,7 +230,7 @@ void IosBuildSettingsWidget::onSigningEntityComboIndexChanged()
|
|||||||
announceSigningChanged(m_autoSignCheckbox->isChecked(), identifier);
|
announceSigningChanged(m_autoSignCheckbox->isChecked(), identifier);
|
||||||
}
|
}
|
||||||
|
|
||||||
void IosBuildSettingsWidget::onReset()
|
void IosSigningSettingsWidget::onReset()
|
||||||
{
|
{
|
||||||
m_lastTeamSelection.clear();
|
m_lastTeamSelection.clear();
|
||||||
m_lastProfileSelection.clear();
|
m_lastProfileSelection.clear();
|
||||||
@@ -227,7 +238,7 @@ void IosBuildSettingsWidget::onReset()
|
|||||||
setDefaultSigningIdentfier("");
|
setDefaultSigningIdentfier("");
|
||||||
}
|
}
|
||||||
|
|
||||||
void IosBuildSettingsWidget::configureSigningUi(bool autoManageSigning)
|
void IosSigningSettingsWidget::configureSigningUi(bool autoManageSigning)
|
||||||
{
|
{
|
||||||
m_signEntityLabel->setText(autoManageSigning ? IosBuildConfiguration::tr("Development team:")
|
m_signEntityLabel->setText(autoManageSigning ? IosBuildConfiguration::tr("Development team:")
|
||||||
: IosBuildConfiguration::tr("Provisioning profile:"));
|
: IosBuildConfiguration::tr("Provisioning profile:"));
|
||||||
@@ -240,17 +251,16 @@ void IosBuildSettingsWidget::configureSigningUi(bool autoManageSigning)
|
|||||||
announceSigningChanged(autoManageSigning, selectedIdentifier());
|
announceSigningChanged(autoManageSigning, selectedIdentifier());
|
||||||
}
|
}
|
||||||
|
|
||||||
void IosBuildSettingsWidget::announceSigningChanged(bool autoManagedSigning, QString identifier)
|
void IosSigningSettingsWidget::announceSigningChanged(bool autoManagedSigning, QString identifier)
|
||||||
{
|
{
|
||||||
if (m_bc->m_signingIdentifier->value().compare(identifier) != 0
|
if (m_signingIdentifier->value().compare(identifier) != 0
|
||||||
|| m_bc->m_autoManagedSigning->value() != autoManagedSigning) {
|
|| m_autoManagedSigning->value() != autoManagedSigning) {
|
||||||
m_bc->m_autoManagedSigning->setValue(autoManagedSigning);
|
m_autoManagedSigning->setValue(autoManagedSigning);
|
||||||
m_bc->m_signingIdentifier->setValue(identifier);
|
m_signingIdentifier->setValue(identifier);
|
||||||
m_bc->updateQmakeCommand();
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
void IosBuildSettingsWidget::populateDevelopmentTeams()
|
void IosSigningSettingsWidget::populateDevelopmentTeams()
|
||||||
{
|
{
|
||||||
{
|
{
|
||||||
QSignalBlocker blocker(m_signEntityCombo);
|
QSignalBlocker blocker(m_signEntityCombo);
|
||||||
@@ -269,7 +279,7 @@ void IosBuildSettingsWidget::populateDevelopmentTeams()
|
|||||||
updateWarningText();
|
updateWarningText();
|
||||||
}
|
}
|
||||||
|
|
||||||
void IosBuildSettingsWidget::populateProvisioningProfiles()
|
void IosSigningSettingsWidget::populateProvisioningProfiles()
|
||||||
{
|
{
|
||||||
{
|
{
|
||||||
// Populate Team id's
|
// Populate Team id's
|
||||||
@@ -292,12 +302,12 @@ void IosBuildSettingsWidget::populateProvisioningProfiles()
|
|||||||
updateWarningText();
|
updateWarningText();
|
||||||
}
|
}
|
||||||
|
|
||||||
QString IosBuildSettingsWidget::selectedIdentifier() const
|
QString IosSigningSettingsWidget::selectedIdentifier() const
|
||||||
{
|
{
|
||||||
return m_signEntityCombo->currentData(IdentifierRole).toString();
|
return m_signEntityCombo->currentData(IdentifierRole).toString();
|
||||||
}
|
}
|
||||||
|
|
||||||
void IosBuildSettingsWidget::updateInfoText()
|
void IosSigningSettingsWidget::updateInfoText()
|
||||||
{
|
{
|
||||||
if (!m_isDevice)
|
if (!m_isDevice)
|
||||||
return;
|
return;
|
||||||
@@ -342,7 +352,7 @@ void IosBuildSettingsWidget::updateInfoText()
|
|||||||
m_infoLabel->setText(infoMessage);
|
m_infoLabel->setText(infoMessage);
|
||||||
}
|
}
|
||||||
|
|
||||||
void IosBuildSettingsWidget::updateWarningText()
|
void IosSigningSettingsWidget::updateWarningText()
|
||||||
{
|
{
|
||||||
if (!m_isDevice)
|
if (!m_isDevice)
|
||||||
return;
|
return;
|
||||||
@@ -387,6 +397,15 @@ IosBuildConfiguration::IosBuildConfiguration(Target *target, Utils::Id id)
|
|||||||
m_autoManagedSigning = addAspect<BoolAspect>();
|
m_autoManagedSigning = addAspect<BoolAspect>();
|
||||||
m_autoManagedSigning->setDefaultValue(true);
|
m_autoManagedSigning->setDefaultValue(true);
|
||||||
m_autoManagedSigning->setSettingsKey(autoManagedSigningKey);
|
m_autoManagedSigning->setSettingsKey(autoManagedSigningKey);
|
||||||
|
|
||||||
|
connect(m_signingIdentifier,
|
||||||
|
&BaseAspect::changed,
|
||||||
|
this,
|
||||||
|
&IosBuildConfiguration::updateQmakeCommand);
|
||||||
|
connect(m_autoManagedSigning,
|
||||||
|
&BaseAspect::changed,
|
||||||
|
this,
|
||||||
|
&IosBuildConfiguration::updateQmakeCommand);
|
||||||
}
|
}
|
||||||
|
|
||||||
QList<NamedWidget *> IosBuildConfiguration::createSubConfigWidgets()
|
QList<NamedWidget *> IosBuildConfiguration::createSubConfigWidgets()
|
||||||
@@ -394,7 +413,9 @@ QList<NamedWidget *> IosBuildConfiguration::createSubConfigWidgets()
|
|||||||
auto subConfigWidgets = QmakeBuildConfiguration::createSubConfigWidgets();
|
auto subConfigWidgets = QmakeBuildConfiguration::createSubConfigWidgets();
|
||||||
|
|
||||||
// Ownership of this widget is with BuildSettingsWidget
|
// Ownership of this widget is with BuildSettingsWidget
|
||||||
auto buildSettingsWidget = new IosBuildSettingsWidget(this);
|
auto buildSettingsWidget = new IosSigningSettingsWidget(this,
|
||||||
|
m_autoManagedSigning,
|
||||||
|
m_signingIdentifier);
|
||||||
subConfigWidgets.prepend(buildSettingsWidget);
|
subConfigWidgets.prepend(buildSettingsWidget);
|
||||||
return subConfigWidgets;
|
return subConfigWidgets;
|
||||||
}
|
}
|
||||||
|
@@ -39,8 +39,6 @@ public:
|
|||||||
IosBuildConfiguration(ProjectExplorer::Target *target, Utils::Id id);
|
IosBuildConfiguration(ProjectExplorer::Target *target, Utils::Id id);
|
||||||
|
|
||||||
private:
|
private:
|
||||||
friend class IosBuildSettingsWidget;
|
|
||||||
|
|
||||||
QList<ProjectExplorer::NamedWidget *> createSubConfigWidgets() override;
|
QList<ProjectExplorer::NamedWidget *> createSubConfigWidgets() override;
|
||||||
bool fromMap(const QVariantMap &map) override;
|
bool fromMap(const QVariantMap &map) override;
|
||||||
|
|
||||||
|
Reference in New Issue
Block a user