Android: Settings widget code cosmetics

unnecessary indirections, const, namespaces, ...

Change-Id: I7955a81eafdce3fbb14646a57ce8436b00045278
Reviewed-by: Assam Boudjelthia <assam.boudjelthia@qt.io>
This commit is contained in:
hjk
2020-05-20 09:54:50 +02:00
parent 1b3920452a
commit 7419e09d0f
3 changed files with 184 additions and 197 deletions

View File

@@ -321,8 +321,7 @@ const std::map<SdkManagerOutputParser::MarkerTag, const char *> markerTags {
{SdkManagerOutputParser::MarkerTag::ExtrasMarker, "extras"} {SdkManagerOutputParser::MarkerTag::ExtrasMarker, "extras"}
}; };
AndroidSdkManager::AndroidSdkManager(const AndroidConfig &config, QObject *parent): AndroidSdkManager::AndroidSdkManager(const AndroidConfig &config):
QObject(parent),
m_d(new AndroidSdkManagerPrivate(*this, config)) m_d(new AndroidSdkManagerPrivate(*this, config))
{ {
} }

View File

@@ -62,7 +62,7 @@ public:
QString stdError; QString stdError;
}; };
AndroidSdkManager(const AndroidConfig &config, QObject *parent = nullptr); explicit AndroidSdkManager(const AndroidConfig &config);
~AndroidSdkManager() override; ~AndroidSdkManager() override;
SdkPlatformList installedSdkPlatforms(); SdkPlatformList installedSdkPlatforms();
@@ -97,8 +97,8 @@ signals:
void cancelActiveOperations(); void cancelActiveOperations();
private: private:
std::unique_ptr<AndroidSdkManagerPrivate> m_d;
friend class AndroidSdkManagerPrivate; friend class AndroidSdkManagerPrivate;
std::unique_ptr<AndroidSdkManagerPrivate> m_d;
}; };
} // namespace Internal } // namespace Internal

View File

