forked from qt-creator/qt-creator
Add signing options to CMake/iOS build configuration
Adds the signing settings to iOS configurations. Adds placeholders for signing flags to the initial CMake arguments, and updates the CMake configuration when signing settings change. The new configuration doesn't get automatically applied. Only the "Apply Configuration Changes" button gets enabled and the user has to press that explicitly. This seems to be a more general issue affecting the QML debugging setting too, though. Task-number: QTCREATORBUG-23574 Change-Id: I3e8d45f565347e1ad2ac274a21b1552f1510e8f4 Reviewed-by: Cristian Adam <cristian.adam@qt.io>
This commit is contained in:
@@ -53,10 +53,12 @@ BuildDirParameters::BuildDirParameters(CMakeBuildConfiguration *bc)
|
|||||||
|
|
||||||
const Utils::MacroExpander *expander = bc->macroExpander();
|
const Utils::MacroExpander *expander = bc->macroExpander();
|
||||||
|
|
||||||
initialCMakeArguments = Utils::transform(bc->initialCMakeArguments(),
|
const QStringList expandedArguments = Utils::transform(bc->initialCMakeArguments(),
|
||||||
[expander](const QString &s) {
|
[expander](const QString &s) {
|
||||||
return expander->expand(s);
|
return expander->expand(s);
|
||||||
});
|
});
|
||||||
|
initialCMakeArguments = Utils::filtered(expandedArguments,
|
||||||
|
[](const QString &s) { return !s.isEmpty(); });
|
||||||
extraCMakeArguments = Utils::transform(bc->extraCMakeArguments(),
|
extraCMakeArguments = Utils::transform(bc->extraCMakeArguments(),
|
||||||
[expander](const QString &s) {
|
[expander](const QString &s) {
|
||||||
return expander->expand(s);
|
return expander->expand(s);
|
||||||
|
@@ -35,10 +35,11 @@
|
|||||||
#include <QString>
|
#include <QString>
|
||||||
|
|
||||||
namespace CMakeProjectManager {
|
namespace CMakeProjectManager {
|
||||||
namespace Internal {
|
|
||||||
|
|
||||||
class CMakeBuildConfiguration;
|
class CMakeBuildConfiguration;
|
||||||
|
|
||||||
|
namespace Internal {
|
||||||
|
|
||||||
class BuildDirParameters {
|
class BuildDirParameters {
|
||||||
public:
|
public:
|
||||||
BuildDirParameters();
|
BuildDirParameters();
|
||||||
|
@@ -77,13 +77,17 @@
|
|||||||
|
|
||||||
using namespace ProjectExplorer;
|
using namespace ProjectExplorer;
|
||||||
using namespace Utils;
|
using namespace Utils;
|
||||||
|
using namespace CMakeProjectManager::Internal;
|
||||||
|
|
||||||
namespace CMakeProjectManager {
|
namespace CMakeProjectManager {
|
||||||
namespace Internal {
|
|
||||||
|
|
||||||
static Q_LOGGING_CATEGORY(cmakeBuildConfigurationLog, "qtc.cmake.bc", QtWarningMsg);
|
static Q_LOGGING_CATEGORY(cmakeBuildConfigurationLog, "qtc.cmake.bc", QtWarningMsg);
|
||||||
|
|
||||||
const char CONFIGURATION_KEY[] = "CMake.Configuration";
|
const char CONFIGURATION_KEY[] = "CMake.Configuration";
|
||||||
|
const char DEVELOPMENT_TEAM_FLAG[] = "Ios:DevelopmentTeam:Flag";
|
||||||
|
const char PROVISIONING_PROFILE_FLAG[] = "Ios:ProvisioningProfile:Flag";
|
||||||
|
|
||||||
|
namespace Internal {
|
||||||
|
|
||||||
class CMakeBuildSettingsWidget : public NamedWidget
|
class CMakeBuildSettingsWidget : public NamedWidget
|
||||||
{
|
{
|
||||||
@@ -98,6 +102,7 @@ private:
|
|||||||
void updateAdvancedCheckBox();
|
void updateAdvancedCheckBox();
|
||||||
void updateFromKit();
|
void updateFromKit();
|
||||||
CMakeProjectManager::CMakeConfig getQmlDebugCxxFlags();
|
CMakeProjectManager::CMakeConfig getQmlDebugCxxFlags();
|
||||||
|
CMakeProjectManager::CMakeConfig getSigningFlagsChanges();
|
||||||
|
|
||||||
void updateSelection();
|
void updateSelection();
|
||||||
void setVariableUnsetFlag(bool unsetFlag);
|
void setVariableUnsetFlag(bool unsetFlag);
|
||||||
@@ -339,6 +344,11 @@ CMakeBuildSettingsWidget::CMakeBuildSettingsWidget(CMakeBuildConfiguration *bc)
|
|||||||
connect(m_configModel, &QAbstractItemModel::modelReset,
|
connect(m_configModel, &QAbstractItemModel::modelReset,
|
||||||
this, &CMakeBuildSettingsWidget::updateButtonState);
|
this, &CMakeBuildSettingsWidget::updateButtonState);
|
||||||
|
|
||||||
|
connect(m_buildConfiguration,
|
||||||
|
&CMakeBuildConfiguration::signingFlagsChanged,
|
||||||
|
this,
|
||||||
|
&CMakeBuildSettingsWidget::updateButtonState);
|
||||||
|
|
||||||
connect(m_showAdvancedCheckBox, &QCheckBox::stateChanged,
|
connect(m_showAdvancedCheckBox, &QCheckBox::stateChanged,
|
||||||
this, &CMakeBuildSettingsWidget::updateAdvancedCheckBox);
|
this, &CMakeBuildSettingsWidget::updateAdvancedCheckBox);
|
||||||
|
|
||||||
@@ -426,7 +436,8 @@ void CMakeBuildSettingsWidget::updateButtonState()
|
|||||||
const QList<ConfigModel::DataItem> changes = m_configModel->configurationForCMake();
|
const QList<ConfigModel::DataItem> changes = m_configModel->configurationForCMake();
|
||||||
|
|
||||||
const CMakeConfig configChanges
|
const CMakeConfig configChanges
|
||||||
= getQmlDebugCxxFlags() + Utils::transform(changes, [](const ConfigModel::DataItem &i) {
|
= getQmlDebugCxxFlags() + getSigningFlagsChanges()
|
||||||
|
+ Utils::transform(changes, [](const ConfigModel::DataItem &i) {
|
||||||
CMakeConfigItem ni;
|
CMakeConfigItem ni;
|
||||||
ni.key = i.key.toUtf8();
|
ni.key = i.key.toUtf8();
|
||||||
ni.value = i.value.toUtf8();
|
ni.value = i.value.toUtf8();
|
||||||
@@ -525,6 +536,28 @@ CMakeConfig CMakeBuildSettingsWidget::getQmlDebugCxxFlags()
|
|||||||
return changedConfig;
|
return changedConfig;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
CMakeConfig CMakeBuildSettingsWidget::getSigningFlagsChanges()
|
||||||
|
{
|
||||||
|
const CMakeConfig flags = m_buildConfiguration->signingFlags();
|
||||||
|
if (flags.isEmpty())
|
||||||
|
return {};
|
||||||
|
const CMakeConfig configList = m_buildConfiguration->configurationFromCMake();
|
||||||
|
if (configList.isEmpty()) {
|
||||||
|
// we don't have any configuration --> initial configuration takes care of this itself
|
||||||
|
return {};
|
||||||
|
}
|
||||||
|
CMakeConfig changedConfig;
|
||||||
|
for (const CMakeConfigItem &signingFlag : flags) {
|
||||||
|
const CMakeConfigItem existingFlag = Utils::findOrDefault(configList,
|
||||||
|
Utils::equal(&CMakeConfigItem::key,
|
||||||
|
signingFlag.key));
|
||||||
|
const bool notInConfig = existingFlag.key.isEmpty();
|
||||||
|
if (notInConfig != signingFlag.isUnset || existingFlag.value != signingFlag.value)
|
||||||
|
changedConfig.append(signingFlag);
|
||||||
|
}
|
||||||
|
return changedConfig;
|
||||||
|
}
|
||||||
|
|
||||||
void CMakeBuildSettingsWidget::updateSelection()
|
void CMakeBuildSettingsWidget::updateSelection()
|
||||||
{
|
{
|
||||||
const QModelIndexList selectedIndexes = m_configView->selectionModel()->selectedIndexes();
|
const QModelIndexList selectedIndexes = m_configView->selectionModel()->selectedIndexes();
|
||||||
@@ -662,6 +695,8 @@ static QStringList defaultInitialCMakeArguments(const Kit *k, const QString buil
|
|||||||
return initialArgs;
|
return initialArgs;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
} // namespace Internal
|
||||||
|
|
||||||
// -----------------------------------------------------------------------------
|
// -----------------------------------------------------------------------------
|
||||||
// CMakeBuildConfiguration:
|
// CMakeBuildConfiguration:
|
||||||
// -----------------------------------------------------------------------------
|
// -----------------------------------------------------------------------------
|
||||||
@@ -696,6 +731,23 @@ CMakeBuildConfiguration::CMakeBuildConfiguration(Target *target, Id id)
|
|||||||
|
|
||||||
auto initialCMakeArgumentsAspect = addAspect<InitialCMakeArgumentsAspect>();
|
auto initialCMakeArgumentsAspect = addAspect<InitialCMakeArgumentsAspect>();
|
||||||
initialCMakeArgumentsAspect->setMacroExpanderProvider([this]{ return macroExpander(); });
|
initialCMakeArgumentsAspect->setMacroExpanderProvider([this]{ return macroExpander(); });
|
||||||
|
macroExpander()->registerVariable(DEVELOPMENT_TEAM_FLAG,
|
||||||
|
tr("The CMake flag for the development team"),
|
||||||
|
[this] {
|
||||||
|
const CMakeConfig flags = signingFlags();
|
||||||
|
if (!flags.isEmpty())
|
||||||
|
return flags.first().toArgument();
|
||||||
|
return QString();
|
||||||
|
});
|
||||||
|
macroExpander()->registerVariable(PROVISIONING_PROFILE_FLAG,
|
||||||
|
tr("The CMake flag for the provisioning profile"),
|
||||||
|
[this] {
|
||||||
|
const CMakeConfig flags = signingFlags();
|
||||||
|
if (flags.size() > 1 && !flags.at(1).isUnset) {
|
||||||
|
return flags.at(1).toArgument();
|
||||||
|
}
|
||||||
|
return QString();
|
||||||
|
});
|
||||||
|
|
||||||
addAspect<SourceDirectoryAspect>();
|
addAspect<SourceDirectoryAspect>();
|
||||||
addAspect<BuildTypeAspect>();
|
addAspect<BuildTypeAspect>();
|
||||||
@@ -774,6 +826,8 @@ CMakeBuildConfiguration::CMakeBuildConfiguration(Target *target, Id id)
|
|||||||
"Qt6/qt.toolchain.cmake");
|
"Qt6/qt.toolchain.cmake");
|
||||||
initialArgs.append("-DCMAKE_OSX_ARCHITECTURES:STRING=" + architecture);
|
initialArgs.append("-DCMAKE_OSX_ARCHITECTURES:STRING=" + architecture);
|
||||||
initialArgs.append("-DCMAKE_OSX_SYSROOT:STRING=" + sysroot);
|
initialArgs.append("-DCMAKE_OSX_SYSROOT:STRING=" + sysroot);
|
||||||
|
initialArgs.append("%{" + QLatin1String(DEVELOPMENT_TEAM_FLAG) + "}");
|
||||||
|
initialArgs.append("%{" + QLatin1String(PROVISIONING_PROFILE_FLAG) + "}");
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -972,14 +1026,18 @@ NamedWidget *CMakeBuildConfiguration::createConfigWidget()
|
|||||||
return new CMakeBuildSettingsWidget(this);
|
return new CMakeBuildSettingsWidget(this);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
CMakeConfig CMakeBuildConfiguration::signingFlags() const
|
||||||
|
{
|
||||||
|
return {};
|
||||||
|
}
|
||||||
|
|
||||||
/*!
|
/*!
|
||||||
\class CMakeBuildConfigurationFactory
|
\class CMakeBuildConfigurationFactory
|
||||||
*/
|
*/
|
||||||
|
|
||||||
CMakeBuildConfigurationFactory::CMakeBuildConfigurationFactory()
|
CMakeBuildConfigurationFactory::CMakeBuildConfigurationFactory()
|
||||||
{
|
{
|
||||||
registerBuildConfiguration<CMakeBuildConfiguration>(
|
registerBuildConfiguration<CMakeBuildConfiguration>(Constants::CMAKE_BUILDCONFIGURATION_ID);
|
||||||
"CMakeProjectManager.CMakeBuildConfiguration");
|
|
||||||
|
|
||||||
setSupportedProjectType(CMakeProjectManager::Constants::CMAKE_PROJECT_ID);
|
setSupportedProjectType(CMakeProjectManager::Constants::CMAKE_PROJECT_ID);
|
||||||
setSupportedProjectMimeTypeName(Constants::CMAKE_PROJECT_MIMETYPE);
|
setSupportedProjectMimeTypeName(Constants::CMAKE_PROJECT_MIMETYPE);
|
||||||
@@ -1114,6 +1172,8 @@ void CMakeBuildConfiguration::setCMakeBuildType(const QString &cmakeBuildType)
|
|||||||
aspect<BuildTypeAspect>()->setValue(cmakeBuildType);
|
aspect<BuildTypeAspect>()->setValue(cmakeBuildType);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
namespace Internal {
|
||||||
|
|
||||||
// ----------------------------------------------------------------------
|
// ----------------------------------------------------------------------
|
||||||
// - InitialCMakeParametersAspect:
|
// - InitialCMakeParametersAspect:
|
||||||
// ----------------------------------------------------------------------
|
// ----------------------------------------------------------------------
|
||||||
|
@@ -25,6 +25,7 @@
|
|||||||
|
|
||||||
#pragma once
|
#pragma once
|
||||||
|
|
||||||
|
#include "cmake_global.h"
|
||||||
#include "cmakeconfigitem.h"
|
#include "cmakeconfigitem.h"
|
||||||
#include "configmodel.h"
|
#include "configmodel.h"
|
||||||
|
|
||||||
@@ -38,16 +39,18 @@ namespace Internal {
|
|||||||
|
|
||||||
class CMakeBuildSystem;
|
class CMakeBuildSystem;
|
||||||
class CMakeBuildSettingsWidget;
|
class CMakeBuildSettingsWidget;
|
||||||
|
class CMakeProjectImporter;
|
||||||
|
|
||||||
class CMakeBuildConfiguration final : public ProjectExplorer::BuildConfiguration
|
} // namespace Internal
|
||||||
|
|
||||||
|
class CMAKE_EXPORT CMakeBuildConfiguration : public ProjectExplorer::BuildConfiguration
|
||||||
{
|
{
|
||||||
Q_OBJECT
|
Q_OBJECT
|
||||||
|
|
||||||
friend class ProjectExplorer::BuildConfigurationFactory;
|
|
||||||
CMakeBuildConfiguration(ProjectExplorer::Target *target, Utils::Id id);
|
|
||||||
~CMakeBuildConfiguration() final;
|
|
||||||
|
|
||||||
public:
|
public:
|
||||||
|
CMakeBuildConfiguration(ProjectExplorer::Target *target, Utils::Id id);
|
||||||
|
~CMakeBuildConfiguration() override;
|
||||||
|
|
||||||
CMakeConfig configurationFromCMake() const;
|
CMakeConfig configurationFromCMake() const;
|
||||||
|
|
||||||
QStringList extraCMakeArguments() const;
|
QStringList extraCMakeArguments() const;
|
||||||
@@ -76,6 +79,10 @@ public:
|
|||||||
signals:
|
signals:
|
||||||
void errorOccurred(const QString &message);
|
void errorOccurred(const QString &message);
|
||||||
void warningOccurred(const QString &message);
|
void warningOccurred(const QString &message);
|
||||||
|
void signingFlagsChanged();
|
||||||
|
|
||||||
|
protected:
|
||||||
|
bool fromMap(const QVariantMap &map) override;
|
||||||
|
|
||||||
private:
|
private:
|
||||||
QVariantMap toMap() const override;
|
QVariantMap toMap() const override;
|
||||||
@@ -83,7 +90,7 @@ private:
|
|||||||
|
|
||||||
ProjectExplorer::NamedWidget *createConfigWidget() override;
|
ProjectExplorer::NamedWidget *createConfigWidget() override;
|
||||||
|
|
||||||
bool fromMap(const QVariantMap &map) override;
|
virtual CMakeConfig signingFlags() const;
|
||||||
|
|
||||||
enum ForceEnabledChanged { False, True };
|
enum ForceEnabledChanged { False, True };
|
||||||
void clearError(ForceEnabledChanged fec = ForceEnabledChanged::False);
|
void clearError(ForceEnabledChanged fec = ForceEnabledChanged::False);
|
||||||
@@ -101,17 +108,16 @@ private:
|
|||||||
QString m_warning;
|
QString m_warning;
|
||||||
|
|
||||||
CMakeConfig m_configurationFromCMake;
|
CMakeConfig m_configurationFromCMake;
|
||||||
CMakeBuildSystem *m_buildSystem = nullptr;
|
Internal::CMakeBuildSystem *m_buildSystem = nullptr;
|
||||||
|
|
||||||
QStringList m_extraCMakeArguments;
|
QStringList m_extraCMakeArguments;
|
||||||
|
|
||||||
friend class CMakeBuildSettingsWidget;
|
friend class Internal::CMakeBuildSettingsWidget;
|
||||||
friend class CMakeBuildSystem;
|
friend class Internal::CMakeBuildSystem;
|
||||||
};
|
};
|
||||||
|
|
||||||
class CMakeProjectImporter;
|
class CMAKE_EXPORT CMakeBuildConfigurationFactory
|
||||||
|
: public ProjectExplorer::BuildConfigurationFactory
|
||||||
class CMakeBuildConfigurationFactory final : public ProjectExplorer::BuildConfigurationFactory
|
|
||||||
{
|
{
|
||||||
public:
|
public:
|
||||||
CMakeBuildConfigurationFactory();
|
CMakeBuildConfigurationFactory();
|
||||||
@@ -128,9 +134,11 @@ public:
|
|||||||
private:
|
private:
|
||||||
static ProjectExplorer::BuildInfo createBuildInfo(BuildType buildType);
|
static ProjectExplorer::BuildInfo createBuildInfo(BuildType buildType);
|
||||||
|
|
||||||
friend class CMakeProjectImporter;
|
friend class Internal::CMakeProjectImporter;
|
||||||
};
|
};
|
||||||
|
|
||||||
|
namespace Internal {
|
||||||
|
|
||||||
class InitialCMakeArgumentsAspect final : public Utils::StringAspect
|
class InitialCMakeArgumentsAspect final : public Utils::StringAspect
|
||||||
{
|
{
|
||||||
Q_OBJECT
|
Q_OBJECT
|
||||||
@@ -155,6 +163,5 @@ public:
|
|||||||
BuildTypeAspect();
|
BuildTypeAspect();
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|
||||||
} // namespace Internal
|
} // namespace Internal
|
||||||
} // namespace CMakeProjectManager
|
} // namespace CMakeProjectManager
|
||||||
|
@@ -43,10 +43,11 @@ class CppProjectUpdater;
|
|||||||
} // namespace CppTools
|
} // namespace CppTools
|
||||||
|
|
||||||
namespace CMakeProjectManager {
|
namespace CMakeProjectManager {
|
||||||
namespace Internal {
|
|
||||||
|
|
||||||
class CMakeBuildConfiguration;
|
class CMakeBuildConfiguration;
|
||||||
|
|
||||||
|
namespace Internal {
|
||||||
|
|
||||||
// --------------------------------------------------------------------
|
// --------------------------------------------------------------------
|
||||||
// CMakeBuildSystem:
|
// CMakeBuildSystem:
|
||||||
// --------------------------------------------------------------------
|
// --------------------------------------------------------------------
|
||||||
|
@@ -42,6 +42,8 @@ const char CMAKE_HOME_DIR[] = "CMakeProject.HomeDirectory";
|
|||||||
// Project
|
// Project
|
||||||
const char CMAKE_PROJECT_ID[] = "CMakeProjectManager.CMakeProject";
|
const char CMAKE_PROJECT_ID[] = "CMakeProjectManager.CMakeProject";
|
||||||
|
|
||||||
|
const char CMAKE_BUILDCONFIGURATION_ID[] = "CMakeProjectManager.CMakeBuildConfiguration";
|
||||||
|
|
||||||
// Menu
|
// Menu
|
||||||
const char M_CONTEXT[] = "CMakeEditor.ContextMenu";
|
const char M_CONTEXT[] = "CMakeEditor.ContextMenu";
|
||||||
|
|
||||||
|
@@ -1,6 +1,6 @@
|
|||||||
add_qtc_plugin(Ios
|
add_qtc_plugin(Ios
|
||||||
DEPENDS QmlDebug Qt5::Xml
|
DEPENDS QmlDebug Qt5::Xml
|
||||||
PLUGIN_DEPENDS Core Debugger ProjectExplorer QmakeProjectManager
|
PLUGIN_DEPENDS Core Debugger ProjectExplorer QmakeProjectManager CMakeProjectManager
|
||||||
SOURCES
|
SOURCES
|
||||||
createsimulatordialog.cpp createsimulatordialog.h createsimulatordialog.ui
|
createsimulatordialog.cpp createsimulatordialog.h createsimulatordialog.ui
|
||||||
ios.qrc
|
ios.qrc
|
||||||
|
@@ -6,6 +6,7 @@ QtcPlugin {
|
|||||||
Depends { name: "Core" }
|
Depends { name: "Core" }
|
||||||
Depends { name: "ProjectExplorer" }
|
Depends { name: "ProjectExplorer" }
|
||||||
Depends { name: "QmakeProjectManager" }
|
Depends { name: "QmakeProjectManager" }
|
||||||
|
Depends { name: "CMakeProjectManager" }
|
||||||
Depends { name: "Debugger" }
|
Depends { name: "Debugger" }
|
||||||
Depends { name: "QtSupport" }
|
Depends { name: "QtSupport" }
|
||||||
Depends { name: "QmlDebug" }
|
Depends { name: "QmlDebug" }
|
||||||
|
@@ -6,4 +6,5 @@ QTC_PLUGIN_DEPENDS += \
|
|||||||
coreplugin \
|
coreplugin \
|
||||||
debugger \
|
debugger \
|
||||||
projectexplorer \
|
projectexplorer \
|
||||||
qmakeprojectmanager
|
qmakeprojectmanager \
|
||||||
|
cmakeprojectmanager
|
||||||
|
@@ -32,6 +32,8 @@
|
|||||||
#include <projectexplorer/namedwidget.h>
|
#include <projectexplorer/namedwidget.h>
|
||||||
#include <projectexplorer/target.h>
|
#include <projectexplorer/target.h>
|
||||||
|
|
||||||
|
#include <cmakeprojectmanager/cmakeprojectconstants.h>
|
||||||
|
|
||||||
#include <qmakeprojectmanager/qmakebuildinfo.h>
|
#include <qmakeprojectmanager/qmakebuildinfo.h>
|
||||||
#include <qmakeprojectmanager/qmakeprojectmanagerconstants.h>
|
#include <qmakeprojectmanager/qmakeprojectmanagerconstants.h>
|
||||||
|
|
||||||
@@ -46,6 +48,7 @@
|
|||||||
#include <QPushButton>
|
#include <QPushButton>
|
||||||
|
|
||||||
using namespace QmakeProjectManager;
|
using namespace QmakeProjectManager;
|
||||||
|
using namespace CMakeProjectManager;
|
||||||
using namespace ProjectExplorer;
|
using namespace ProjectExplorer;
|
||||||
using namespace Utils;
|
using namespace Utils;
|
||||||
|
|
||||||
@@ -101,7 +104,7 @@ private:
|
|||||||
IosSigningSettingsWidget::IosSigningSettingsWidget(BuildConfiguration *buildConfiguration,
|
IosSigningSettingsWidget::IosSigningSettingsWidget(BuildConfiguration *buildConfiguration,
|
||||||
BoolAspect *autoManagedSigning,
|
BoolAspect *autoManagedSigning,
|
||||||
StringAspect *signingIdentifier)
|
StringAspect *signingIdentifier)
|
||||||
: NamedWidget(IosBuildConfiguration::tr("iOS Settings"))
|
: NamedWidget(IosQmakeBuildConfiguration::tr("iOS Settings"))
|
||||||
, m_autoManagedSigning(autoManagedSigning)
|
, m_autoManagedSigning(autoManagedSigning)
|
||||||
, m_signingIdentifier(signingIdentifier)
|
, m_signingIdentifier(signingIdentifier)
|
||||||
, m_isDevice(DeviceTypeKitAspect::deviceTypeId(buildConfiguration->kit())
|
, m_isDevice(DeviceTypeKitAspect::deviceTypeId(buildConfiguration->kit())
|
||||||
@@ -115,7 +118,7 @@ IosSigningSettingsWidget::IosSigningSettingsWidget(BuildConfiguration *buildConf
|
|||||||
sizePolicy.setHorizontalStretch(0);
|
sizePolicy.setHorizontalStretch(0);
|
||||||
sizePolicy.setVerticalStretch(0);
|
sizePolicy.setVerticalStretch(0);
|
||||||
m_qmakeDefaults->setSizePolicy(sizePolicy);
|
m_qmakeDefaults->setSizePolicy(sizePolicy);
|
||||||
m_qmakeDefaults->setText(IosBuildConfiguration::tr("Reset"));
|
m_qmakeDefaults->setText(IosQmakeBuildConfiguration::tr("Reset"));
|
||||||
m_qmakeDefaults->setEnabled(m_isDevice);
|
m_qmakeDefaults->setEnabled(m_isDevice);
|
||||||
|
|
||||||
m_signEntityCombo = new QComboBox(container);
|
m_signEntityCombo = new QComboBox(container);
|
||||||
@@ -130,7 +133,7 @@ IosSigningSettingsWidget::IosSigningSettingsWidget(BuildConfiguration *buildConf
|
|||||||
sizePolicy2.setVerticalStretch(0);
|
sizePolicy2.setVerticalStretch(0);
|
||||||
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(IosQmakeBuildConfiguration::tr("Automatically manage signing"));
|
||||||
m_autoSignCheckbox->setChecked(m_autoManagedSigning->value());
|
m_autoSignCheckbox->setChecked(m_autoManagedSigning->value());
|
||||||
m_autoSignCheckbox->setEnabled(m_isDevice);
|
m_autoSignCheckbox->setEnabled(m_isDevice);
|
||||||
|
|
||||||
@@ -140,7 +143,7 @@ IosSigningSettingsWidget::IosSigningSettingsWidget(BuildConfiguration *buildConf
|
|||||||
|
|
||||||
m_warningLabel = new Utils::InfoLabel({}, Utils::InfoLabel::Warning, container);
|
m_warningLabel = new Utils::InfoLabel({}, Utils::InfoLabel::Warning, container);
|
||||||
|
|
||||||
m_signEntityLabel->setText(IosBuildConfiguration::tr("Development team:"));
|
m_signEntityLabel->setText(IosQmakeBuildConfiguration::tr("Development team:"));
|
||||||
|
|
||||||
connect(m_qmakeDefaults, &QPushButton::clicked, this, &IosSigningSettingsWidget::onReset);
|
connect(m_qmakeDefaults, &QPushButton::clicked, this, &IosSigningSettingsWidget::onReset);
|
||||||
|
|
||||||
@@ -240,8 +243,9 @@ void IosSigningSettingsWidget::onReset()
|
|||||||
|
|
||||||
void IosSigningSettingsWidget::configureSigningUi(bool autoManageSigning)
|
void IosSigningSettingsWidget::configureSigningUi(bool autoManageSigning)
|
||||||
{
|
{
|
||||||
m_signEntityLabel->setText(autoManageSigning ? IosBuildConfiguration::tr("Development team:")
|
m_signEntityLabel->setText(autoManageSigning
|
||||||
: IosBuildConfiguration::tr("Provisioning profile:"));
|
? IosQmakeBuildConfiguration::tr("Development team:")
|
||||||
|
: IosQmakeBuildConfiguration::tr("Provisioning profile:"));
|
||||||
if (autoManageSigning)
|
if (autoManageSigning)
|
||||||
populateDevelopmentTeams();
|
populateDevelopmentTeams();
|
||||||
else
|
else
|
||||||
@@ -266,7 +270,7 @@ void IosSigningSettingsWidget::populateDevelopmentTeams()
|
|||||||
QSignalBlocker blocker(m_signEntityCombo);
|
QSignalBlocker blocker(m_signEntityCombo);
|
||||||
// Populate Team id's
|
// Populate Team id's
|
||||||
m_signEntityCombo->clear();
|
m_signEntityCombo->clear();
|
||||||
m_signEntityCombo->addItem(IosBuildConfiguration::tr("Default"));
|
m_signEntityCombo->addItem(IosQmakeBuildConfiguration::tr("Default"));
|
||||||
foreach (auto team, IosConfigurations::developmentTeams()) {
|
foreach (auto team, IosConfigurations::developmentTeams()) {
|
||||||
m_signEntityCombo->addItem(team->displayName());
|
m_signEntityCombo->addItem(team->displayName());
|
||||||
const int index = m_signEntityCombo->count() - 1;
|
const int index = m_signEntityCombo->count() - 1;
|
||||||
@@ -294,7 +298,7 @@ void IosSigningSettingsWidget::populateProvisioningProfiles()
|
|||||||
m_signEntityCombo->setItemData(index, profile->details(), Qt::ToolTipRole);
|
m_signEntityCombo->setItemData(index, profile->details(), Qt::ToolTipRole);
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
m_signEntityCombo->addItem(IosBuildConfiguration::tr("None"));
|
m_signEntityCombo->addItem(IosQmakeBuildConfiguration::tr("None"));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
// Maintain previous selection.
|
// Maintain previous selection.
|
||||||
@@ -325,11 +329,12 @@ void IosSigningSettingsWidget::updateInfoText()
|
|||||||
if (identifier.isEmpty()) {
|
if (identifier.isEmpty()) {
|
||||||
// No signing entity selection.
|
// No signing entity selection.
|
||||||
if (configuringTeams)
|
if (configuringTeams)
|
||||||
addMessage(IosBuildConfiguration::tr("Development team is not selected."));
|
addMessage(IosQmakeBuildConfiguration::tr("Development team is not selected."));
|
||||||
else
|
else
|
||||||
addMessage(IosBuildConfiguration::tr("Provisioning profile is not selected."));
|
addMessage(IosQmakeBuildConfiguration::tr("Provisioning profile is not selected."));
|
||||||
|
|
||||||
addMessage(IosBuildConfiguration::tr("Using default development team and provisioning profile."));
|
addMessage(IosQmakeBuildConfiguration::tr(
|
||||||
|
"Using default development team and provisioning profile."));
|
||||||
} else {
|
} else {
|
||||||
if (!configuringTeams) {
|
if (!configuringTeams) {
|
||||||
ProvisioningProfilePtr profile = IosConfigurations::provisioningProfile(identifier);
|
ProvisioningProfilePtr profile = IosConfigurations::provisioningProfile(identifier);
|
||||||
@@ -337,14 +342,17 @@ void IosSigningSettingsWidget::updateInfoText()
|
|||||||
auto team = profile->developmentTeam();
|
auto team = profile->developmentTeam();
|
||||||
if (team) {
|
if (team) {
|
||||||
// Display corresponding team information.
|
// Display corresponding team information.
|
||||||
addMessage(IosBuildConfiguration::tr("Development team: %1 (%2)").arg(team->displayName())
|
addMessage(IosQmakeBuildConfiguration::tr("Development team: %1 (%2)")
|
||||||
|
.arg(team->displayName())
|
||||||
.arg(team->identifier()));
|
.arg(team->identifier()));
|
||||||
addMessage(IosBuildConfiguration::tr("Settings defined here override the QMake environment."));
|
addMessage(IosQmakeBuildConfiguration::tr(
|
||||||
|
"Settings defined here override the QMake environment."));
|
||||||
} else {
|
} else {
|
||||||
qCDebug(iosSettingsLog) << "Development team not found for profile" << profile;
|
qCDebug(iosSettingsLog) << "Development team not found for profile" << profile;
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
addMessage(IosBuildConfiguration::tr("Settings defined here override the QMake environment."));
|
addMessage(IosQmakeBuildConfiguration::tr(
|
||||||
|
"Settings defined here override the QMake environment."));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -360,21 +368,25 @@ void IosSigningSettingsWidget::updateWarningText()
|
|||||||
QString warningText;
|
QString warningText;
|
||||||
bool configuringTeams = m_autoSignCheckbox->isChecked();
|
bool configuringTeams = m_autoSignCheckbox->isChecked();
|
||||||
if (m_signEntityCombo->count() < 2) {
|
if (m_signEntityCombo->count() < 2) {
|
||||||
warningText = IosBuildConfiguration::tr("%1 not configured. Use Xcode and Apple "
|
warningText = IosQmakeBuildConfiguration::tr("%1 not configured. Use Xcode and Apple "
|
||||||
"developer account to configure the "
|
"developer account to configure the "
|
||||||
"provisioning profiles and teams.")
|
"provisioning profiles and teams.")
|
||||||
.arg(configuringTeams ? IosBuildConfiguration::tr("Development teams")
|
.arg(configuringTeams
|
||||||
: IosBuildConfiguration::tr("Provisioning profiles"));
|
? IosQmakeBuildConfiguration::tr("Development teams")
|
||||||
|
: IosQmakeBuildConfiguration::tr("Provisioning profiles"));
|
||||||
} else {
|
} else {
|
||||||
QString identifier = selectedIdentifier();
|
QString identifier = selectedIdentifier();
|
||||||
if (configuringTeams) {
|
if (configuringTeams) {
|
||||||
auto team = IosConfigurations::developmentTeam(identifier);
|
auto team = IosConfigurations::developmentTeam(identifier);
|
||||||
if (team && !team->hasProvisioningProfile())
|
if (team && !team->hasProvisioningProfile())
|
||||||
warningText = IosBuildConfiguration::tr("No provisioning profile found for the selected team.");
|
warningText = IosQmakeBuildConfiguration::tr(
|
||||||
|
"No provisioning profile found for the selected team.");
|
||||||
} else {
|
} else {
|
||||||
auto profile = IosConfigurations::provisioningProfile(identifier);
|
auto profile = IosConfigurations::provisioningProfile(identifier);
|
||||||
if (profile && QDateTime::currentDateTimeUtc() > profile->expirationDate()) {
|
if (profile && QDateTime::currentDateTimeUtc() > profile->expirationDate()) {
|
||||||
warningText = IosBuildConfiguration::tr("Provisioning profile expired. Expiration date: %1")
|
warningText
|
||||||
|
= IosQmakeBuildConfiguration::tr(
|
||||||
|
"Provisioning profile expired. Expiration date: %1")
|
||||||
.arg(QLocale::system().toString(profile->expirationDate().toLocalTime(),
|
.arg(QLocale::system().toString(profile->expirationDate().toLocalTime(),
|
||||||
QLocale::LongFormat));
|
QLocale::LongFormat));
|
||||||
}
|
}
|
||||||
@@ -388,7 +400,7 @@ void IosSigningSettingsWidget::updateWarningText()
|
|||||||
|
|
||||||
// IosBuildConfiguration
|
// IosBuildConfiguration
|
||||||
|
|
||||||
IosBuildConfiguration::IosBuildConfiguration(Target *target, Utils::Id id)
|
IosQmakeBuildConfiguration::IosQmakeBuildConfiguration(Target *target, Utils::Id id)
|
||||||
: QmakeBuildConfiguration(target, id)
|
: QmakeBuildConfiguration(target, id)
|
||||||
{
|
{
|
||||||
m_signingIdentifier = addAspect<StringAspect>();
|
m_signingIdentifier = addAspect<StringAspect>();
|
||||||
@@ -401,14 +413,14 @@ IosBuildConfiguration::IosBuildConfiguration(Target *target, Utils::Id id)
|
|||||||
connect(m_signingIdentifier,
|
connect(m_signingIdentifier,
|
||||||
&BaseAspect::changed,
|
&BaseAspect::changed,
|
||||||
this,
|
this,
|
||||||
&IosBuildConfiguration::updateQmakeCommand);
|
&IosQmakeBuildConfiguration::updateQmakeCommand);
|
||||||
connect(m_autoManagedSigning,
|
connect(m_autoManagedSigning,
|
||||||
&BaseAspect::changed,
|
&BaseAspect::changed,
|
||||||
this,
|
this,
|
||||||
&IosBuildConfiguration::updateQmakeCommand);
|
&IosQmakeBuildConfiguration::updateQmakeCommand);
|
||||||
}
|
}
|
||||||
|
|
||||||
QList<NamedWidget *> IosBuildConfiguration::createSubConfigWidgets()
|
QList<NamedWidget *> IosQmakeBuildConfiguration::createSubConfigWidgets()
|
||||||
{
|
{
|
||||||
auto subConfigWidgets = QmakeBuildConfiguration::createSubConfigWidgets();
|
auto subConfigWidgets = QmakeBuildConfiguration::createSubConfigWidgets();
|
||||||
|
|
||||||
@@ -420,7 +432,7 @@ QList<NamedWidget *> IosBuildConfiguration::createSubConfigWidgets()
|
|||||||
return subConfigWidgets;
|
return subConfigWidgets;
|
||||||
}
|
}
|
||||||
|
|
||||||
bool IosBuildConfiguration::fromMap(const QVariantMap &map)
|
bool IosQmakeBuildConfiguration::fromMap(const QVariantMap &map)
|
||||||
{
|
{
|
||||||
if (!QmakeBuildConfiguration::fromMap(map))
|
if (!QmakeBuildConfiguration::fromMap(map))
|
||||||
return false;
|
return false;
|
||||||
@@ -428,7 +440,22 @@ bool IosBuildConfiguration::fromMap(const QVariantMap &map)
|
|||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
void IosBuildConfiguration::updateQmakeCommand()
|
static QString teamIdForProvisioningProfile(const QString &id)
|
||||||
|
{
|
||||||
|
// Get the team id from provisioning profile
|
||||||
|
ProvisioningProfilePtr profile = IosConfigurations::provisioningProfile(id);
|
||||||
|
QString teamId;
|
||||||
|
if (profile)
|
||||||
|
teamId = profile->developmentTeam()->identifier();
|
||||||
|
else
|
||||||
|
qCDebug(iosLog) << "No provisioing profile found for id:" << id;
|
||||||
|
|
||||||
|
if (teamId.isEmpty())
|
||||||
|
qCDebug(iosLog) << "Development team unavailable for profile:" << profile;
|
||||||
|
return teamId;
|
||||||
|
}
|
||||||
|
|
||||||
|
void IosQmakeBuildConfiguration::updateQmakeCommand()
|
||||||
{
|
{
|
||||||
QMakeStep *qmakeStepInstance = qmakeStep();
|
QMakeStep *qmakeStepInstance = qmakeStep();
|
||||||
const QString forceOverrideArg("-after");
|
const QString forceOverrideArg("-after");
|
||||||
@@ -451,20 +478,10 @@ void IosBuildConfiguration::updateQmakeCommand()
|
|||||||
if (m_autoManagedSigning->value()) {
|
if (m_autoManagedSigning->value()) {
|
||||||
extraArgs << qmakeIosTeamSettings + signingIdentifier;
|
extraArgs << qmakeIosTeamSettings + signingIdentifier;
|
||||||
} else {
|
} else {
|
||||||
// Get the team id from provisioning profile
|
const QString teamId = teamIdForProvisioningProfile(signingIdentifier);
|
||||||
ProvisioningProfilePtr profile =
|
|
||||||
IosConfigurations::provisioningProfile(signingIdentifier);
|
|
||||||
QString teamId;
|
|
||||||
if (profile)
|
|
||||||
teamId = profile->developmentTeam()->identifier();
|
|
||||||
else
|
|
||||||
qCDebug(iosLog) << "No provisioing profile found for id:" << signingIdentifier;
|
|
||||||
|
|
||||||
if (!teamId.isEmpty()) {
|
if (!teamId.isEmpty()) {
|
||||||
extraArgs << qmakeProvisioningProfileSettings + signingIdentifier;
|
extraArgs << qmakeProvisioningProfileSettings + signingIdentifier;
|
||||||
extraArgs << qmakeIosTeamSettings + teamId;
|
extraArgs << qmakeIosTeamSettings + teamId;
|
||||||
} else {
|
|
||||||
qCDebug(iosLog) << "Development team unavailable for profile:" << profile;
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@@ -473,9 +490,80 @@ void IosBuildConfiguration::updateQmakeCommand()
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
IosBuildConfigurationFactory::IosBuildConfigurationFactory()
|
IosQmakeBuildConfigurationFactory::IosQmakeBuildConfigurationFactory()
|
||||||
{
|
{
|
||||||
registerBuildConfiguration<IosBuildConfiguration>(QmakeProjectManager::Constants::QMAKE_BC_ID);
|
registerBuildConfiguration<IosQmakeBuildConfiguration>(
|
||||||
|
QmakeProjectManager::Constants::QMAKE_BC_ID);
|
||||||
|
addSupportedTargetDeviceType(Constants::IOS_DEVICE_TYPE);
|
||||||
|
addSupportedTargetDeviceType(Constants::IOS_SIMULATOR_TYPE);
|
||||||
|
}
|
||||||
|
|
||||||
|
IosCMakeBuildConfiguration::IosCMakeBuildConfiguration(Target *target, Id id)
|
||||||
|
: CMakeBuildConfiguration(target, id)
|
||||||
|
{
|
||||||
|
m_signingIdentifier = addAspect<StringAspect>();
|
||||||
|
m_signingIdentifier->setSettingsKey(signingIdentifierKey);
|
||||||
|
|
||||||
|
m_autoManagedSigning = addAspect<BoolAspect>();
|
||||||
|
m_autoManagedSigning->setDefaultValue(true);
|
||||||
|
m_autoManagedSigning->setSettingsKey(autoManagedSigningKey);
|
||||||
|
|
||||||
|
connect(m_signingIdentifier,
|
||||||
|
&BaseAspect::changed,
|
||||||
|
this,
|
||||||
|
&IosCMakeBuildConfiguration::signingFlagsChanged);
|
||||||
|
connect(m_autoManagedSigning,
|
||||||
|
&BaseAspect::changed,
|
||||||
|
this,
|
||||||
|
&IosCMakeBuildConfiguration::signingFlagsChanged);
|
||||||
|
}
|
||||||
|
|
||||||
|
QList<NamedWidget *> IosCMakeBuildConfiguration::createSubConfigWidgets()
|
||||||
|
{
|
||||||
|
auto subConfigWidgets = CMakeBuildConfiguration::createSubConfigWidgets();
|
||||||
|
|
||||||
|
// Ownership of this widget is with BuildSettingsWidget
|
||||||
|
auto buildSettingsWidget = new IosSigningSettingsWidget(this,
|
||||||
|
m_autoManagedSigning,
|
||||||
|
m_signingIdentifier);
|
||||||
|
subConfigWidgets.prepend(buildSettingsWidget);
|
||||||
|
return subConfigWidgets;
|
||||||
|
}
|
||||||
|
|
||||||
|
bool IosCMakeBuildConfiguration::fromMap(const QVariantMap &map)
|
||||||
|
{
|
||||||
|
if (!CMakeBuildConfiguration::fromMap(map))
|
||||||
|
return false;
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
|
||||||
|
CMakeConfig IosCMakeBuildConfiguration::signingFlags() const
|
||||||
|
{
|
||||||
|
if (DeviceTypeKitAspect::deviceTypeId(kit()) != Constants::IOS_DEVICE_TYPE)
|
||||||
|
return {};
|
||||||
|
const QString signingIdentifier = m_signingIdentifier->value();
|
||||||
|
if (m_autoManagedSigning->value()) {
|
||||||
|
const DevelopmentTeams teams = IosConfigurations::developmentTeams();
|
||||||
|
const QString teamId = signingIdentifier.isEmpty() && !teams.isEmpty()
|
||||||
|
? teams.first()->identifier()
|
||||||
|
: signingIdentifier;
|
||||||
|
CMakeConfigItem provisioningConfig("CMAKE_XCODE_ATTRIBUTE_PROVISIONING_PROFILE_SPECIFIER",
|
||||||
|
"");
|
||||||
|
provisioningConfig.isUnset = true;
|
||||||
|
return {{"CMAKE_XCODE_ATTRIBUTE_DEVELOPMENT_TEAM", teamId.toUtf8()}, provisioningConfig};
|
||||||
|
}
|
||||||
|
const QString teamId = teamIdForProvisioningProfile(signingIdentifier);
|
||||||
|
if (!teamId.isEmpty())
|
||||||
|
return {{"CMAKE_XCODE_ATTRIBUTE_DEVELOPMENT_TEAM", teamId.toUtf8()},
|
||||||
|
{"CMAKE_XCODE_ATTRIBUTE_PROVISIONING_PROFILE_SPECIFIER",
|
||||||
|
signingIdentifier.toUtf8()}};
|
||||||
|
return {};
|
||||||
|
}
|
||||||
|
|
||||||
|
IosCMakeBuildConfigurationFactory::IosCMakeBuildConfigurationFactory()
|
||||||
|
{
|
||||||
|
registerBuildConfiguration<IosCMakeBuildConfiguration>(
|
||||||
|
CMakeProjectManager::Constants::CMAKE_BUILDCONFIGURATION_ID);
|
||||||
addSupportedTargetDeviceType(Constants::IOS_DEVICE_TYPE);
|
addSupportedTargetDeviceType(Constants::IOS_DEVICE_TYPE);
|
||||||
addSupportedTargetDeviceType(Constants::IOS_SIMULATOR_TYPE);
|
addSupportedTargetDeviceType(Constants::IOS_SIMULATOR_TYPE);
|
||||||
}
|
}
|
||||||
|
@@ -25,18 +25,18 @@
|
|||||||
#pragma once
|
#pragma once
|
||||||
|
|
||||||
#include "qmakeprojectmanager/qmakebuildconfiguration.h"
|
#include "qmakeprojectmanager/qmakebuildconfiguration.h"
|
||||||
|
#include <cmakeprojectmanager/cmakebuildconfiguration.h>
|
||||||
#include <utils/aspects.h>
|
#include <utils/aspects.h>
|
||||||
|
|
||||||
namespace Ios {
|
namespace Ios {
|
||||||
namespace Internal {
|
namespace Internal {
|
||||||
|
|
||||||
class IosBuildConfiguration : public QmakeProjectManager::QmakeBuildConfiguration
|
class IosQmakeBuildConfiguration : public QmakeProjectManager::QmakeBuildConfiguration
|
||||||
{
|
{
|
||||||
Q_OBJECT
|
Q_OBJECT
|
||||||
|
|
||||||
public:
|
public:
|
||||||
IosBuildConfiguration(ProjectExplorer::Target *target, Utils::Id id);
|
IosQmakeBuildConfiguration(ProjectExplorer::Target *target, Utils::Id id);
|
||||||
|
|
||||||
private:
|
private:
|
||||||
QList<ProjectExplorer::NamedWidget *> createSubConfigWidgets() override;
|
QList<ProjectExplorer::NamedWidget *> createSubConfigWidgets() override;
|
||||||
@@ -48,10 +48,33 @@ private:
|
|||||||
Utils::BoolAspect *m_autoManagedSigning = nullptr;
|
Utils::BoolAspect *m_autoManagedSigning = nullptr;
|
||||||
};
|
};
|
||||||
|
|
||||||
class IosBuildConfigurationFactory : public QmakeProjectManager::QmakeBuildConfigurationFactory
|
class IosQmakeBuildConfigurationFactory : public QmakeProjectManager::QmakeBuildConfigurationFactory
|
||||||
{
|
{
|
||||||
public:
|
public:
|
||||||
IosBuildConfigurationFactory();
|
IosQmakeBuildConfigurationFactory();
|
||||||
|
};
|
||||||
|
|
||||||
|
class IosCMakeBuildConfiguration : public CMakeProjectManager::CMakeBuildConfiguration
|
||||||
|
{
|
||||||
|
Q_OBJECT
|
||||||
|
|
||||||
|
public:
|
||||||
|
IosCMakeBuildConfiguration(ProjectExplorer::Target *target, Utils::Id id);
|
||||||
|
|
||||||
|
private:
|
||||||
|
QList<ProjectExplorer::NamedWidget *> createSubConfigWidgets() override;
|
||||||
|
bool fromMap(const QVariantMap &map) override;
|
||||||
|
|
||||||
|
CMakeProjectManager::CMakeConfig signingFlags() const final;
|
||||||
|
|
||||||
|
Utils::StringAspect *m_signingIdentifier = nullptr;
|
||||||
|
Utils::BoolAspect *m_autoManagedSigning = nullptr;
|
||||||
|
};
|
||||||
|
|
||||||
|
class IosCMakeBuildConfigurationFactory : public CMakeProjectManager::CMakeBuildConfigurationFactory
|
||||||
|
{
|
||||||
|
public:
|
||||||
|
IosCMakeBuildConfigurationFactory();
|
||||||
};
|
};
|
||||||
|
|
||||||
} // namespace Internal
|
} // namespace Internal
|
||||||
|
@@ -69,7 +69,8 @@ public:
|
|||||||
class IosPluginPrivate
|
class IosPluginPrivate
|
||||||
{
|
{
|
||||||
public:
|
public:
|
||||||
IosBuildConfigurationFactory buildConfigurationFactory;
|
IosQmakeBuildConfigurationFactory qmakeBuildConfigurationFactory;
|
||||||
|
IosCMakeBuildConfigurationFactory cmakeBuildConfigurationFactory;
|
||||||
IosToolChainFactory toolChainFactory;
|
IosToolChainFactory toolChainFactory;
|
||||||
IosRunConfigurationFactory runConfigurationFactory;
|
IosRunConfigurationFactory runConfigurationFactory;
|
||||||
IosSettingsPage settingsPage;
|
IosSettingsPage settingsPage;
|
||||||
|
Reference in New Issue
Block a user