Newer
Older
/**************************************************************************
**
** This file is part of Qt Creator
**
** Copyright (c) 2010 Nokia Corporation and/or its subsidiary(-ies).
**
** Commercial Usage
**
** Licensees holding valid Qt Commercial licenses may use this file in
** accordance with the Qt Commercial License Agreement provided with the
** Software or, alternatively, in accordance with the terms contained in
** a written agreement between you and Nokia.
**
** GNU Lesser General Public License Usage
**
** Alternatively, this file may be used under the terms of the GNU Lesser
** General Public License version 2.1 as published by the Free Software
** Foundation and appearing in the file LICENSE.LGPL included in the
** packaging of this file. Please review the following information to
** ensure the GNU Lesser General Public License version 2.1 requirements
** will be met: http://www.gnu.org/licenses/old-licenses/lgpl-2.1.html.
**
** If you are unsure which license is appropriate for your use, please
** contact the sales department at http://qt.nokia.com/contact.
**
**************************************************************************/
#include "s60manager.h"
#include "qtversionmanager.h"

Friedemann Kleint
committed
#include "symbiandevicemanager.h"
#include "winscwtoolchain.h"
#include "s60emulatorrunconfiguration.h"
#include "s60createpackagestep.h"
#include <projectexplorer/projectexplorerconstants.h>
#include <projectexplorer/toolchain.h>
#include <QtGui/QMainWindow>
#include <QtCore/QDir>
#include <QtCore/QFileInfo>
const char S60_AUTODETECTION_SOURCE[] = "QTS60";
namespace Qt4ProjectManager {
namespace Internal {
S60Manager *S60Manager::m_instance = 0;
// ======== Parametrizable Factory for RunControls, depending on the configuration
// class and mode.
template <class RunControl, class RunConfiguration>
class RunControlFactory : public ProjectExplorer::IRunControlFactory
{
public:
explicit RunControlFactory(const QString &mode,
const QString &name,
QObject *parent = 0) :
IRunControlFactory(parent), m_mode(mode), m_name(name) {}
bool canRun(ProjectExplorer::RunConfiguration *runConfiguration, const QString &mode) const {
&& (qobject_cast<RunConfiguration *>(runConfiguration) != 0);
ProjectExplorer::RunControl* create(ProjectExplorer::RunConfiguration *runConfiguration, const QString &mode) {
RunConfiguration *rc = qobject_cast<RunConfiguration *>(runConfiguration);
QTC_ASSERT(rc && mode == m_mode, return 0);
}
QString displayName() const {
return m_name;
}
QWidget *createConfigurationWidget(ProjectExplorer::RunConfiguration * /*runConfiguration */) {
return 0;
}
private:
const QString m_mode;
const QString m_name;
};
// ======== S60Manager
S60Manager *S60Manager::instance() { return m_instance; }
: QObject(parent), m_devices(S60Devices::createS60Devices(this))
m_instance = this;
addAutoReleasedObject(new S60DevicesPreferencePane(m_devices, this));
addAutoReleasedObject(new S60EmulatorRunConfigurationFactory);
addAutoReleasedObject(new RunControlFactory<S60EmulatorRunControl,
S60EmulatorRunConfiguration>
(QLatin1String(ProjectExplorer::Constants::RUNMODE),
tr("Run in Emulator"), parent));
addAutoReleasedObject(new S60DeviceRunConfigurationFactory);
addAutoReleasedObject(new RunControlFactory<S60DeviceRunControl,
S60DeviceRunConfiguration>
(QLatin1String(ProjectExplorer::Constants::RUNMODE),
tr("Run on Device"), parent));
addAutoReleasedObject(new S60CreatePackageStepFactory);
addAutoReleasedObject(new S60DeployStepFactory);
if (Debugger::DebuggerPlugin::instance())
addAutoReleasedObject(new RunControlFactory<S60DeviceDebugRunControl,
S60DeviceRunConfiguration>
(QLatin1String(ProjectExplorer::Constants::DEBUGMODE),
tr("Debug on Device"), parent));
connect(m_devices, SIGNAL(qtVersionsChanged()),
this, SLOT(updateQtVersions()));
connect(Core::ICore::instance()->mainWindow(), SIGNAL(deviceChange()),

Friedemann Kleint
committed
SymbianUtils::SymbianDeviceManager::instance(), SLOT(update()));
ExtensionSystem::PluginManager *pm = ExtensionSystem::PluginManager::instance();
for (int i = m_pluginObjects.size() - 1; i >= 0; i--) {
pm->removeObject(m_pluginObjects.at(i));
delete m_pluginObjects.at(i);
}
bool S60Manager::hasRvctCompiler()
{
return !RVCTToolChain::rvctBinEnvironmentVariable().isEmpty();
}
void S60Manager::addAutoReleasedObject(QObject *o)
{
ExtensionSystem::PluginManager::instance()->addObject(o);
m_pluginObjects.push_back(o);
QString S60Manager::deviceIdFromDetectionSource(const QString &autoDetectionSource) const
{
if (autoDetectionSource.startsWith(S60_AUTODETECTION_SOURCE))
return autoDetectionSource.mid(QString(S60_AUTODETECTION_SOURCE).length()+1);
static inline QString qmakeFromQtDir(const QString &qtDir)
{
QString qmake = qtDir + QLatin1String("/bin/qmake");
#ifdef Q_OS_WIN
qmake += QLatin1String(".exe");
#endif
return qmake;
}
void S60Manager::updateQtVersions()
{
// This assumes that the QtVersionManager has already read
// the Qt versions from the settings
QtVersionManager *versionManager = QtVersionManager::instance();
QList<QtVersion *> versions = versionManager->versions();
QList<QtVersion *> handledVersions;
QList<QtVersion *> versionsToAdd;
foreach (const S60Devices::Device &device, m_devices->devices()) {
if (device.qt.isEmpty()) // no Qt version found for this sdk
continue;
QtVersion *deviceVersion = 0;
// look if we have a respective Qt version already
foreach (QtVersion *version, versions) {
if (version->isAutodetected()
&& deviceIdFromDetectionSource(version->autodetectionSource()) == device.id) {
deviceVersion = version;
break;
}
}
if (deviceVersion) {
deviceVersion->setQMakeCommand(qmakeFromQtDir(device.qt));
deviceVersion->setDisplayName(QString("%1 (Qt %2)").arg(device.id, deviceVersion->qtVersionString()));
handledVersions.append(deviceVersion);
} else {
deviceVersion = new QtVersion(QString("%1 (Qt %2)").arg(device.id), qmakeFromQtDir(device.qt),
true, QString("%1.%2").arg(S60_AUTODETECTION_SOURCE, device.id));
deviceVersion->setDisplayName(deviceVersion->displayName().arg(deviceVersion->qtVersionString()));
versionsToAdd.append(deviceVersion);
}
deviceVersion->setS60SDKDirectory(device.epocRoot);
}
// remove old autodetected versions
foreach (QtVersion *version, versions) {
if (version->isAutodetected()
&& version->autodetectionSource().startsWith(S60_AUTODETECTION_SOURCE)
&& !handledVersions.contains(version)) {
versionManager->removeVersion(version);
}
}
// add new versions
foreach (QtVersion *version, versionsToAdd) {
versionManager->addVersion(version);
}
}
ProjectExplorer::ToolChain *S60Manager::createWINSCWToolChain(const Qt4ProjectManager::QtVersion *version) const
{
return new WINSCWToolChain(deviceForQtVersion(version), version->mwcDirectory());
ProjectExplorer::ToolChain *S60Manager::createGCCEToolChain(const Qt4ProjectManager::QtVersion *version) const
{
return GCCEToolChain::create(deviceForQtVersion(version), version->gcceDirectory(), ProjectExplorer::ToolChain::GCCE);
}
ProjectExplorer::ToolChain *S60Manager::createGCCE_GnuPocToolChain(const Qt4ProjectManager::QtVersion *version) const
{
return GCCEToolChain::create(deviceForQtVersion(version), version->gcceDirectory(), ProjectExplorer::ToolChain::GCCE_GNUPOC);
ProjectExplorer::ToolChain *S60Manager::createRVCTToolChain(
const Qt4ProjectManager::QtVersion *version,
ProjectExplorer::ToolChain::ToolChainType type) const
return new RVCTToolChain(deviceForQtVersion(version), type);
S60Devices::Device S60Manager::deviceForQtVersion(const Qt4ProjectManager::QtVersion *version) const
{
S60Devices::Device device;
QString deviceId;
if (version->isAutodetected())
deviceId = deviceIdFromDetectionSource(version->autodetectionSource());
if (deviceId.isEmpty()) { // it's not an s60 autodetected version
// try to find a device entry belonging to the root given in Qt prefs
QString sdkRoot = version->s60SDKDirectory();
if (sdkRoot.isEmpty()) { // no sdk explicitly set in the preferences
// check if EPOCROOT is set and use that
QString epocRootEnv = QProcessEnvironment::systemEnvironment()
.value(QLatin1String("EPOCROOT"));
if (!epocRootEnv.isEmpty())
sdkRoot = QDir::fromNativeSeparators(epocRootEnv);
}
if (sdkRoot.isEmpty()) { // no sdk set via preference or EPOCROOT
// try default device
device = m_devices->defaultDevice();
} else {
device = m_devices->deviceForEpocRoot(sdkRoot);
}
if (device.epocRoot.isEmpty()) { // no device found
// check if we can construct a dummy one
if (QFile::exists(QString::fromLatin1("%1/epoc32").arg(sdkRoot))) {
device.epocRoot = sdkRoot;
device.toolsRoot = device.epocRoot;
device.isDefault = false;
device.name = QString::fromLatin1("Manual");
device.id = QString::fromLatin1("Manual");
}
// override any Qt version that might be still autodetected
device.qt = QFileInfo(QFileInfo(version->qmakeCommand()).path()).path();
} else {
device = m_devices->deviceForId(deviceId);
}
return device;
} // namespace internal
} // namespace qt4projectmanager