@@ -109,7 +109,7 @@ private:
void apply() final { AndroidConfigurations::setConfig(m_androidConfig); } void apply() final { AndroidConfigurations::setConfig(m_androidConfig); }
void validateJdk(); void validateJdk();
Utils::FilePath findJdkInCommonPaths(); FilePath findJdkInCommonPaths() const;
void validateNdk(); void validateNdk();
void updateNdkList(); void updateNdkList();
void onSdkPathChanged(); void onSdkPathChanged();
@@ -137,22 +137,22 @@ private:
void downloadSdk(); void downloadSdk();
bool allEssentialsInstalled(); bool allEssentialsInstalled();
bool sdkToolsOk() const; bool sdkToolsOk() const;
Utils::FilePath getDefaultSdkPath(); FilePath getDefaultSdkPath() const;
void showEvent(QShowEvent *event) override; void showEvent(QShowEvent *event) final;
void addCustomNdkItem(); void addCustomNdkItem();
void validateOpenSsl(); void validateOpenSsl();
Ui_AndroidSettingsWidget *m_ui; Ui_AndroidSettingsWidget m_ui;
AndroidSdkManagerWidget *m_sdkManagerWidget = nullptr; AndroidSdkManagerWidget *m_sdkManagerWidget = nullptr;
AndroidConfig m_androidConfig; AndroidConfig m_androidConfig{AndroidConfigurations::currentConfig()};
AvdModel m_AVDModel; AvdModel m_AVDModel;
QFutureWatcher<CreateAvdInfo> m_futureWatcher; QFutureWatcher<CreateAvdInfo> m_futureWatcher;
QFutureWatcher<AndroidDeviceInfoList> m_virtualDevicesWatcher; QFutureWatcher<AndroidDeviceInfoList> m_virtualDevicesWatcher;
QString m_lastAddedAvd; QString m_lastAddedAvd;
std::unique_ptr<AndroidAvdManager> m_avdManager; AndroidAvdManager m_avdManager{AndroidConfigurations::currentConfig()};
std::unique_ptr<AndroidSdkManager> m_sdkManager; AndroidSdkManager m_sdkManager{AndroidConfigurations::currentConfig()};
std::unique_ptr<AndroidSdkDownloader> m_sdkDownloader; AndroidSdkDownloader m_sdkDownloader;
bool m_isInitialReloadDone = false; bool m_isInitialReloadDone = false;
}; };
@@ -186,13 +186,13 @@ class SummaryWidget : public QWidget
{ {
class RowData { class RowData {
public: public:
Utils::InfoLabel *m_infoLabel = nullptr; InfoLabel *m_infoLabel = nullptr;
bool m_valid = false; bool m_valid = false;
}; };
public: public:
SummaryWidget(const QMap<int, QString> &validationPoints, const QString &validText, SummaryWidget(const QMap<int, QString> &validationPoints, const QString &validText,
const QString &invalidText, Utils::DetailsWidget *detailsWidget) : const QString &invalidText, DetailsWidget *detailsWidget) :
QWidget(detailsWidget), QWidget(detailsWidget),
m_validText(validText), m_validText(validText),
m_invalidText(invalidText), m_invalidText(invalidText),
@@ -203,7 +203,7 @@ public:
layout->setContentsMargins(12, 12, 12, 12); layout->setContentsMargins(12, 12, 12, 12);
for (auto itr = validationPoints.cbegin(); itr != validationPoints.cend(); ++itr) { for (auto itr = validationPoints.cbegin(); itr != validationPoints.cend(); ++itr) {
RowData data; RowData data;
data.m_infoLabel = new Utils::InfoLabel(itr.value()); data.m_infoLabel = new InfoLabel(itr.value());
layout->addWidget(data.m_infoLabel); layout->addWidget(data.m_infoLabel);
m_validationData[itr.key()] = data; m_validationData[itr.key()] = data;
setPointValid(itr.key(), true); setPointValid(itr.key(), true);
@@ -216,7 +216,7 @@ public:
return; return;
RowData& data = m_validationData[key]; RowData& data = m_validationData[key];
data.m_valid = valid; data.m_valid = valid;
data.m_infoLabel->setType(valid ? Utils::InfoLabel::Ok : Utils::InfoLabel::NotOk); data.m_infoLabel->setType(valid ? InfoLabel::Ok : InfoLabel::NotOk);
updateUi(); updateUi();
} }
@@ -238,15 +238,14 @@ public:
private: private:
void updateUi() { void updateUi() {
bool ok = allRowsOk(); bool ok = allRowsOk();
m_detailsWidget->setIcon(ok ? Utils::Icons::OK.icon() : m_detailsWidget->setIcon(ok ? Icons::OK.icon() : Icons::CRITICAL.icon());
Utils::Icons::CRITICAL.icon());
m_detailsWidget->setSummaryText(ok ? QString("%1 %2").arg(m_validText).arg(m_infoText) m_detailsWidget->setSummaryText(ok ? QString("%1 %2").arg(m_validText).arg(m_infoText)
: m_invalidText); : m_invalidText);
} }
QString m_validText; QString m_validText;
QString m_invalidText; QString m_invalidText;
QString m_infoText; QString m_infoText;
Utils::DetailsWidget *m_detailsWidget = nullptr; DetailsWidget *m_detailsWidget = nullptr;
QMap<int, RowData> m_validationData; QMap<int, RowData> m_validationData;
}; };
@@ -288,25 +287,25 @@ AvdModel::AvdModel()
setHeader({tr("AVD Name"), tr("API"), tr("CPU/ABI"), tr("Device type"), tr("Target"), tr("SD-card size")}); setHeader({tr("AVD Name"), tr("API"), tr("CPU/ABI"), tr("Device type"), tr("Target"), tr("SD-card size")});
} }
Utils::FilePath AndroidSettingsWidget::getDefaultSdkPath() FilePath AndroidSettingsWidget::getDefaultSdkPath() const
{ {
QString sdkFromEnvVar = QString::fromLocal8Bit(getenv("ANDROID_SDK_ROOT")); QString sdkFromEnvVar = QString::fromLocal8Bit(getenv("ANDROID_SDK_ROOT"));
if (!sdkFromEnvVar.isEmpty()) if (!sdkFromEnvVar.isEmpty())
return Utils::FilePath::fromString(sdkFromEnvVar); return FilePath::fromString(sdkFromEnvVar);
// Set default path of SDK as used by Android Studio // Set default path of SDK as used by Android Studio
if (Utils::HostOsInfo::isMacHost()) { if (HostOsInfo::isMacHost()) {
return Utils::FilePath::fromString( return FilePath::fromString(
QStandardPaths::writableLocation(QStandardPaths::AppLocalDataLocation) QStandardPaths::writableLocation(QStandardPaths::AppLocalDataLocation)
+ "/../Android/sdk"); + "/../Android/sdk");
} }
if (Utils::HostOsInfo::isWindowsHost()) { if (HostOsInfo::isWindowsHost()) {
return Utils::FilePath::fromString( return FilePath::fromString(
QStandardPaths::writableLocation(QStandardPaths::HomeLocation) + "/Android/sdk"); QStandardPaths::writableLocation(QStandardPaths::HomeLocation) + "/Android/sdk");
} }
return Utils::FilePath::fromString( return FilePath::fromString(
QStandardPaths::writableLocation(QStandardPaths::HomeLocation) + "/Android/Sdk"); QStandardPaths::writableLocation(QStandardPaths::HomeLocation) + "/Android/Sdk");
} }
@@ -317,7 +316,7 @@ void AndroidSettingsWidget::showEvent(QShowEvent *event)
// Reloading SDK packages (force) is still synchronous. Use zero timer // Reloading SDK packages (force) is still synchronous. Use zero timer
// to let settings dialog open first. // to let settings dialog open first.
QTimer::singleShot(0, std::bind(&AndroidSdkManager::reloadPackages, QTimer::singleShot(0, std::bind(&AndroidSdkManager::reloadPackages,
m_sdkManager.get(), false)); &m_sdkManager, false));
validateOpenSsl(); validateOpenSsl();
m_isInitialReloadDone = true; m_isInitialReloadDone = true;
} }
@@ -325,22 +324,21 @@ void AndroidSettingsWidget::showEvent(QShowEvent *event)
void AndroidSettingsWidget::updateNdkList() void AndroidSettingsWidget::updateNdkList()
{ {
m_ui->ndkListWidget->clear(); m_ui.ndkListWidget->clear();
for (const Ndk *ndk : m_sdkManager->installedNdkPackages()) { for (const Ndk *ndk : m_sdkManager.installedNdkPackages()) {
m_ui->ndkListWidget->addItem(new QListWidgetItem(Utils::Icons::LOCKED.icon(), m_ui.ndkListWidget->addItem(new QListWidgetItem(Icons::LOCKED.icon(),
ndk->installedLocation().toString())); ndk->installedLocation().toString()));
} }
for (const QString &ndk : m_androidConfig.getCustomNdkList()) { for (const QString &ndk : m_androidConfig.getCustomNdkList()) {
if (m_androidConfig.isValidNdk(ndk)) { if (m_androidConfig.isValidNdk(ndk)) {
m_ui->ndkListWidget->addItem( m_ui.ndkListWidget->addItem(new QListWidgetItem(Icons::UNLOCKED.icon(), ndk));
new QListWidgetItem(Utils::Icons::UNLOCKED.icon(), ndk));
} else { } else {
m_androidConfig.removeCustomNdk(ndk); m_androidConfig.removeCustomNdk(ndk);
} }
} }
m_ui->ndkListWidget->setCurrentRow(0); m_ui.ndkListWidget->setCurrentRow(0);
} }
void AndroidSettingsWidget::addCustomNdkItem() void AndroidSettingsWidget::addCustomNdkItem()
@@ -350,9 +348,8 @@ void AndroidSettingsWidget::addCustomNdkItem()
if (m_androidConfig.isValidNdk(ndkPath)) { if (m_androidConfig.isValidNdk(ndkPath)) {
m_androidConfig.addCustomNdk(ndkPath); m_androidConfig.addCustomNdk(ndkPath);
if (m_ui->ndkListWidget->findItems(ndkPath, Qt::MatchExactly).size() == 0) { if (m_ui.ndkListWidget->findItems(ndkPath, Qt::MatchExactly).size() == 0) {
m_ui->ndkListWidget->addItem( m_ui.ndkListWidget->addItem(new QListWidgetItem(Icons::UNLOCKED.icon(), ndkPath));
new QListWidgetItem(Utils::Icons::UNLOCKED.icon(), ndkPath));
} }
} else if (!ndkPath.isEmpty()) { } else if (!ndkPath.isEmpty()) {
QMessageBox::warning( QMessageBox::warning(
@@ -366,30 +363,25 @@ void AndroidSettingsWidget::addCustomNdkItem()
} }
AndroidSettingsWidget::AndroidSettingsWidget() AndroidSettingsWidget::AndroidSettingsWidget()
: m_ui(new Ui_AndroidSettingsWidget),
m_androidConfig(AndroidConfigurations::currentConfig()),
m_avdManager(new AndroidAvdManager(m_androidConfig)),
m_sdkManager(new AndroidSdkManager(m_androidConfig)),
m_sdkDownloader(new AndroidSdkDownloader())
{ {
m_ui->setupUi(this); m_ui.setupUi(this);
m_sdkManagerWidget = new AndroidSdkManagerWidget(m_androidConfig, m_sdkManager.get(), m_sdkManagerWidget = new AndroidSdkManagerWidget(m_androidConfig, &m_sdkManager,
m_ui->sdkManagerTab); m_ui.sdkManagerTab);
auto sdkMangerLayout = new QVBoxLayout(m_ui->sdkManagerTab); auto sdkMangerLayout = new QVBoxLayout(m_ui.sdkManagerTab);
sdkMangerLayout->setContentsMargins(0, 0, 0, 0); sdkMangerLayout->setContentsMargins(0, 0, 0, 0);
sdkMangerLayout->addWidget(m_sdkManagerWidget); sdkMangerLayout->addWidget(m_sdkManagerWidget);
connect(m_sdkManagerWidget, &AndroidSdkManagerWidget::updatingSdk, [this]() { connect(m_sdkManagerWidget, &AndroidSdkManagerWidget::updatingSdk, [this] {
m_ui->SDKLocationPathChooser->setEnabled(false); m_ui.SDKLocationPathChooser->setEnabled(false);
// Disable the tab bar to restrict the user moving away from sdk manager tab untill // Disable the tab bar to restrict the user moving away from sdk manager tab untill
// operations finish. // operations finish.
m_ui->managerTabWidget->tabBar()->setEnabled(false); m_ui.managerTabWidget->tabBar()->setEnabled(false);
}); });
connect(m_sdkManagerWidget, &AndroidSdkManagerWidget::updatingSdkFinished, [this]() { connect(m_sdkManagerWidget, &AndroidSdkManagerWidget::updatingSdkFinished, [this] {
m_ui->SDKLocationPathChooser->setEnabled(true); m_ui.SDKLocationPathChooser->setEnabled(true);
m_ui->managerTabWidget->tabBar()->setEnabled(true); m_ui.managerTabWidget->tabBar()->setEnabled(true);
}); });
connect(m_sdkManagerWidget, &AndroidSdkManagerWidget::licenseWorkflowStarted, [this]() { connect(m_sdkManagerWidget, &AndroidSdkManagerWidget::licenseWorkflowStarted, [this] {
m_ui->scrollArea->ensureWidgetVisible(m_ui->managerTabWidget); m_ui.scrollArea->ensureWidgetVisible(m_ui.managerTabWidget);
}); });
QMap<int, QString> javaValidationPoints; QMap<int, QString> javaValidationPoints;
@@ -397,8 +389,8 @@ AndroidSettingsWidget::AndroidSettingsWidget()
javaValidationPoints[JavaJdkValidRow] = tr("JDK path is a valid JDK root folder."); javaValidationPoints[JavaJdkValidRow] = tr("JDK path is a valid JDK root folder.");
javaValidationPoints[JavaJdkValidVersionRow] = tr("Working JDK version (8) detected."); javaValidationPoints[JavaJdkValidVersionRow] = tr("Working JDK version (8) detected.");
auto javaSummary = new SummaryWidget(javaValidationPoints, tr("Java Settings are OK."), auto javaSummary = new SummaryWidget(javaValidationPoints, tr("Java Settings are OK."),
tr("Java settings have errors."), m_ui->javaDetailsWidget); tr("Java settings have errors."), m_ui.javaDetailsWidget);
m_ui->javaDetailsWidget->setWidget(javaSummary); m_ui.javaDetailsWidget->setWidget(javaSummary);
QMap<int, QString> androidValidationPoints; QMap<int, QString> androidValidationPoints;
androidValidationPoints[SdkPathExistsRow] = tr("Android SDK path exists."); androidValidationPoints[SdkPathExistsRow] = tr("Android SDK path exists.");
@@ -417,8 +409,8 @@ AndroidSettingsWidget::AndroidSettingsWidget()
"spaces."); "spaces.");
auto androidSummary = new SummaryWidget(androidValidationPoints, tr("Android settings are OK."), auto androidSummary = new SummaryWidget(androidValidationPoints, tr("Android settings are OK."),
tr("Android settings have errors."), tr("Android settings have errors."),
m_ui->androidDetailsWidget); m_ui.androidDetailsWidget);
m_ui->androidDetailsWidget->setWidget(androidSummary); m_ui.androidDetailsWidget->setWidget(androidSummary);
QMap<int, QString> openSslValidationPoints; QMap<int, QString> openSslValidationPoints;
openSslValidationPoints[OpenSslPathExistsRow] = tr("OpenSSL path exists."); openSslValidationPoints[OpenSslPathExistsRow] = tr("OpenSSL path exists.");
@@ -429,44 +421,44 @@ AndroidSettingsWidget::AndroidSettingsWidget()
auto openSslSummary = new SummaryWidget(openSslValidationPoints, auto openSslSummary = new SummaryWidget(openSslValidationPoints,
tr("OpenSSL Settings are OK."), tr("OpenSSL Settings are OK."),
tr("OpenSSL settings have errors."), tr("OpenSSL settings have errors."),
m_ui->openSslDetailsWidget); m_ui.openSslDetailsWidget);
m_ui->openSslDetailsWidget->setWidget(openSslSummary); m_ui.openSslDetailsWidget->setWidget(openSslSummary);
connect(m_ui->OpenJDKLocationPathChooser, &Utils::PathChooser::rawPathChanged, connect(m_ui.OpenJDKLocationPathChooser, &PathChooser::rawPathChanged,
this, &AndroidSettingsWidget::validateJdk); this, &AndroidSettingsWidget::validateJdk);
Utils::FilePath currentJdkPath = m_androidConfig.openJDKLocation(); FilePath currentJdkPath = m_androidConfig.openJDKLocation();
if (currentJdkPath.isEmpty()) if (currentJdkPath.isEmpty())
currentJdkPath = findJdkInCommonPaths(); currentJdkPath = findJdkInCommonPaths();
m_ui->OpenJDKLocationPathChooser->setFilePath(currentJdkPath); m_ui.OpenJDKLocationPathChooser->setFilePath(currentJdkPath);
m_ui->OpenJDKLocationPathChooser->setPromptDialogTitle(tr("Select JDK Path")); m_ui.OpenJDKLocationPathChooser->setPromptDialogTitle(tr("Select JDK Path"));
Utils::FilePath currentSDKPath = m_androidConfig.sdkLocation(); FilePath currentSDKPath = m_androidConfig.sdkLocation();
if (currentSDKPath.isEmpty()) if (currentSDKPath.isEmpty())
currentSDKPath = getDefaultSdkPath(); currentSDKPath = getDefaultSdkPath();
m_ui->SDKLocationPathChooser->setFilePath(currentSDKPath); m_ui.SDKLocationPathChooser->setFilePath(currentSDKPath);
m_ui->SDKLocationPathChooser->setPromptDialogTitle(tr("Select Android SDK folder")); m_ui.SDKLocationPathChooser->setPromptDialogTitle(tr("Select Android SDK folder"));
m_ui->openSslPathChooser->setPromptDialogTitle(tr("Select OpenSSL Include Project File")); m_ui.openSslPathChooser->setPromptDialogTitle(tr("Select OpenSSL Include Project File"));
Utils::FilePath currentOpenSslPath = m_androidConfig.openSslLocation(); FilePath currentOpenSslPath = m_androidConfig.openSslLocation();
if (currentOpenSslPath.isEmpty()) if (currentOpenSslPath.isEmpty())
currentOpenSslPath = currentSDKPath.pathAppended("android_openssl"); currentOpenSslPath = currentSDKPath.pathAppended("android_openssl");
m_ui->openSslPathChooser->setFilePath(currentOpenSslPath); m_ui.openSslPathChooser->setFilePath(currentOpenSslPath);
m_ui->DataPartitionSizeSpinBox->setValue(m_androidConfig.partitionSize()); m_ui.DataPartitionSizeSpinBox->setValue(m_androidConfig.partitionSize());
m_ui->CreateKitCheckBox->setChecked(m_androidConfig.automaticKitCreation()); m_ui.CreateKitCheckBox->setChecked(m_androidConfig.automaticKitCreation());
m_ui->AVDTableView->setModel(&m_AVDModel); m_ui.AVDTableView->setModel(&m_AVDModel);
m_ui->AVDTableView->horizontalHeader()->setSectionResizeMode(QHeaderView::Stretch); m_ui.AVDTableView->horizontalHeader()->setSectionResizeMode(QHeaderView::Stretch);
m_ui->AVDTableView->horizontalHeader()->setSectionResizeMode(1, QHeaderView::ResizeToContents); m_ui.AVDTableView->horizontalHeader()->setSectionResizeMode(1, QHeaderView::ResizeToContents);
m_ui->downloadOpenJDKToolButton->setVisible(!Utils::HostOsInfo::isLinuxHost()); m_ui.downloadOpenJDKToolButton->setVisible(!HostOsInfo::isLinuxHost());
const QIcon downloadIcon = Utils::Icons::DOWNLOAD.icon(); const QIcon downloadIcon = Icons::DOWNLOAD.icon();
m_ui->downloadSDKToolButton->setIcon(downloadIcon); m_ui.downloadSDKToolButton->setIcon(downloadIcon);
m_ui->downloadNDKToolButton->setIcon(downloadIcon); m_ui.downloadNDKToolButton->setIcon(downloadIcon);
m_ui->downloadOpenJDKToolButton->setIcon(downloadIcon); m_ui.downloadOpenJDKToolButton->setIcon(downloadIcon);
m_ui->downloadOpenSSLPrebuiltLibs->setIcon(downloadIcon); m_ui.downloadOpenSSLPrebuiltLibs->setIcon(downloadIcon);
m_ui->sdkToolsAutoDownloadButton->setToolTip(tr( m_ui.sdkToolsAutoDownloadButton->setToolTip(tr(
"Automatically download Android SDK Tools to selected location.\n\n" "Automatically download Android SDK Tools to selected location.\n\n"
"If the selected path contains no valid SDK Tools, the SDK Tools package " "If the selected path contains no valid SDK Tools, the SDK Tools package "
"is downloaded from %1, and extracted to the selected path.\n" "is downloaded from %1, and extracted to the selected path.\n"
@@ -474,67 +466,68 @@ AndroidSettingsWidget::AndroidSettingsWidget()
"any essential packages required for Qt to build for Android.") "any essential packages required for Qt to build for Android.")
.arg(m_androidConfig.sdkToolsUrl().toString())); .arg(m_androidConfig.sdkToolsUrl().toString()));
connect(m_ui->SDKLocationPathChooser, &Utils::PathChooser::rawPathChanged, connect(m_ui.SDKLocationPathChooser, &PathChooser::rawPathChanged,
this, &AndroidSettingsWidget::onSdkPathChanged); this, &AndroidSettingsWidget::onSdkPathChanged);
connect(m_ui->ndkListWidget, &QListWidget::currentTextChanged, [this](const QString &ndk) { connect(m_ui.ndkListWidget, &QListWidget::currentTextChanged, [this](const QString &ndk) {
validateNdk(); validateNdk();
m_ui->removeCustomNdkButton->setEnabled(m_androidConfig.getCustomNdkList().contains(ndk)); m_ui.removeCustomNdkButton->setEnabled(m_androidConfig.getCustomNdkList().contains(ndk));
}); });
connect(m_ui->addCustomNdkButton, &QPushButton::clicked, this, connect(m_ui.addCustomNdkButton, &QPushButton::clicked, this,
&AndroidSettingsWidget::addCustomNdkItem); &AndroidSettingsWidget::addCustomNdkItem);
connect(m_ui->removeCustomNdkButton, &QPushButton::clicked, this, [this]() { connect(m_ui.removeCustomNdkButton, &QPushButton::clicked, this, [this] {
m_androidConfig.removeCustomNdk(m_ui->ndkListWidget->currentItem()->text()); m_androidConfig.removeCustomNdk(m_ui.ndkListWidget->currentItem()->text());
m_ui->ndkListWidget->takeItem(m_ui->ndkListWidget->currentRow()); m_ui.ndkListWidget->takeItem(m_ui.ndkListWidget->currentRow());
}); });
connect(m_ui->openSslPathChooser, &Utils::PathChooser::rawPathChanged, this, connect(m_ui.openSslPathChooser, &PathChooser::rawPathChanged,
&AndroidSettingsWidget::validateOpenSsl); this, &AndroidSettingsWidget::validateOpenSsl);
connect(&m_virtualDevicesWatcher, &QFutureWatcherBase::finished, connect(&m_virtualDevicesWatcher, &QFutureWatcherBase::finished,
this, &AndroidSettingsWidget::updateAvds); this, &AndroidSettingsWidget::updateAvds);
connect(m_ui->AVDRefreshPushButton, &QAbstractButton::clicked, connect(m_ui.AVDRefreshPushButton, &QAbstractButton::clicked,
this, &AndroidSettingsWidget::startUpdateAvd); this, &AndroidSettingsWidget::startUpdateAvd);
connect(&m_futureWatcher, &QFutureWatcherBase::finished, this, &AndroidSettingsWidget::avdAdded); connect(&m_futureWatcher, &QFutureWatcherBase::finished,
connect(m_ui->AVDAddPushButton, &QAbstractButton::clicked, this, &AndroidSettingsWidget::avdAdded);
connect(m_ui.AVDAddPushButton, &QAbstractButton::clicked,
this, &AndroidSettingsWidget::addAVD); this, &AndroidSettingsWidget::addAVD);
connect(m_ui->AVDRemovePushButton, &QAbstractButton::clicked, connect(m_ui.AVDRemovePushButton, &QAbstractButton::clicked,
this, &AndroidSettingsWidget::removeAVD); this, &AndroidSettingsWidget::removeAVD);
connect(m_ui->AVDStartPushButton, &QAbstractButton::clicked, connect(m_ui.AVDStartPushButton, &QAbstractButton::clicked,
this, &AndroidSettingsWidget::startAVD); this, &AndroidSettingsWidget::startAVD);
connect(m_ui->AVDTableView, &QAbstractItemView::activated, connect(m_ui.AVDTableView, &QAbstractItemView::activated,
this, &AndroidSettingsWidget::avdActivated); this, &AndroidSettingsWidget::avdActivated);
connect(m_ui->AVDTableView, &QAbstractItemView::clicked, connect(m_ui.AVDTableView, &QAbstractItemView::clicked,
this, &AndroidSettingsWidget::avdActivated); this, &AndroidSettingsWidget::avdActivated);
connect(m_ui->DataPartitionSizeSpinBox, &QAbstractSpinBox::editingFinished, connect(m_ui.DataPartitionSizeSpinBox, &QAbstractSpinBox::editingFinished,
this, &AndroidSettingsWidget::dataPartitionSizeEditingFinished); this, &AndroidSettingsWidget::dataPartitionSizeEditingFinished);
connect(m_ui->nativeAvdManagerButton, &QAbstractButton::clicked, connect(m_ui.nativeAvdManagerButton, &QAbstractButton::clicked,
this, &AndroidSettingsWidget::manageAVD); this, &AndroidSettingsWidget::manageAVD);
connect(m_ui->CreateKitCheckBox, &QAbstractButton::toggled, connect(m_ui.CreateKitCheckBox, &QAbstractButton::toggled,
this, &AndroidSettingsWidget::createKitToggled); this, &AndroidSettingsWidget::createKitToggled);
connect(m_ui->downloadNDKToolButton, &QAbstractButton::clicked, connect(m_ui.downloadNDKToolButton, &QAbstractButton::clicked,
this, &AndroidSettingsWidget::openNDKDownloadUrl); this, &AndroidSettingsWidget::openNDKDownloadUrl);
connect(m_ui->downloadSDKToolButton, &QAbstractButton::clicked, connect(m_ui.downloadSDKToolButton, &QAbstractButton::clicked,
this, &AndroidSettingsWidget::openSDKDownloadUrl); this, &AndroidSettingsWidget::openSDKDownloadUrl);
connect(m_ui->downloadOpenSSLPrebuiltLibs, &QAbstractButton::clicked, connect(m_ui.downloadOpenSSLPrebuiltLibs, &QAbstractButton::clicked,
this, &AndroidSettingsWidget::downloadOpenSslRepo); this, &AndroidSettingsWidget::downloadOpenSslRepo);
connect(m_ui->downloadOpenJDKToolButton, &QAbstractButton::clicked, connect(m_ui.downloadOpenJDKToolButton, &QAbstractButton::clicked,
this, &AndroidSettingsWidget::openOpenJDKDownloadUrl); this, &AndroidSettingsWidget::openOpenJDKDownloadUrl);
// Validate SDK again after any change in SDK packages. // Validate SDK again after any change in SDK packages.
connect(m_sdkManager.get(), &AndroidSdkManager::packageReloadFinished, connect(&m_sdkManager, &AndroidSdkManager::packageReloadFinished,
this, &AndroidSettingsWidget::validateSdk); this, &AndroidSettingsWidget::validateSdk);
connect(m_ui->sdkToolsAutoDownloadButton, &QAbstractButton::clicked, connect(m_ui.sdkToolsAutoDownloadButton, &QAbstractButton::clicked,
this, &AndroidSettingsWidget::downloadSdk); this, &AndroidSettingsWidget::downloadSdk);
connect(m_sdkDownloader.get(), &AndroidSdkDownloader::sdkDownloaderError, this, [this](const QString &error) { connect(&m_sdkDownloader, &AndroidSdkDownloader::sdkDownloaderError, this, [this](const QString &error) {
QMessageBox::warning(this, AndroidSdkDownloader::dialogTitle(), error); QMessageBox::warning(this, AndroidSdkDownloader::dialogTitle(), error);
}); });
connect(m_sdkDownloader.get(), &AndroidSdkDownloader::sdkExtracted, this, [this]() { connect(&m_sdkDownloader, &AndroidSdkDownloader::sdkExtracted, this, [this] {
m_sdkManager->reloadPackages(true); m_sdkManager.reloadPackages(true);
updateUI(); updateUI();
apply(); apply();
QMetaObject::Connection *const openSslOneShot = new QMetaObject::Connection; QMetaObject::Connection *const openSslOneShot = new QMetaObject::Connection;
*openSslOneShot = connect(m_sdkManager.get(), &AndroidSdkManager::packageReloadFinished, *openSslOneShot = connect(&m_sdkManager, &AndroidSdkManager::packageReloadFinished,
this, [this, openSslOneShot]() { this, [this, openSslOneShot] {
QObject::disconnect(*openSslOneShot); QObject::disconnect(*openSslOneShot);
downloadOpenSslRepo(true); downloadOpenSslRepo(true);
delete openSslOneShot; delete openSslOneShot;
@@ -546,36 +539,35 @@ AndroidSettingsWidget::~AndroidSettingsWidget()
{ {
// Deleting m_sdkManagerWidget will cancel all ongoing and pending sdkmanager operations. // Deleting m_sdkManagerWidget will cancel all ongoing and pending sdkmanager operations.
delete m_sdkManagerWidget; delete m_sdkManagerWidget;
delete m_ui;
m_futureWatcher.waitForFinished(); m_futureWatcher.waitForFinished();
} }
void AndroidSettingsWidget::disableAvdControls() void AndroidSettingsWidget::disableAvdControls()
{ {
m_ui->AVDAddPushButton->setEnabled(false); m_ui.AVDAddPushButton->setEnabled(false);
m_ui->AVDTableView->setEnabled(false); m_ui.AVDTableView->setEnabled(false);
m_ui->AVDRemovePushButton->setEnabled(false); m_ui.AVDRemovePushButton->setEnabled(false);
m_ui->AVDStartPushButton->setEnabled(false); m_ui.AVDStartPushButton->setEnabled(false);
} }
void AndroidSettingsWidget::enableAvdControls() void AndroidSettingsWidget::enableAvdControls()
{ {
m_ui->AVDTableView->setEnabled(true); m_ui.AVDTableView->setEnabled(true);
m_ui->AVDAddPushButton->setEnabled(true); m_ui.AVDAddPushButton->setEnabled(true);
avdActivated(m_ui->AVDTableView->currentIndex()); avdActivated(m_ui.AVDTableView->currentIndex());
} }
void AndroidSettingsWidget::startUpdateAvd() void AndroidSettingsWidget::startUpdateAvd()
{ {
disableAvdControls(); disableAvdControls();
m_virtualDevicesWatcher.setFuture(m_avdManager->avdList()); m_virtualDevicesWatcher.setFuture(m_avdManager.avdList());
} }
void AndroidSettingsWidget::updateAvds() void AndroidSettingsWidget::updateAvds()
{ {
m_AVDModel.setAllData(m_virtualDevicesWatcher.result()); m_AVDModel.setAllData(m_virtualDevicesWatcher.result());
if (!m_lastAddedAvd.isEmpty()) { if (!m_lastAddedAvd.isEmpty()) {
m_ui->AVDTableView->setCurrentIndex(m_AVDModel.indexForAvdName(m_lastAddedAvd)); m_ui.AVDTableView->setCurrentIndex(m_AVDModel.indexForAvdName(m_lastAddedAvd));
m_lastAddedAvd.clear(); m_lastAddedAvd.clear();
} }
enableAvdControls(); enableAvdControls();
@@ -583,21 +575,21 @@ void AndroidSettingsWidget::updateAvds()
void AndroidSettingsWidget::validateJdk() void AndroidSettingsWidget::validateJdk()
{ {
m_androidConfig.setOpenJDKLocation(m_ui->OpenJDKLocationPathChooser->filePath()); m_androidConfig.setOpenJDKLocation(m_ui.OpenJDKLocationPathChooser->filePath());
bool jdkPathExists = m_androidConfig.openJDKLocation().exists(); bool jdkPathExists = m_androidConfig.openJDKLocation().exists();
auto summaryWidget = static_cast<SummaryWidget *>(m_ui->javaDetailsWidget->widget()); auto summaryWidget = static_cast<SummaryWidget *>(m_ui.javaDetailsWidget->widget());
summaryWidget->setPointValid(JavaPathExistsRow, jdkPathExists); summaryWidget->setPointValid(JavaPathExistsRow, jdkPathExists);
const Utils::FilePath bin = m_androidConfig.openJDKLocation().pathAppended("bin/javac" QTC_HOST_EXE_SUFFIX); const FilePath bin = m_androidConfig.openJDKLocation().pathAppended("bin/javac" QTC_HOST_EXE_SUFFIX);
summaryWidget->setPointValid(JavaJdkValidRow, jdkPathExists && bin.exists()); summaryWidget->setPointValid(JavaJdkValidRow, jdkPathExists && bin.exists());
bool jdkVersionCorrect = false; bool jdkVersionCorrect = false;
Utils::SynchronousProcess javacProcess; SynchronousProcess javacProcess;
const int timeoutS = 5; const int timeoutS = 5;
javacProcess.setTimeoutS(timeoutS); javacProcess.setTimeoutS(timeoutS);
const Utils::CommandLine cmd(bin, {"-version"}); const CommandLine cmd(bin, {"-version"});
Utils::SynchronousProcessResponse response = javacProcess.runBlocking(cmd); SynchronousProcessResponse response = javacProcess.runBlocking(cmd);
if (response.result == Utils::SynchronousProcessResponse::Finished) { if (response.result == SynchronousProcessResponse::Finished) {
QString output = response.stdOut(); // JDK 14 uses stdOut for this output. QString output = response.stdOut(); // JDK 14 uses stdOut for this output.
if (output.isEmpty()) if (output.isEmpty())
output = response.stdErr(); // JDK 8 uses stdErr for this output. output = response.stdErr(); // JDK 8 uses stdErr for this output.
@@ -614,9 +606,9 @@ void AndroidSettingsWidget::validateJdk()
void AndroidSettingsWidget::validateOpenSsl() void AndroidSettingsWidget::validateOpenSsl()
{ {
m_androidConfig.setOpenSslLocation(m_ui->openSslPathChooser->filePath()); m_androidConfig.setOpenSslLocation(m_ui.openSslPathChooser->filePath());
auto summaryWidget = static_cast<SummaryWidget *>(m_ui->openSslDetailsWidget->widget()); auto summaryWidget = static_cast<SummaryWidget *>(m_ui.openSslDetailsWidget->widget());
summaryWidget->setPointValid(OpenSslPathExistsRow, m_androidConfig.openSslLocation().exists()); summaryWidget->setPointValid(OpenSslPathExistsRow, m_androidConfig.openSslLocation().exists());
const bool priFileExists = m_androidConfig.openSslLocation().pathAppended("openssl.pri").exists(); const bool priFileExists = m_androidConfig.openSslLocation().pathAppended("openssl.pri").exists();
@@ -627,22 +619,22 @@ void AndroidSettingsWidget::validateOpenSsl()
updateUI(); updateUI();
} }
Utils::FilePath AndroidSettingsWidget::findJdkInCommonPaths() FilePath AndroidSettingsWidget::findJdkInCommonPaths() const
{ {
QString jdkFromEnvVar = QString::fromLocal8Bit(getenv("JAVA_HOME")); QString jdkFromEnvVar = QString::fromLocal8Bit(getenv("JAVA_HOME"));
if (!jdkFromEnvVar.isEmpty()) if (!jdkFromEnvVar.isEmpty())
return Utils::FilePath::fromUserInput(jdkFromEnvVar); return FilePath::fromUserInput(jdkFromEnvVar);
if (Utils::HostOsInfo::isWindowsHost()) { if (HostOsInfo::isWindowsHost()) {
QString jdkRegisteryPath = "HKEY_LOCAL_MACHINE\\SOFTWARE\\JavaSoft\\JDK\\"; QString jdkRegisteryPath = "HKEY_LOCAL_MACHINE\\SOFTWARE\\JavaSoft\\JDK\\";
QSettings jdkSettings(jdkRegisteryPath, QSettings::NativeFormat); QSettings jdkSettings(jdkRegisteryPath, QSettings::NativeFormat);
QStringList jdkVersions = jdkSettings.childGroups(); QStringList jdkVersions = jdkSettings.childGroups();
Utils::FilePath jdkHome; FilePath jdkHome;
for (const QString &version : jdkVersions) { for (const QString &version : jdkVersions) {
jdkSettings.beginGroup(version); jdkSettings.beginGroup(version);
jdkHome = Utils::FilePath::fromUserInput(jdkSettings.value("JavaHome").toString()); jdkHome = FilePath::fromUserInput(jdkSettings.value("JavaHome").toString());
jdkSettings.endGroup(); jdkSettings.endGroup();
if (version.startsWith("1.8")) if (version.startsWith("1.8"))
return jdkHome; return jdkHome;
@@ -656,7 +648,7 @@ Utils::FilePath AndroidSettingsWidget::findJdkInCommonPaths()
QString cmd; QString cmd;
QStringList args; QStringList args;
if (Utils::HostOsInfo::isMacHost()) { if (HostOsInfo::isMacHost()) {
cmd = "sh"; cmd = "sh";
args << "-c" << "/usr/libexec/java_home"; args << "-c" << "/usr/libexec/java_home";
} else { } else {
@@ -668,23 +660,23 @@ Utils::FilePath AndroidSettingsWidget::findJdkInCommonPaths()
findJdkPathProc.waitForFinished(); findJdkPathProc.waitForFinished();
QByteArray jdkPath = findJdkPathProc.readAllStandardOutput().trimmed(); QByteArray jdkPath = findJdkPathProc.readAllStandardOutput().trimmed();
if (Utils::HostOsInfo::isMacHost()) if (HostOsInfo::isMacHost())
return Utils::FilePath::fromUtf8(jdkPath); return FilePath::fromUtf8(jdkPath);
else else
return Utils::FilePath::fromUtf8(jdkPath.replace("jre/bin/java", "")); return FilePath::fromUtf8(jdkPath.replace("jre/bin/java", ""));
} }
void AndroidSettingsWidget::validateNdk() void AndroidSettingsWidget::validateNdk()
{ {
const QListWidgetItem *currentItem = m_ui->ndkListWidget->currentItem(); const QListWidgetItem *currentItem = m_ui.ndkListWidget->currentItem();
Utils::FilePath ndkPath = Utils::FilePath::fromString(currentItem ? currentItem->text() : ""); FilePath ndkPath = FilePath::fromString(currentItem ? currentItem->text() : "");
auto summaryWidget = static_cast<SummaryWidget *>(m_ui->androidDetailsWidget->widget()); auto summaryWidget = static_cast<SummaryWidget *>(m_ui.androidDetailsWidget->widget());
summaryWidget->setPointValid(NdkPathExistsRow, ndkPath.exists()); summaryWidget->setPointValid(NdkPathExistsRow, ndkPath.exists());
const Utils::FilePath ndkPlatformsDir = ndkPath.pathAppended("platforms"); const FilePath ndkPlatformsDir = ndkPath.pathAppended("platforms");
const Utils::FilePath ndkToolChainsDir = ndkPath.pathAppended("toolchains"); const FilePath ndkToolChainsDir = ndkPath.pathAppended("toolchains");
const Utils::FilePath ndkSourcesDir = ndkPath.pathAppended("sources/cxx-stl"); const FilePath ndkSourcesDir = ndkPath.pathAppended("sources/cxx-stl");
summaryWidget->setPointValid(NdkDirStructureRow, summaryWidget->setPointValid(NdkDirStructureRow,
ndkPlatformsDir.exists() ndkPlatformsDir.exists()
&& ndkToolChainsDir.exists() && ndkToolChainsDir.exists()
@@ -697,22 +689,22 @@ void AndroidSettingsWidget::validateNdk()
void AndroidSettingsWidget::onSdkPathChanged() void AndroidSettingsWidget::onSdkPathChanged()
{ {
auto sdkPath = Utils::FilePath::fromUserInput(m_ui->SDKLocationPathChooser->rawPath()); auto sdkPath = FilePath::fromUserInput(m_ui.SDKLocationPathChooser->rawPath());
m_androidConfig.setSdkLocation(sdkPath); m_androidConfig.setSdkLocation(sdkPath);
Utils::FilePath currentOpenSslPath = m_androidConfig.openSslLocation(); FilePath currentOpenSslPath = m_androidConfig.openSslLocation();
if (currentOpenSslPath.isEmpty() || !currentOpenSslPath.exists()) if (currentOpenSslPath.isEmpty() || !currentOpenSslPath.exists())
currentOpenSslPath = sdkPath.pathAppended("android_openssl"); currentOpenSslPath = sdkPath.pathAppended("android_openssl");
m_ui->openSslPathChooser->setFileName(currentOpenSslPath); m_ui.openSslPathChooser->setFileName(currentOpenSslPath);
// Package reload will trigger validateSdk. // Package reload will trigger validateSdk.
m_sdkManager->reloadPackages(); m_sdkManager.reloadPackages();
} }
void AndroidSettingsWidget::validateSdk() void AndroidSettingsWidget::validateSdk()
{ {
auto sdkPath = Utils::FilePath::fromUserInput(m_ui->SDKLocationPathChooser->rawPath()); auto sdkPath = FilePath::fromUserInput(m_ui.SDKLocationPathChooser->rawPath());
m_androidConfig.setSdkLocation(sdkPath); m_androidConfig.setSdkLocation(sdkPath);
auto summaryWidget = static_cast<SummaryWidget *>(m_ui->androidDetailsWidget->widget()); auto summaryWidget = static_cast<SummaryWidget *>(m_ui.androidDetailsWidget->widget());
summaryWidget->setPointValid(SdkPathExistsRow, m_androidConfig.sdkLocation().exists()); summaryWidget->setPointValid(SdkPathExistsRow, m_androidConfig.sdkLocation().exists());
summaryWidget->setPointValid(SdkPathWritableRow, m_androidConfig.sdkLocation().isWritablePath()); summaryWidget->setPointValid(SdkPathWritableRow, m_androidConfig.sdkLocation().isWritablePath());
summaryWidget->setPointValid(SdkToolsInstalledRow, summaryWidget->setPointValid(SdkToolsInstalledRow,
@@ -721,11 +713,11 @@ void AndroidSettingsWidget::validateSdk()
m_androidConfig.adbToolPath().exists()); m_androidConfig.adbToolPath().exists());
summaryWidget->setPointValid(BuildToolsInstalledRow, summaryWidget->setPointValid(BuildToolsInstalledRow,
!m_androidConfig.buildToolsVersion().isNull()); !m_androidConfig.buildToolsVersion().isNull());
summaryWidget->setPointValid(SdkManagerSuccessfulRow, m_sdkManager->packageListingSuccessful()); summaryWidget->setPointValid(SdkManagerSuccessfulRow, m_sdkManager.packageListingSuccessful());
// installedSdkPlatforms should not trigger a package reload as validate SDK is only called // installedSdkPlatforms should not trigger a package reload as validate SDK is only called
// after AndroidSdkManager::packageReloadFinished. // after AndroidSdkManager::packageReloadFinished.
summaryWidget->setPointValid(PlatformSdkInstalledRow, summaryWidget->setPointValid(PlatformSdkInstalledRow,
!m_sdkManager->installedSdkPlatforms().isEmpty()); !m_sdkManager.installedSdkPlatforms().isEmpty());
summaryWidget->setPointValid(AllEssentialsInstalledRow, allEssentialsInstalled()); summaryWidget->setPointValid(AllEssentialsInstalledRow, allEssentialsInstalled());
updateUI(); updateUI();
@@ -743,7 +735,7 @@ void AndroidSettingsWidget::validateSdk()
auto userInput = QMessageBox::information(this, tr("Missing Android SDK packages"), auto userInput = QMessageBox::information(this, tr("Missing Android SDK packages"),
message, QMessageBox::Yes | QMessageBox::No); message, QMessageBox::Yes | QMessageBox::No);
if (userInput == QMessageBox::Yes) { if (userInput == QMessageBox::Yes) {
m_ui->managerTabWidget->setCurrentWidget(m_ui->sdkManagerTab); m_ui.managerTabWidget->setCurrentWidget(m_ui.sdkManagerTab);
m_sdkManagerWidget->installEssentials(); m_sdkManagerWidget->installEssentials();
} }
} }
@@ -770,10 +762,10 @@ void AndroidSettingsWidget::openOpenJDKDownloadUrl()
void AndroidSettingsWidget::downloadOpenSslRepo(const bool silent) void AndroidSettingsWidget::downloadOpenSslRepo(const bool silent)
{ {
const Utils::FilePath openSslPath = m_ui->openSslPathChooser->filePath(); const FilePath openSslPath = m_ui.openSslPathChooser->filePath();
const QString openSslCloneTitle(tr("OpenSSL Cloning")); const QString openSslCloneTitle(tr("OpenSSL Cloning"));
auto openSslSummaryWidget = static_cast<SummaryWidget *>(m_ui->openSslDetailsWidget->widget()); auto openSslSummaryWidget = static_cast<SummaryWidget *>(m_ui.openSslDetailsWidget->widget());
if (openSslSummaryWidget->allRowsOk()) { if (openSslSummaryWidget->allRowsOk()) {
if (!silent) { if (!silent) {
QMessageBox::information(this, openSslCloneTitle, QMessageBox::information(this, openSslCloneTitle,
@@ -783,13 +775,11 @@ void AndroidSettingsWidget::downloadOpenSslRepo(const bool silent)
} }
const QString openSslRepo("https://github.com/KDAB/android_openssl.git"); const QString openSslRepo("https://github.com/KDAB/android_openssl.git");
Utils::QtcProcess *gitCloner = new Utils::QtcProcess(this); QtcProcess *gitCloner = new QtcProcess(this);
Utils::CommandLine gitCloneCommand("git", CommandLine gitCloneCommand("git", {"clone", "--depth=1", openSslRepo, openSslPath.toString()});
{"clone", "--depth=1", openSslRepo, openSslPath.toString()});
gitCloner->setCommand(gitCloneCommand); gitCloner->setCommand(gitCloneCommand);
qCDebug(androidsettingswidget) << "Cloning OpenSSL repo: " << qCDebug(androidsettingswidget) << "Cloning OpenSSL repo: " << gitCloneCommand.toUserOutput();
gitCloneCommand.toUserOutput();
QDir openSslDir(openSslPath.toString()); QDir openSslDir(openSslPath.toString());
if (openSslDir.exists()) { if (openSslDir.exists()) {
@@ -811,20 +801,18 @@ void AndroidSettingsWidget::downloadOpenSslRepo(const bool silent)
openSslProgressDialog->setWindowTitle(openSslCloneTitle); openSslProgressDialog->setWindowTitle(openSslCloneTitle);
openSslProgressDialog->setFixedSize(openSslProgressDialog->sizeHint()); openSslProgressDialog->setFixedSize(openSslProgressDialog->sizeHint());
connect(openSslProgressDialog, &QProgressDialog::canceled, this, [gitCloner]() { connect(openSslProgressDialog, &QProgressDialog::canceled, gitCloner, &QtcProcess::kill);
gitCloner->kill();
});
gitCloner->start(); gitCloner->start();
openSslProgressDialog->show(); openSslProgressDialog->show();
connect(gitCloner, QOverload<int, Utils::QtcProcess::ExitStatus>::of(&Utils::QtcProcess::finished), connect(gitCloner, QOverload<int, QtcProcess::ExitStatus>::of(&QtcProcess::finished),
[=](int exitCode, QProcess::ExitStatus exitStatus) { [=](int exitCode, QProcess::ExitStatus exitStatus) {
openSslProgressDialog->close(); openSslProgressDialog->close();
validateOpenSsl(); validateOpenSsl();
if (!openSslProgressDialog->wasCanceled() || if (!openSslProgressDialog->wasCanceled() ||
(exitStatus == Utils::QtcProcess::NormalExit && exitCode != 0)) { (exitStatus == QtcProcess::NormalExit && exitCode != 0)) {
QMessageBox::information(this, openSslCloneTitle, QMessageBox::information(this, openSslCloneTitle,
tr("OpenSSL prebuilt libraries cloning failed. " tr("OpenSSL prebuilt libraries cloning failed. "
"Opening OpenSSL URL for manual download.")); "Opening OpenSSL URL for manual download."));
@@ -836,14 +824,14 @@ void AndroidSettingsWidget::downloadOpenSslRepo(const bool silent)
void AndroidSettingsWidget::addAVD() void AndroidSettingsWidget::addAVD()
{ {
disableAvdControls(); disableAvdControls();
CreateAvdInfo info = AvdDialog::gatherCreateAVDInfo(this, m_sdkManager.get(), m_androidConfig); CreateAvdInfo info = AvdDialog::gatherCreateAVDInfo(this, &m_sdkManager, m_androidConfig);
if (!info.isValid()) { if (!info.isValid()) {
enableAvdControls(); enableAvdControls();
return; return;
} }
m_futureWatcher.setFuture(m_avdManager->createAvd(info)); m_futureWatcher.setFuture(m_avdManager.createAvd(info));
} }
void AndroidSettingsWidget::avdAdded() void AndroidSettingsWidget::avdAdded()
@@ -862,7 +850,7 @@ void AndroidSettingsWidget::avdAdded()
void AndroidSettingsWidget::removeAVD() void AndroidSettingsWidget::removeAVD()
{ {
disableAvdControls(); disableAvdControls();
QString avdName = m_AVDModel.avdName(m_ui->AVDTableView->currentIndex()); QString avdName = m_AVDModel.avdName(m_ui.AVDTableView->currentIndex());
if (QMessageBox::question(this, tr("Remove Android Virtual Device"), if (QMessageBox::question(this, tr("Remove Android Virtual Device"),
tr("Remove device \"%1\"? This cannot be undone.").arg(avdName), tr("Remove device \"%1\"? This cannot be undone.").arg(avdName),
QMessageBox::Yes | QMessageBox::No) QMessageBox::Yes | QMessageBox::No)
@@ -871,64 +859,64 @@ void AndroidSettingsWidget::removeAVD()
return; return;
} }
m_avdManager->removeAvd(avdName); m_avdManager.removeAvd(avdName);
startUpdateAvd(); startUpdateAvd();
} }
void AndroidSettingsWidget::startAVD() void AndroidSettingsWidget::startAVD()
{ {
m_avdManager->startAvdAsync(m_AVDModel.avdName(m_ui->AVDTableView->currentIndex())); m_avdManager.startAvdAsync(m_AVDModel.avdName(m_ui.AVDTableView->currentIndex()));
} }
void AndroidSettingsWidget::avdActivated(const QModelIndex &index) void AndroidSettingsWidget::avdActivated(const QModelIndex &index)
{ {
m_ui->AVDRemovePushButton->setEnabled(index.isValid()); m_ui.AVDRemovePushButton->setEnabled(index.isValid());
m_ui->AVDStartPushButton->setEnabled(index.isValid()); m_ui.AVDStartPushButton->setEnabled(index.isValid());
} }
void AndroidSettingsWidget::dataPartitionSizeEditingFinished() void AndroidSettingsWidget::dataPartitionSizeEditingFinished()
{ {
m_androidConfig.setPartitionSize(m_ui->DataPartitionSizeSpinBox->value()); m_androidConfig.setPartitionSize(m_ui.DataPartitionSizeSpinBox->value());
} }
void AndroidSettingsWidget::createKitToggled() void AndroidSettingsWidget::createKitToggled()
{ {
m_androidConfig.setAutomaticKitCreation(m_ui->CreateKitCheckBox->isChecked()); m_androidConfig.setAutomaticKitCreation(m_ui.CreateKitCheckBox->isChecked());
} }
void AndroidSettingsWidget::updateUI() void AndroidSettingsWidget::updateUI()
{ {
auto javaSummaryWidget = static_cast<SummaryWidget *>(m_ui->javaDetailsWidget->widget()); auto javaSummaryWidget = static_cast<SummaryWidget *>(m_ui.javaDetailsWidget->widget());
auto androidSummaryWidget = static_cast<SummaryWidget *>(m_ui->androidDetailsWidget->widget()); auto androidSummaryWidget = static_cast<SummaryWidget *>(m_ui.androidDetailsWidget->widget());
auto openSslSummaryWidget = static_cast<SummaryWidget *>(m_ui->openSslDetailsWidget->widget()); auto openSslSummaryWidget = static_cast<SummaryWidget *>(m_ui.openSslDetailsWidget->widget());
const bool javaSetupOk = javaSummaryWidget->allRowsOk(); const bool javaSetupOk = javaSummaryWidget->allRowsOk();
const bool sdkToolsOk = androidSummaryWidget->rowsOk({SdkPathExistsRow, SdkPathWritableRow, SdkToolsInstalledRow}); const bool sdkToolsOk = androidSummaryWidget->rowsOk({SdkPathExistsRow, SdkPathWritableRow, SdkToolsInstalledRow});
const bool androidSetupOk = androidSummaryWidget->allRowsOk(); const bool androidSetupOk = androidSummaryWidget->allRowsOk();
const bool openSslOk = openSslSummaryWidget->allRowsOk(); const bool openSslOk = openSslSummaryWidget->allRowsOk();
m_ui->avdManagerTab->setEnabled(javaSetupOk && androidSetupOk); m_ui.avdManagerTab->setEnabled(javaSetupOk && androidSetupOk);
m_ui->sdkManagerTab->setEnabled(sdkToolsOk); m_ui.sdkManagerTab->setEnabled(sdkToolsOk);
m_sdkManagerWidget->setSdkManagerControlsEnabled(!m_androidConfig.useNativeUiTools()); m_sdkManagerWidget->setSdkManagerControlsEnabled(!m_androidConfig.useNativeUiTools());
const QListWidgetItem *currentItem = m_ui->ndkListWidget->currentItem(); const QListWidgetItem *currentItem = m_ui.ndkListWidget->currentItem();
Utils::FilePath currentNdk = Utils::FilePath::fromString(currentItem ? currentItem->text() : ""); FilePath currentNdk = FilePath::fromString(currentItem ? currentItem->text() : "");
auto infoText = tr("(SDK Version: %1, NDK Bundle Version: %2)") auto infoText = tr("(SDK Version: %1, NDK Bundle Version: %2)")
.arg(m_androidConfig.sdkToolsVersion().toString()) .arg(m_androidConfig.sdkToolsVersion().toString())
.arg(currentNdk.isEmpty() ? "" : m_androidConfig.ndkVersion(currentNdk).toString()); .arg(currentNdk.isEmpty() ? "" : m_androidConfig.ndkVersion(currentNdk).toString());
androidSummaryWidget->setInfoText(androidSetupOk ? infoText : ""); androidSummaryWidget->setInfoText(androidSetupOk ? infoText : "");
m_ui->javaDetailsWidget->setState(javaSetupOk ? Utils::DetailsWidget::Collapsed : m_ui.javaDetailsWidget->setState(javaSetupOk ? DetailsWidget::Collapsed :
Utils::DetailsWidget::Expanded); DetailsWidget::Expanded);
m_ui->androidDetailsWidget->setState(androidSetupOk ? Utils::DetailsWidget::Collapsed : m_ui.androidDetailsWidget->setState(androidSetupOk ? DetailsWidget::Collapsed :
Utils::DetailsWidget::Expanded); DetailsWidget::Expanded);
m_ui->openSslDetailsWidget->setState(openSslOk ? Utils::DetailsWidget::Collapsed : m_ui.openSslDetailsWidget->setState(openSslOk ? DetailsWidget::Collapsed :
Utils::DetailsWidget::Expanded); DetailsWidget::Expanded);
} }
void AndroidSettingsWidget::manageAVD() void AndroidSettingsWidget::manageAVD()
{ {
if (m_androidConfig.useNativeUiTools()) { if (m_androidConfig.useNativeUiTools()) {
m_avdManager->launchAvdManagerUiTool(); m_avdManager.launchAvdManagerUiTool();
} else { } else {
QMessageBox::warning(this, tr("AVD Manager Not Available"), QMessageBox::warning(this, tr("AVD Manager Not Available"),
tr("AVD manager UI tool is not available in the installed SDK tools " tr("AVD manager UI tool is not available in the installed SDK tools "
@@ -948,15 +936,15 @@ void AndroidSettingsWidget::downloadSdk()
} }
QString message(tr("Download and install Android SDK Tools to: %1?") QString message(tr("Download and install Android SDK Tools to: %1?")
.arg(QDir::toNativeSeparators(m_ui->SDKLocationPathChooser->rawPath()))); .arg(QDir::toNativeSeparators(m_ui.SDKLocationPathChooser->rawPath())));
auto userInput = QMessageBox::information(this, AndroidSdkDownloader::dialogTitle(), auto userInput = QMessageBox::information(this, AndroidSdkDownloader::dialogTitle(),
message, QMessageBox::Yes | QMessageBox::No); message, QMessageBox::Yes | QMessageBox::No);
if (userInput == QMessageBox::Yes) { if (userInput == QMessageBox::Yes) {
auto javaSummaryWidget = static_cast<SummaryWidget *>(m_ui->javaDetailsWidget->widget()); auto javaSummaryWidget = static_cast<SummaryWidget *>(m_ui.javaDetailsWidget->widget());
if (javaSummaryWidget->allRowsOk()) { if (javaSummaryWidget->allRowsOk()) {
auto javaPath = Utils::FilePath::fromUserInput(m_ui->OpenJDKLocationPathChooser->rawPath()); auto javaPath = FilePath::fromUserInput(m_ui.OpenJDKLocationPathChooser->rawPath());
m_sdkDownloader->downloadAndExtractSdk(javaPath.toString(), m_sdkDownloader.downloadAndExtractSdk(javaPath.toString(),
m_ui->SDKLocationPathChooser->filePath().toString()); m_ui.SDKLocationPathChooser->filePath().toString());
} }
} }
} }
@@ -964,7 +952,7 @@ void AndroidSettingsWidget::downloadSdk()
bool AndroidSettingsWidget::allEssentialsInstalled() bool AndroidSettingsWidget::allEssentialsInstalled()
{ {
QStringList essentialPkgs(m_androidConfig.allEssentials()); QStringList essentialPkgs(m_androidConfig.allEssentials());
for (const AndroidSdkPackage *pkg : m_sdkManager->installedSdkPackages()) { for (const AndroidSdkPackage *pkg : m_sdkManager.installedSdkPackages()) {
if (essentialPkgs.contains(pkg->sdkStylePath())) if (essentialPkgs.contains(pkg->sdkStylePath()))
essentialPkgs.removeOne(pkg->sdkStylePath()); essentialPkgs.removeOne(pkg->sdkStylePath());
if (essentialPkgs.isEmpty()) if (essentialPkgs.isEmpty())
@@ -991,7 +979,7 @@ AndroidSettingsPage::AndroidSettingsPage()
setWidgetCreator([] { setWidgetCreator([] {
auto widget = new AndroidSettingsWidget; auto widget = new AndroidSettingsWidget;
QPalette pal = widget->palette(); QPalette pal = widget->palette();
pal.setColor(QPalette::Window, Utils::creatorTheme()->color(Utils::Theme::BackgroundColorNormal)); pal.setColor(QPalette::Window, Utils::creatorTheme()->color(Theme::BackgroundColorNormal));
widget->setPalette(pal); widget->setPalette(pal);
return widget; return widget;
}); });