forked from qt-creator/qt-creator
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:
@@ -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
|
||||||
|
|||||||
@@ -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();
|
||||||
|
|||||||
@@ -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;
|
||||||
|
|||||||
@@ -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
|
||||||
|
|||||||
@@ -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
|
||||||
|
|||||||
Reference in New Issue
Block a user