Android: Use generic functions in CreateAndroidManifestwizard

The only really qmake specific one was adding files to a project
node, that's now done using the usual *QtSupport indirection.

Change-Id: Id6f011d4b26eaba1cd3943f0089fc5b913193fb7
Reviewed-by: Vikas Pachdha <vikas.pachdha@qt.io>
This commit is contained in:
hjk
2018-07-02 18:12:25 +02:00
parent f10002e3f5
commit 5807cea413
5 changed files with 82 additions and 49 deletions

View File

@@ -81,6 +81,9 @@ public:
virtual bool validParse(const ProjectExplorer::Target *target) const = 0; virtual bool validParse(const ProjectExplorer::Target *target) const = 0;
virtual bool extraLibraryEnabled(const ProjectExplorer::Target *target) const = 0; virtual bool extraLibraryEnabled(const ProjectExplorer::Target *target) const = 0;
virtual Utils::FileName projectFilePath(const ProjectExplorer::Target *target) const = 0; virtual Utils::FileName projectFilePath(const ProjectExplorer::Target *target) const = 0;
virtual void addFiles(const ProjectExplorer::Target *target, const QString &buildKey,
const QStringList &addedFiles) const = 0;
}; };
} // namespace Android } // namespace Android

View File

@@ -34,28 +34,24 @@
#include <projectexplorer/runconfiguration.h> #include <projectexplorer/runconfiguration.h>
#include <projectexplorer/target.h> #include <projectexplorer/target.h>
#include <qmakeprojectmanager/qmakeproject.h>
#include <proparser/prowriter.h>
#include <qtsupport/qtkitinformation.h> #include <qtsupport/qtkitinformation.h>
#include <utils/utilsicons.h> #include <utils/utilsicons.h>
#include <QCheckBox> #include <QCheckBox>
#include <QComboBox> #include <QComboBox>
#include <QDir>
#include <QFileInfo>
#include <QFormLayout> #include <QFormLayout>
#include <QLabel> #include <QLabel>
#include <QMessageBox> #include <QMessageBox>
#include <QVBoxLayout> #include <QVBoxLayout>
using namespace Android; using namespace Android;
using namespace ProjectExplorer;
using namespace QmakeAndroidSupport::Internal; using namespace QmakeAndroidSupport::Internal;
using namespace Utils; using namespace Utils;
using QmakeProjectManager::QmakeProject;
using QmakeProjectManager::QmakeProFile;
// //
// NoApplicationProFilePage // NoApplicationProFilePage
// //
@@ -73,10 +69,8 @@ NoApplicationProFilePage::NoApplicationProFilePage(CreateAndroidManifestWizard *
// //
// ChooseProFilePage // ChooseProFilePage
// //
ChooseProFilePage::ChooseProFilePage(CreateAndroidManifestWizard *wizard, ChooseProFilePage::ChooseProFilePage(CreateAndroidManifestWizard *wizard)
const QList<QmakeProFile *> &files, : m_wizard(wizard)
const QmakeProFile *select) :
m_wizard(wizard)
{ {
QFormLayout *fl = new QFormLayout(this); QFormLayout *fl = new QFormLayout(this);
QLabel *label = new QLabel(this); QLabel *label = new QLabel(this);
@@ -84,10 +78,17 @@ ChooseProFilePage::ChooseProFilePage(CreateAndroidManifestWizard *wizard,
label->setText(tr("Select the .pro file for which you want to create the Android template files.")); label->setText(tr("Select the .pro file for which you want to create the Android template files."));
fl->addRow(label); fl->addRow(label);
Target *target = wizard->target();
QString currentBuildTarget;
if (RunConfiguration *rc = target->activeRunConfiguration())
currentBuildTarget = rc->buildKey();
m_comboBox = new QComboBox(this); m_comboBox = new QComboBox(this);
for (QmakeProFile *file : files) { const BuildTargetInfoList buildTargets = wizard->target()->applicationTargets();
m_comboBox->addItem(file->displayName(), QVariant::fromValue(static_cast<void *>(file))); // TODO something more? for (const BuildTargetInfo &bti : buildTargets.list) {
if (file == select) const QString displayName = bti.buildKey;
m_comboBox->addItem(displayName, QVariant(bti.buildKey)); // TODO something more?
if (bti.buildKey == currentBuildTarget)
m_comboBox->setCurrentIndex(m_comboBox->count() - 1); m_comboBox->setCurrentIndex(m_comboBox->count() - 1);
} }
@@ -102,7 +103,7 @@ ChooseProFilePage::ChooseProFilePage(CreateAndroidManifestWizard *wizard,
void ChooseProFilePage::nodeSelected(int index) void ChooseProFilePage::nodeSelected(int index)
{ {
Q_UNUSED(index) Q_UNUSED(index)
m_wizard->setProFile(static_cast<QmakeProFile *>(m_comboBox->itemData(m_comboBox->currentIndex()).value<void *>())); m_wizard->setBuildKey(m_comboBox->itemData(m_comboBox->currentIndex()).toString());
} }
@@ -153,8 +154,11 @@ ChooseDirectoryPage::ChooseDirectoryPage(CreateAndroidManifestWizard *wizard)
void ChooseDirectoryPage::checkPackageSourceDir() void ChooseDirectoryPage::checkPackageSourceDir()
{ {
QString projectDir = m_wizard->proFile()->filePath().toFileInfo().absolutePath(); const QString buildKey = m_wizard->buildKey();
QString newDir = m_androidPackageSourceDir->path(); const BuildTargetInfo bti = m_wizard->target()->applicationTargets().buildTargetInfo(buildKey);
const QString projectDir = bti.projectFilePath.toFileInfo().absolutePath();
const QString newDir = m_androidPackageSourceDir->path();
bool isComplete = QFileInfo(projectDir) != QFileInfo(newDir); bool isComplete = QFileInfo(projectDir) != QFileInfo(newDir);
m_sourceDirectoryWarning->setVisible(!isComplete); m_sourceDirectoryWarning->setVisible(!isComplete);
@@ -173,13 +177,20 @@ bool ChooseDirectoryPage::isComplete() const
void ChooseDirectoryPage::initializePage() void ChooseDirectoryPage::initializePage()
{ {
QString androidPackageDir = m_wizard->proFile()->singleVariableValue(QmakeProjectManager::Variable::AndroidPackageSourceDir); const QString buildKey = m_wizard->buildKey();
const BuildTargetInfo bti = m_wizard->target()->applicationTargets().buildTargetInfo(buildKey);
const QString projectDir = bti.projectFilePath.toFileInfo().absolutePath();
AndroidQtSupport *qtSupport = AndroidManager::androidQtSupport(m_wizard->target());
const QString androidPackageDir
= qtSupport->targetDataItem(Android::Constants::AndroidPackageSourceDir, m_wizard->target());
if (androidPackageDir.isEmpty()) { if (androidPackageDir.isEmpty()) {
m_label->setText(tr("Select the Android package source directory.\n\n" m_label->setText(tr("Select the Android package source directory.\n\n"
"The files in the Android package source directory are copied to the build directory's " "The files in the Android package source directory are copied to the build directory's "
"Android directory and the default files are overwritten.")); "Android directory and the default files are overwritten."));
m_androidPackageSourceDir->setPath(m_wizard->proFile()->filePath().toFileInfo().absolutePath().append(QLatin1String("/android"))); m_androidPackageSourceDir->setPath(projectDir + "/android");
connect(m_androidPackageSourceDir, &PathChooser::rawPathChanged, connect(m_androidPackageSourceDir, &PathChooser::rawPathChanged,
this, &ChooseDirectoryPage::checkPackageSourceDir); this, &ChooseDirectoryPage::checkPackageSourceDir);
} else { } else {
@@ -196,39 +207,34 @@ void ChooseDirectoryPage::initializePage()
// CreateAndroidManifestWizard // CreateAndroidManifestWizard
// //
CreateAndroidManifestWizard::CreateAndroidManifestWizard(ProjectExplorer::Target *target) CreateAndroidManifestWizard::CreateAndroidManifestWizard(ProjectExplorer::Target *target)
: m_target(target), m_proFile(0), m_copyState(Ask) : m_target(target), m_copyState(Ask)
{ {
setWindowTitle(tr("Create Android Template Files Wizard")); setWindowTitle(tr("Create Android Template Files Wizard"));
QmakeProject *project = static_cast<QmakeProject *>(target->project()); const BuildTargetInfoList buildTargets = target->applicationTargets();
QList<QmakeProFile *> files = project->applicationProFiles();
QtSupport::BaseQtVersion *version = QtSupport::QtKitInformation::qtVersion(target->kit()); QtSupport::BaseQtVersion *version = QtSupport::QtKitInformation::qtVersion(target->kit());
m_copyGradle = version && version->qtVersion() >= QtSupport::QtVersionNumber(5, 4, 0); m_copyGradle = version && version->qtVersion() >= QtSupport::QtVersionNumber(5, 4, 0);
const QmakeProFile *currentRunNode = nullptr; if (buildTargets.list.isEmpty()) {
if (ProjectExplorer::RunConfiguration *rc = target->activeRunConfiguration())
currentRunNode = project->rootProFile()->findProFile(FileName::fromString(rc->buildKey()));
if (files.isEmpty()) {
// oh uhm can't create anything // oh uhm can't create anything
addPage(new NoApplicationProFilePage(this)); addPage(new NoApplicationProFilePage(this));
} else if (files.size() == 1) { } else if (buildTargets.list.size() == 1) {
setProFile(files.first()); setBuildKey(buildTargets.list.first().buildKey);
addPage(new ChooseDirectoryPage(this)); addPage(new ChooseDirectoryPage(this));
} else { } else {
addPage(new ChooseProFilePage(this, files, currentRunNode)); addPage(new ChooseProFilePage(this));
addPage(new ChooseDirectoryPage(this)); addPage(new ChooseDirectoryPage(this));
} }
} }
QmakeProjectManager::QmakeProFile *CreateAndroidManifestWizard::proFile() const QString CreateAndroidManifestWizard::buildKey() const
{ {
return m_proFile; return m_buildKey;
} }
void CreateAndroidManifestWizard::setProFile(QmakeProjectManager::QmakeProFile *node) void CreateAndroidManifestWizard::setBuildKey(const QString &buildKey)
{ {
m_proFile = node; m_buildKey = buildKey;
} }
void CreateAndroidManifestWizard::setDirectory(const QString &directory) void CreateAndroidManifestWizard::setDirectory(const QString &directory)
@@ -337,24 +343,33 @@ void CreateAndroidManifestWizard::createAndroidTemplateFiles()
AndroidManager::updateGradleProperties(m_target); AndroidManager::updateGradleProperties(m_target);
} }
m_proFile->addFiles(addedFiles);
if (m_proFile->singleVariableValue(QmakeProjectManager::Variable::AndroidPackageSourceDir).isEmpty()) { AndroidQtSupport *qtSupport = AndroidManager::androidQtSupport(m_target);
qtSupport->addFiles(m_target, m_buildKey, addedFiles);
const QString androidPackageDir
= qtSupport->targetDataItem(Android::Constants::AndroidPackageSourceDir, m_target);
if (androidPackageDir.isEmpty()) {
// and now time for some magic // and now time for some magic
QString value = QLatin1String("$$PWD/") const BuildTargetInfo bti = m_target->applicationTargets().buildTargetInfo(m_buildKey);
+ m_proFile->filePath().toFileInfo().absoluteDir().relativeFilePath(m_directory); const QString value = "$$PWD/" + bti.projectFilePath.toFileInfo().absoluteDir().relativeFilePath(m_directory);
bool result = bool result = qtSupport->setTargetData(Android::Constants::AndroidPackageSourceDir, {value}, m_target);
m_proFile->setProVariable(QLatin1String("ANDROID_PACKAGE_SOURCE_DIR"), QStringList(value));
if (!result) { if (!result) {
QMessageBox::warning(this, tr("Project File not Updated"), QMessageBox::warning(this, tr("Project File not Updated"),
tr("Could not update the .pro file %1.") tr("Could not update the project file %1.")
.arg(m_proFile->filePath().toUserOutput())); .arg(bti.projectFilePath.toUserOutput()));
} }
} }
Core::EditorManager::openEditor(m_directory + QLatin1String("/AndroidManifest.xml")); Core::EditorManager::openEditor(m_directory + QLatin1String("/AndroidManifest.xml"));
} }
ProjectExplorer::Target *CreateAndroidManifestWizard::target() const
{
return m_target;
}
void CreateAndroidManifestWizard::accept() void CreateAndroidManifestWizard::accept()
{ {
createAndroidTemplateFiles(); createAndroidTemplateFiles();

View File

@@ -36,7 +36,6 @@ class QFormLayout;
QT_END_NAMESPACE QT_END_NAMESPACE
namespace ProjectExplorer { class Target; } namespace ProjectExplorer { class Target; }
namespace QmakeProjectManager { class QmakeProFile; }
namespace QmakeAndroidSupport { namespace QmakeAndroidSupport {
namespace Internal { namespace Internal {
@@ -56,9 +55,8 @@ class ChooseProFilePage : public QWizardPage
{ {
Q_OBJECT Q_OBJECT
public: public:
ChooseProFilePage(CreateAndroidManifestWizard *wizard, explicit ChooseProFilePage(CreateAndroidManifestWizard *wizard);
const QList<QmakeProjectManager::QmakeProFile *> &nodes,
const QmakeProjectManager::QmakeProFile *select);
private: private:
void nodeSelected(int index); void nodeSelected(int index);
private: private:
@@ -92,8 +90,8 @@ class CreateAndroidManifestWizard : public Utils::Wizard
public: public:
CreateAndroidManifestWizard(ProjectExplorer::Target *target); CreateAndroidManifestWizard(ProjectExplorer::Target *target);
QmakeProjectManager::QmakeProFile *proFile() const; QString buildKey() const;
void setProFile(QmakeProjectManager::QmakeProFile *proFile); void setBuildKey(const QString &buildKey);
void accept(); void accept();
bool copyGradle(); bool copyGradle();
@@ -101,6 +99,8 @@ public:
void setDirectory(const QString &directory); void setDirectory(const QString &directory);
void setCopyGradle(bool copy); void setCopyGradle(bool copy);
ProjectExplorer::Target *target() const;
private: private:
enum CopyState { enum CopyState {
Ask, Ask,
@@ -112,7 +112,7 @@ private:
void createAndroidManifestFile(); void createAndroidManifestFile();
void createAndroidTemplateFiles(); void createAndroidTemplateFiles();
ProjectExplorer::Target *m_target; ProjectExplorer::Target *m_target;
QmakeProjectManager::QmakeProFile *m_proFile; QString m_buildKey;
QString m_directory; QString m_directory;
CopyState m_copyState; CopyState m_copyState;
bool m_copyGradle; bool m_copyGradle;

View File

@@ -124,6 +124,8 @@ bool QmakeAndroidSupport::setTargetData(Core::Id role, const QStringList &values
QString var; QString var;
if (role == Android::Constants::AndroidExtraLibs) if (role == Android::Constants::AndroidExtraLibs)
var = "ANDROID_EXTRA_LIBS"; var = "ANDROID_EXTRA_LIBS";
else if (role == Android::Constants::AndroidPackageSourceDir)
var = "ANDROID_PACKAGE_SOURCE_DIR";
if (var.isEmpty()) if (var.isEmpty())
return false; return false;
@@ -203,5 +205,15 @@ void QmakeAndroidSupport::manifestSaved(const ProjectExplorer::Target *target)
qbc->manifestSaved(); qbc->manifestSaved();
} }
void QmakeAndroidSupport::addFiles(const ProjectExplorer::Target *target,
const QString &buildKey,
const QStringList &addedFiles) const
{
QmakeProject *project = static_cast<QmakeProject *>(target->project());
QmakeProFile *currentRunNode = project->rootProFile()->findProFile(FileName::fromString(buildKey));
QTC_ASSERT(currentRunNode, return);
currentRunNode->addFiles(addedFiles);
}
} // namespace Internal } // namespace Internal
} // namespace QmakeAndroidSupport } // namespace QmakeAndroidSupport

View File

@@ -49,6 +49,9 @@ public:
bool validParse(const ProjectExplorer::Target *target) const override; bool validParse(const ProjectExplorer::Target *target) const override;
bool extraLibraryEnabled(const ProjectExplorer::Target *target) const override; bool extraLibraryEnabled(const ProjectExplorer::Target *target) const override;
Utils::FileName projectFilePath(const ProjectExplorer::Target *target) const override; Utils::FileName projectFilePath(const ProjectExplorer::Target *target) const override;
void addFiles(const ProjectExplorer::Target *target, const QString &buildKey,
const QStringList &addedFiles) const override;
}; };
} // namespace Internal } // namespace Internal