Files
qt-creator/src/plugins/qt4projectmanager/qt-s60/s60manager.cpp

272 lines
9.9 KiB
C++
Raw Normal View History

2009-05-26 15:31:29 +02:00
/**************************************************************************
**
** This file is part of Qt Creator
**
2011-01-11 16:28:15 +01:00
** Copyright (c) 2011 Nokia Corporation and/or its subsidiary(-ies).
2009-05-26 15:31:29 +02:00
**
2009-10-12 18:28:48 +02:00
** Contact: Nokia Corporation (qt-info@nokia.com)
2009-05-26 15:31:29 +02:00
**
2010-12-17 16:01:08 +01:00
** No Commercial Usage
2009-05-26 15:31:29 +02:00
**
2010-12-17 16:01:08 +01:00
** This file contains pre-release code and may not be distributed.
** You may use this file in accordance with the terms and conditions
** contained in the Technology Preview License Agreement accompanying
** this package.
2009-05-26 15:31:29 +02:00
**
** 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.
**
2010-12-17 16:01:08 +01:00
** In addition, as a special exception, Nokia gives you certain additional
** rights. These rights are described in the Nokia Qt LGPL Exception
** version 1.1, included in the file LGPL_EXCEPTION.txt in this package.
**
** If you have questions regarding the use of this file, please contact
** Nokia at qt-info@nokia.com.
2009-05-26 15:31:29 +02:00
**
**************************************************************************/
#include "s60manager.h"
#include "qtversionmanager.h"
2009-05-26 15:31:29 +02:00
#include "s60devicespreferencepane.h"
#include "s60emulatorrunconfiguration.h"
2009-08-17 11:47:17 +02:00
#include "s60devicerunconfiguration.h"
#include "s60createpackagestep.h"
#include "s60deploystep.h"
#include "s60runcontrolfactory.h"
#include "qt4symbiantargetfactory.h"
2009-05-26 15:31:29 +02:00
#include "gccetoolchain.h"
#include "rvcttoolchain.h"
#include "winscwtoolchain.h"
#include <symbianutils/symbiandevicemanager.h>
#include <coreplugin/icore.h>
2009-05-26 15:31:29 +02:00
#include <extensionsystem/pluginmanager.h>
#include <projectexplorer/projectexplorerconstants.h>
2011-01-10 10:14:23 +01:00
#include <debugger/debuggerconstants.h>
#include <utils/qtcassert.h>
2009-05-26 15:31:29 +02:00
#include <QtGui/QMainWindow>
#include <QtCore/QDir>
2009-10-29 12:19:56 +01:00
namespace {
const char S60_AUTODETECTION_SOURCE[] = "QTS60";
2009-10-29 12:19:56 +01:00
}
namespace Qt4ProjectManager {
namespace Internal {
2009-05-26 15:31:29 +02:00
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 {
return (mode == m_mode)
&& (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);
return new RunControl(rc, mode);
}
QString displayName() const {
return m_name;
}
ProjectExplorer::RunConfigWidget *createConfigurationWidget(ProjectExplorer::RunConfiguration *) {
return 0;
}
private:
const QString m_mode;
const QString m_name;
};
// ======== S60Manager
S60Manager *S60Manager::instance() { return m_instance; }
2009-05-26 15:31:29 +02:00
S60Manager::S60Manager(QObject *parent)
: QObject(parent), m_devices(S60Devices::createS60Devices(this))
2009-05-26 15:31:29 +02:00
{
m_instance = this;
addAutoReleasedObject(new GcceToolChainFactory);
addAutoReleasedObject(new RvctToolChainFactory);
addAutoReleasedObject(new WinscwToolChainFactory);
#ifdef QTCREATOR_WITH_S60
addAutoReleasedObject(new S60DevicesPreferencePane(m_devices, this));
#endif
addAutoReleasedObject(new S60EmulatorRunConfigurationFactory);
addAutoReleasedObject(new RunControlFactory<S60EmulatorRunControl, S60EmulatorRunConfiguration>
(QLatin1String(ProjectExplorer::Constants::RUNMODE),
tr("Run in Emulator"), parent));
addAutoReleasedObject(new S60DeviceRunConfigurationFactory);
addAutoReleasedObject(new S60RunControlFactory(QLatin1String(ProjectExplorer::Constants::RUNMODE),
tr("Run on Device"), parent));
addAutoReleasedObject(new S60CreatePackageStepFactory);
addAutoReleasedObject(new S60DeployStepFactory);
addAutoReleasedObject(new S60DeviceDebugRunControlFactory);
addAutoReleasedObject(new Qt4SymbianTargetFactory);
updateQtVersions();
connect(m_devices, SIGNAL(qtVersionsChanged()),
this, SLOT(updateQtVersions()));
connect(Core::ICore::instance()->mainWindow(), SIGNAL(deviceChange()),
SymbianUtils::SymbianDeviceManager::instance(), SLOT(update()));
2009-05-26 15:31:29 +02:00
}
S60Manager::~S60Manager()
{
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);
}
}
QString S60Manager::platform(const ProjectExplorer::ToolChain *tc)
{
if (!tc || tc->targetAbi().os() != ProjectExplorer::Abi::SymbianOS)
return QString();
QString target = tc->defaultMakeTarget();
return target.right(target.lastIndexOf(QLatin1Char('-')));
}
void S60Manager::addAutoReleasedObject(QObject *o)
{
ExtensionSystem::PluginManager::instance()->addObject(o);
m_pluginObjects.push_back(o);
2009-05-26 15:31:29 +02:00
}
QString S60Manager::deviceIdFromDetectionSource(const QString &autoDetectionSource) const
{
if (autoDetectionSource.startsWith(S60_AUTODETECTION_SOURCE))
return autoDetectionSource.mid(QString(S60_AUTODETECTION_SOURCE).length()+1);
return QString();
}
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);
}
}
S60Devices::Device S60Manager::deviceForQtVersion(const Qt4ProjectManager::QtVersion *version) const
{
Q_ASSERT(version);
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;
2009-06-05 16:10:26 +02:00
}
2009-10-29 12:19:56 +01:00
} // namespace internal
} // namespace qt4projectmanager