/**************************************************************************** ** ** Copyright (C) 2013 Digia Plc and/or its subsidiary(-ies). ** Contact: http://www.qt-project.org/legal ** ** This file is part of Qt Creator. ** ** Commercial License Usage ** Licensees holding valid commercial Qt licenses may use this file in ** accordance with the commercial license agreement provided with the ** Software or, alternatively, in accordance with the terms contained in ** a written agreement between you and Digia. For licensing terms and ** conditions see http://qt.digia.com/licensing. For further information ** use the contact form at http://qt.digia.com/contact-us. ** ** 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. ** ** In addition, as a special exception, Digia gives you certain additional ** rights. These rights are described in the Digia Qt LGPL Exception ** version 1.1, included in the file LGPL_EXCEPTION.txt in this package. ** ****************************************************************************/ #include "remotelinuxrunconfiguration.h" #include "remotelinuxenvironmentaspect.h" #include "remotelinuxrunconfigurationwidget.h" #include #include #include #include #include #include #include using namespace ProjectExplorer; using namespace Utils; namespace RemoteLinux { namespace Internal { namespace { const char ArgumentsKey[] = "Qt4ProjectManager.MaemoRunConfiguration.Arguments"; const char ProFileKey[] = "Qt4ProjectManager.MaemoRunConfiguration.ProFile"; const char UseAlternateExeKey[] = "RemoteLinux.RunConfig.UseAlternateRemoteExecutable"; const char AlternateExeKey[] = "RemoteLinux.RunConfig.AlternateRemoteExecutable"; const char WorkingDirectoryKey[] = "RemoteLinux.RunConfig.WorkingDirectory"; } // anonymous namespace class RemoteLinuxRunConfigurationPrivate { public: RemoteLinuxRunConfigurationPrivate(const QString &projectFilePath) : projectFilePath(projectFilePath), useAlternateRemoteExecutable(false) { } RemoteLinuxRunConfigurationPrivate(const RemoteLinuxRunConfigurationPrivate *other) : projectFilePath(other->projectFilePath), gdbPath(other->gdbPath), arguments(other->arguments), useAlternateRemoteExecutable(other->useAlternateRemoteExecutable), alternateRemoteExecutable(other->alternateRemoteExecutable), workingDirectory(other->workingDirectory) { } QString projectFilePath; QString gdbPath; QStringList arguments; QString disabledReason; bool useAlternateRemoteExecutable; QString alternateRemoteExecutable; QString workingDirectory; }; } // namespace Internal using namespace Internal; RemoteLinuxRunConfiguration::RemoteLinuxRunConfiguration(Target *parent, const Core::Id id, const QString &proFilePath) : RunConfiguration(parent, id), d(new RemoteLinuxRunConfigurationPrivate(proFilePath)) { init(); } RemoteLinuxRunConfiguration::RemoteLinuxRunConfiguration(ProjectExplorer::Target *parent, RemoteLinuxRunConfiguration *source) : RunConfiguration(parent, source), d(new RemoteLinuxRunConfigurationPrivate(source->d)) { init(); } RemoteLinuxRunConfiguration::~RemoteLinuxRunConfiguration() { delete d; } void RemoteLinuxRunConfiguration::init() { setDefaultDisplayName(defaultDisplayName()); addExtraAspect(new RemoteLinuxEnvironmentAspect(this)); connect(target(), SIGNAL(deploymentDataChanged()), SLOT(handleBuildSystemDataUpdated())); connect(target(), SIGNAL(applicationTargetsChanged()), SLOT(handleBuildSystemDataUpdated())); connect(target(), SIGNAL(kitChanged()), this, SLOT(handleBuildSystemDataUpdated())); // Handles device changes, etc. } bool RemoteLinuxRunConfiguration::isEnabled() const { return true; } QString RemoteLinuxRunConfiguration::disabledReason() const { return d->disabledReason; } QWidget *RemoteLinuxRunConfiguration::createConfigurationWidget() { return new RemoteLinuxRunConfigurationWidget(this); } OutputFormatter *RemoteLinuxRunConfiguration::createOutputFormatter() const { return new QtSupport::QtOutputFormatter(target()->project()); } QVariantMap RemoteLinuxRunConfiguration::toMap() const { QVariantMap map(RunConfiguration::toMap()); map.insert(QLatin1String(ArgumentsKey), d->arguments); const QDir dir = QDir(target()->project()->projectDirectory()); map.insert(QLatin1String(ProFileKey), dir.relativeFilePath(d->projectFilePath)); map.insert(QLatin1String(UseAlternateExeKey), d->useAlternateRemoteExecutable); map.insert(QLatin1String(AlternateExeKey), d->alternateRemoteExecutable); map.insert(QLatin1String(WorkingDirectoryKey), d->workingDirectory); return map; } bool RemoteLinuxRunConfiguration::fromMap(const QVariantMap &map) { if (!RunConfiguration::fromMap(map)) return false; d->arguments = map.value(QLatin1String(ArgumentsKey)).toStringList(); const QDir dir = QDir(target()->project()->projectDirectory()); d->projectFilePath = QDir::cleanPath(dir.filePath(map.value(QLatin1String(ProFileKey)).toString())); d->useAlternateRemoteExecutable = map.value(QLatin1String(UseAlternateExeKey), false).toBool(); d->alternateRemoteExecutable = map.value(QLatin1String(AlternateExeKey)).toString(); d->workingDirectory = map.value(QLatin1String(WorkingDirectoryKey)).toString(); setDefaultDisplayName(defaultDisplayName()); return true; } QString RemoteLinuxRunConfiguration::defaultDisplayName() { if (!d->projectFilePath.isEmpty()) //: %1 is the name of a project which is being run on remote Linux return tr("%1 (on Remote Device)").arg(QFileInfo(d->projectFilePath).completeBaseName()); //: Remote Linux run configuration default display name return tr("Run on Remote Device"); } QStringList RemoteLinuxRunConfiguration::arguments() const { return d->arguments; } Environment RemoteLinuxRunConfiguration::environment() const { RemoteLinuxEnvironmentAspect *aspect = extraAspect(); QTC_ASSERT(aspect, return Environment()); Environment env(OsTypeLinux); env.modify(aspect->userEnvironmentChanges()); const QString displayKey = QLatin1String("DISPLAY"); if (!env.hasKey(displayKey)) env.appendOrSet(displayKey, QLatin1String(":0.0")); return env; } QString RemoteLinuxRunConfiguration::localExecutableFilePath() const { return target()->applicationTargets() .targetForProject(Utils::FileName::fromString(d->projectFilePath)).toString(); } QString RemoteLinuxRunConfiguration::defaultRemoteExecutableFilePath() const { return target()->deploymentData().deployableForLocalFile(localExecutableFilePath()) .remoteFilePath(); } QString RemoteLinuxRunConfiguration::remoteExecutableFilePath() const { return d->useAlternateRemoteExecutable ? alternateRemoteExecutable() : defaultRemoteExecutableFilePath(); } void RemoteLinuxRunConfiguration::setArguments(const QString &args) { d->arguments = QtcProcess::splitArgs(args); // TODO: Widget should be list-based. } QString RemoteLinuxRunConfiguration::workingDirectory() const { return d->workingDirectory; } void RemoteLinuxRunConfiguration::setWorkingDirectory(const QString &wd) { d->workingDirectory = wd; } void RemoteLinuxRunConfiguration::setUseAlternateExecutable(bool useAlternate) { d->useAlternateRemoteExecutable = useAlternate; } bool RemoteLinuxRunConfiguration::useAlternateExecutable() const { return d->useAlternateRemoteExecutable; } void RemoteLinuxRunConfiguration::setAlternateRemoteExecutable(const QString &exe) { d->alternateRemoteExecutable = exe; } QString RemoteLinuxRunConfiguration::alternateRemoteExecutable() const { return d->alternateRemoteExecutable; } int RemoteLinuxRunConfiguration::portsUsedByDebuggers() const { int ports = 0; Debugger::DebuggerRunConfigurationAspect *aspect = extraAspect(); if (aspect->useQmlDebugger()) ++ports; if (aspect->useCppDebugger()) ++ports; return ports; } void RemoteLinuxRunConfiguration::handleBuildSystemDataUpdated() { emit deploySpecsChanged(); emit targetInformationChanged(); updateEnabledState(); } QString RemoteLinuxRunConfiguration::projectFilePath() const { return d->projectFilePath; } void RemoteLinuxRunConfiguration::setDisabledReason(const QString &reason) const { d->disabledReason = reason; } const char *RemoteLinuxRunConfiguration::IdPrefix = "RemoteLinuxRunConfiguration:"; } // namespace RemoteLinux