forked from qt-creator/qt-creator
Android: Rework settings dialog
Make it possible to create multiple AndroidConfigs so that we can have a different one in the settings dialog from the global one. Move pretty much every method from AndroidConfigurations to AndroidConfig, so that the settings dialog can work with its copy. Also add some additional logic to the settings page around the java setting. To start the avd manager we need both a sdk path and a java path. Also do some basic additional checking of the java path. Task-number: QTCREATORBUG-7724 Task-number: QTCREATORBUG-10936 Task-number: QTCREATORBUG-10937 Task-number: QTCREATORBUG-11059 Task-number: QTCREATORBUG-11218 Change-Id: I148c69b9c98a8a070d17d9b0e223d01db1750e69 Reviewed-by: Daniel Teske <daniel.teske@digia.com>
This commit is contained in:
@@ -48,26 +48,9 @@ QT_END_NAMESPACE
|
||||
namespace ProjectExplorer { class Project; }
|
||||
|
||||
namespace Android {
|
||||
class AndroidPlugin;
|
||||
namespace Internal {
|
||||
|
||||
class AndroidConfig
|
||||
{
|
||||
public:
|
||||
AndroidConfig();
|
||||
AndroidConfig(const QSettings &settings);
|
||||
void save(QSettings &settings) const;
|
||||
|
||||
Utils::FileName sdkLocation;
|
||||
Utils::FileName ndkLocation;
|
||||
Utils::FileName antLocation;
|
||||
Utils::FileName openJDKLocation;
|
||||
Utils::FileName keystoreLocation;
|
||||
QString toolchainHost;
|
||||
QStringList makeExtraSearchDirectories;
|
||||
unsigned partitionSize;
|
||||
bool automaticKitCreation;
|
||||
};
|
||||
|
||||
struct AndroidDeviceInfo
|
||||
{
|
||||
QString serialNumber;
|
||||
@@ -80,89 +63,138 @@ struct AndroidDeviceInfo
|
||||
static QStringList adbSelector(const QString &serialNumber);
|
||||
};
|
||||
|
||||
class AndroidConfigurations : public QObject
|
||||
class AndroidConfig
|
||||
{
|
||||
Q_OBJECT
|
||||
|
||||
public:
|
||||
static AndroidConfigurations &instance(QObject *parent = 0);
|
||||
AndroidConfig config() const { return m_config; }
|
||||
void setConfig(const AndroidConfig &config);
|
||||
AndroidConfig();
|
||||
|
||||
void load(const QSettings &settings);
|
||||
void save(QSettings &settings) const;
|
||||
|
||||
QStringList sdkTargets(int minApiLevel = 0) const;
|
||||
|
||||
Utils::FileName sdkLocation() const;
|
||||
void setSdkLocation(const Utils::FileName &sdkLocation);
|
||||
|
||||
Utils::FileName ndkLocation() const;
|
||||
void setNdkLocation(const Utils::FileName &ndkLocation);
|
||||
|
||||
Utils::FileName antLocation() const;
|
||||
void setAntLocation(const Utils::FileName &antLocation);
|
||||
|
||||
Utils::FileName openJDKLocation() const;
|
||||
void setOpenJDKLocation(const Utils::FileName &openJDKLocation);
|
||||
|
||||
Utils::FileName keystoreLocation() const;
|
||||
void setKeystoreLocation(const Utils::FileName &keystoreLocation);
|
||||
|
||||
QString toolchainHost() const;
|
||||
QStringList makeExtraSearchDirectories() const;
|
||||
|
||||
unsigned partitionSize() const;
|
||||
void setPartitionSize(unsigned partitionSize);
|
||||
|
||||
bool automaticKitCreation() const;
|
||||
void setAutomaticKitCreation(bool b);
|
||||
|
||||
Utils::FileName adbToolPath() const;
|
||||
Utils::FileName androidToolPath() const;
|
||||
Utils::Environment androidToolEnvironment() const;
|
||||
Utils::FileName antToolPath() const;
|
||||
Utils::FileName emulatorToolPath() const;
|
||||
|
||||
|
||||
Utils::FileName gccPath(ProjectExplorer::Abi::Architecture architecture, const QString &ndkToolChainVersion) const;
|
||||
Utils::FileName gdbPath(ProjectExplorer::Abi::Architecture architecture, const QString &ndkToolChainVersion) const;
|
||||
Utils::FileName openJDKPath() const;
|
||||
|
||||
Utils::FileName keytoolPath() const;
|
||||
Utils::FileName jarsignerPath() const;
|
||||
Utils::FileName zipalignPath() const;
|
||||
Utils::FileName stripPath(ProjectExplorer::Abi::Architecture architecture, const QString &ndkToolChainVersion) const;
|
||||
Utils::FileName readelfPath(ProjectExplorer::Abi::Architecture architecture, const QString &ndkToolChainVersion) const;
|
||||
|
||||
|
||||
QString createAVD(QWidget *parent, int minApiLevel = 0, QString targetArch = QString()) const;
|
||||
QString createAVD(const QString &target, const QString &name, const QString &abi, int sdcardSize) const;
|
||||
bool removeAVD(const QString &name) const;
|
||||
|
||||
QVector<AndroidDeviceInfo> connectedDevices(QString *error = 0) const;
|
||||
QVector<AndroidDeviceInfo> androidVirtualDevices() const;
|
||||
QString startAVD(const QString &name, int apiLevel, QString cpuAbi) const;
|
||||
bool startAVDAsync(const QString &avdName) const;
|
||||
QString findAvd(int apiLevel, const QString &cpuAbi) const;
|
||||
QString waitForAvd(int apiLevel, const QString &cpuAbi, const QFutureInterface<bool> &fi = QFutureInterface<bool>()) const;
|
||||
// special version for AndroidDeployQt::run
|
||||
QString bestNdkPlatformMatch(const QString &targetAPI) const;
|
||||
|
||||
QStringList makeExtraSearchDirectories() const;
|
||||
|
||||
static ProjectExplorer::Abi::Architecture architectureForToolChainPrefix(const QString &toolchainprefix);
|
||||
static QLatin1String toolchainPrefix(ProjectExplorer::Abi::Architecture architecture);
|
||||
static QLatin1String toolsPrefix(ProjectExplorer::Abi::Architecture architecture);
|
||||
|
||||
// called from AndroidPlugin
|
||||
void updateAndroidDevice();
|
||||
|
||||
QString getProductModel(const QString &device) const;
|
||||
bool hasFinishedBooting(const QString &device) const;
|
||||
bool waitForBooted(const QString &serialNumber, const QFutureInterface<bool> &fi) const;
|
||||
bool isConnected(const QString &serialNumber) const;
|
||||
|
||||
AndroidDeviceInfo showDeviceDialog(ProjectExplorer::Project *project, int apiLevel, const QString &abi);
|
||||
void setDefaultDevice(ProjectExplorer::Project *project, const QString &abi, const QString &serialNumber); // serial number or avd name
|
||||
QString defaultDevice(ProjectExplorer::Project *project, const QString &abi) const; // serial number or avd name
|
||||
QString highestAndroidSdk() const;
|
||||
public slots:
|
||||
void clearDefaultDevices(ProjectExplorer::Project *project);
|
||||
|
||||
signals:
|
||||
void updated();
|
||||
|
||||
public slots:
|
||||
void updateAutomaticKitList();
|
||||
|
||||
private:
|
||||
Utils::FileName toolPath(ProjectExplorer::Abi::Architecture architecture, const QString &ndkToolChainVersion) const;
|
||||
Utils::FileName openJDKBinPath() const;
|
||||
void detectToolchainHost();
|
||||
int getSDKVersion(const QString &device) const;
|
||||
QStringList getAbis(const QString &device) const;
|
||||
bool isBootToQt(const QString &device) const;
|
||||
|
||||
void updateAvailableSdkPlatforms() const;
|
||||
void updateNdkInformation() const;
|
||||
|
||||
Utils::FileName m_sdkLocation;
|
||||
Utils::FileName m_ndkLocation;
|
||||
Utils::FileName m_antLocation;
|
||||
Utils::FileName m_openJDKLocation;
|
||||
Utils::FileName m_keystoreLocation;
|
||||
QStringList m_makeExtraSearchDirectories;
|
||||
unsigned m_partitionSize;
|
||||
bool m_automaticKitCreation;
|
||||
|
||||
//caches
|
||||
mutable bool m_availableSdkPlatformsUpToDate;
|
||||
mutable QVector<int> m_availableSdkPlatforms;
|
||||
|
||||
mutable bool m_NdkInformationUpToDate;
|
||||
mutable QString m_toolchainHost;
|
||||
mutable QVector<int> m_availableNdkPlatforms;
|
||||
|
||||
mutable QHash<QString, QString> m_serialNumberToDeviceName;
|
||||
};
|
||||
|
||||
class AndroidConfigurations : public QObject
|
||||
{
|
||||
friend class Android::AndroidPlugin;
|
||||
Q_OBJECT
|
||||
|
||||
public:
|
||||
static AndroidConfig currentConfig();
|
||||
static void setConfig(const AndroidConfig &config);
|
||||
static AndroidConfigurations *instance();
|
||||
|
||||
static void updateAndroidDevice();
|
||||
static AndroidDeviceInfo showDeviceDialog(ProjectExplorer::Project *project, int apiLevel, const QString &abi);
|
||||
static void setDefaultDevice(ProjectExplorer::Project *project, const QString &abi, const QString &serialNumber); // serial number or avd name
|
||||
static QString defaultDevice(ProjectExplorer::Project *project, const QString &abi); // serial number or avd name
|
||||
public slots:
|
||||
static void clearDefaultDevices(ProjectExplorer::Project *project);
|
||||
static void updateAutomaticKitList();
|
||||
|
||||
signals:
|
||||
void updated();
|
||||
|
||||
private:
|
||||
AndroidConfigurations(QObject *parent);
|
||||
void load();
|
||||
void save();
|
||||
|
||||
int getSDKVersion(const QString &device) const;
|
||||
QStringList getAbis(const QString &device) const;
|
||||
bool isBootToQt(const QString &device) const;
|
||||
void updateAvailableNdkPlatforms();
|
||||
void updateAvailableSdkPlatforms();
|
||||
|
||||
|
||||
static AndroidConfigurations *m_instance;
|
||||
AndroidConfig m_config;
|
||||
QVector<int> m_availableNdkPlatforms;
|
||||
QVector<int> m_availableSdkPlatforms;
|
||||
|
||||
mutable QHash<QString, QString> m_serialNumberToDeviceName;
|
||||
|
||||
QMap<ProjectExplorer::Project *, QMap<QString, QString> > m_defaultDeviceForAbi;
|
||||
};
|
||||
|
||||
Reference in New Issue
Block a user