forked from qt-creator/qt-creator
Boot2Qt: Merge qdbmakedefaultappservice into build step files
Not worth a separate compilation unit and pimpling. Change-Id: Ie7649938bc8c97061ccac0a37c075a6bd7900c97 Reviewed-by: Jarek Kobus <jaroslaw.kobus@qt.io>
This commit is contained in:
@@ -9,7 +9,6 @@ add_qtc_plugin(Boot2Qt
|
||||
qdbdeployconfigurationfactory.cpp qdbdeployconfigurationfactory.h
|
||||
qdbdevice.cpp qdbdevice.h
|
||||
qdbdevicedebugsupport.cpp qdbdevicedebugsupport.h
|
||||
qdbmakedefaultappservice.cpp qdbmakedefaultappservice.h
|
||||
qdbmakedefaultappstep.cpp qdbmakedefaultappstep.h
|
||||
qdbplugin.cpp qdbplugin.h
|
||||
qdbqtversion.cpp qdbqtversion.h
|
||||
|
@@ -27,8 +27,6 @@ QtcPlugin {
|
||||
"qdbdevice.h",
|
||||
"qdbdevicedebugsupport.cpp",
|
||||
"qdbdevicedebugsupport.h",
|
||||
"qdbmakedefaultappservice.cpp",
|
||||
"qdbmakedefaultappservice.h",
|
||||
"qdbmakedefaultappstep.cpp",
|
||||
"qdbmakedefaultappstep.h",
|
||||
"qdbplugin.cpp",
|
||||
|
@@ -1,97 +0,0 @@
|
||||
/****************************************************************************
|
||||
**
|
||||
** Copyright (C) 2019 The Qt Company Ltd.
|
||||
** Contact: https://www.qt.io/licensing/
|
||||
**
|
||||
** 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 The Qt Company. For licensing terms
|
||||
** and conditions see https://www.qt.io/terms-conditions. For further
|
||||
** information use the contact form at https://www.qt.io/contact-us.
|
||||
**
|
||||
** GNU General Public License Usage
|
||||
** Alternatively, this file may be used under the terms of the GNU
|
||||
** General Public License version 3 as published by the Free Software
|
||||
** Foundation with exceptions as appearing in the file LICENSE.GPL3-EXCEPT
|
||||
** included in the packaging of this file. Please review the following
|
||||
** information to ensure the GNU General Public License requirements will
|
||||
** be met: https://www.gnu.org/licenses/gpl-3.0.html.
|
||||
**
|
||||
****************************************************************************/
|
||||
|
||||
#include "qdbmakedefaultappservice.h"
|
||||
|
||||
#include "qdbconstants.h"
|
||||
#include "qdbrunconfiguration.h"
|
||||
|
||||
#include <projectexplorer/devicesupport/idevice.h>
|
||||
#include <projectexplorer/target.h>
|
||||
#include <utils/qtcprocess.h>
|
||||
|
||||
using namespace Utils;
|
||||
|
||||
namespace Qdb {
|
||||
namespace Internal {
|
||||
|
||||
class QdbMakeDefaultAppServicePrivate
|
||||
{
|
||||
public:
|
||||
bool m_makeDefault = true;
|
||||
QtcProcess m_process;
|
||||
};
|
||||
|
||||
QdbMakeDefaultAppService::QdbMakeDefaultAppService(QObject *parent)
|
||||
: AbstractRemoteLinuxDeployService(parent),
|
||||
d(new QdbMakeDefaultAppServicePrivate)
|
||||
{
|
||||
connect(&d->m_process, &QtcProcess::done, this, [this] {
|
||||
if (d->m_process.error() != QProcess::UnknownError)
|
||||
emit errorMessage(tr("Remote process failed: %1").arg(d->m_process.errorString()));
|
||||
else if (d->m_makeDefault)
|
||||
emit progressMessage(tr("Application set as the default one."));
|
||||
else
|
||||
emit progressMessage(tr("Reset the default application."));
|
||||
|
||||
stopDeployment();
|
||||
});
|
||||
connect(&d->m_process, &QtcProcess::readyReadStandardError, this, [this] {
|
||||
emit stdErrData(QString::fromUtf8(d->m_process.readAllStandardError()));
|
||||
});
|
||||
}
|
||||
|
||||
QdbMakeDefaultAppService::~QdbMakeDefaultAppService() = default;
|
||||
|
||||
void QdbMakeDefaultAppService::setMakeDefault(bool makeDefault)
|
||||
{
|
||||
d->m_makeDefault = makeDefault;
|
||||
}
|
||||
|
||||
void QdbMakeDefaultAppService::doDeploy()
|
||||
{
|
||||
QString remoteExe;
|
||||
|
||||
if (ProjectExplorer::RunConfiguration *rc = target()->activeRunConfiguration()) {
|
||||
if (auto exeAspect = rc->aspect<ProjectExplorer::ExecutableAspect>())
|
||||
remoteExe = exeAspect->executable().toString();
|
||||
}
|
||||
|
||||
const QString args = d->m_makeDefault && !remoteExe.isEmpty()
|
||||
? QStringLiteral("--make-default ") + remoteExe
|
||||
: QStringLiteral("--remove-default");
|
||||
d->m_process.setCommand(
|
||||
{deviceConfiguration()->mapToGlobalPath(Constants::AppcontrollerFilepath), {args}});
|
||||
d->m_process.start();
|
||||
}
|
||||
|
||||
void QdbMakeDefaultAppService::stopDeployment()
|
||||
{
|
||||
d->m_process.close();
|
||||
handleDeploymentDone();
|
||||
}
|
||||
|
||||
} // namespace Internal
|
||||
} // namespace Qdb
|
@@ -1,52 +0,0 @@
|
||||
/****************************************************************************
|
||||
**
|
||||
** Copyright (C) 2019 The Qt Company Ltd.
|
||||
** Contact: https://www.qt.io/licensing/
|
||||
**
|
||||
** 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 The Qt Company. For licensing terms
|
||||
** and conditions see https://www.qt.io/terms-conditions. For further
|
||||
** information use the contact form at https://www.qt.io/contact-us.
|
||||
**
|
||||
** GNU General Public License Usage
|
||||
** Alternatively, this file may be used under the terms of the GNU
|
||||
** General Public License version 3 as published by the Free Software
|
||||
** Foundation with exceptions as appearing in the file LICENSE.GPL3-EXCEPT
|
||||
** included in the packaging of this file. Please review the following
|
||||
** information to ensure the GNU General Public License requirements will
|
||||
** be met: https://www.gnu.org/licenses/gpl-3.0.html.
|
||||
**
|
||||
****************************************************************************/
|
||||
|
||||
#pragma once
|
||||
|
||||
#include <remotelinux/abstractremotelinuxdeployservice.h>
|
||||
|
||||
namespace Qdb {
|
||||
namespace Internal {
|
||||
|
||||
class QdbMakeDefaultAppServicePrivate;
|
||||
|
||||
class QdbMakeDefaultAppService : public RemoteLinux::AbstractRemoteLinuxDeployService
|
||||
{
|
||||
Q_OBJECT
|
||||
public:
|
||||
QdbMakeDefaultAppService(QObject *parent = 0);
|
||||
~QdbMakeDefaultAppService();
|
||||
void setMakeDefault(bool makeDefault);
|
||||
|
||||
private:
|
||||
bool isDeploymentNecessary() const final { return true; }
|
||||
void doDeploy() final;
|
||||
void stopDeployment() final;
|
||||
|
||||
std::unique_ptr<QdbMakeDefaultAppServicePrivate> d;
|
||||
};
|
||||
|
||||
} // namespace Internal
|
||||
} // namespace Qdb
|
@@ -26,29 +26,92 @@
|
||||
#include "qdbmakedefaultappstep.h"
|
||||
|
||||
#include "qdbconstants.h"
|
||||
#include "qdbmakedefaultappservice.h"
|
||||
|
||||
#include <projectexplorer/devicesupport/idevice.h>
|
||||
#include <projectexplorer/runconfigurationaspects.h>
|
||||
#include <projectexplorer/target.h>
|
||||
|
||||
#include <remotelinux/abstractremotelinuxdeploystep.h>
|
||||
|
||||
#include <utils/commandline.h>
|
||||
#include <utils/qtcprocess.h>
|
||||
|
||||
using namespace ProjectExplorer;
|
||||
using namespace Utils;
|
||||
|
||||
namespace Qdb {
|
||||
namespace Internal {
|
||||
|
||||
// QdbMakeDefaultAppService
|
||||
|
||||
class QdbMakeDefaultAppService : public RemoteLinux::AbstractRemoteLinuxDeployService
|
||||
{
|
||||
Q_DECLARE_TR_FUNCTIONS(Qdb::Internal::QdbMakeDefaultAppService)
|
||||
|
||||
public:
|
||||
QdbMakeDefaultAppService()
|
||||
{
|
||||
connect(&m_process, &QtcProcess::done, this, [this] {
|
||||
if (m_process.error() != QProcess::UnknownError)
|
||||
emit errorMessage(tr("Remote process failed: %1").arg(m_process.errorString()));
|
||||
else if (m_makeDefault)
|
||||
emit progressMessage(tr("Application set as the default one."));
|
||||
else
|
||||
emit progressMessage(tr("Reset the default application."));
|
||||
|
||||
stopDeployment();
|
||||
});
|
||||
connect(&m_process, &QtcProcess::readyReadStandardError, this, [this] {
|
||||
emit stdErrData(QString::fromUtf8(m_process.readAllStandardError()));
|
||||
});
|
||||
}
|
||||
|
||||
void setMakeDefault(bool makeDefault)
|
||||
{
|
||||
m_makeDefault = makeDefault;
|
||||
}
|
||||
|
||||
private:
|
||||
bool isDeploymentNecessary() const final { return true; }
|
||||
|
||||
void doDeploy() final
|
||||
{
|
||||
QString remoteExe;
|
||||
|
||||
if (RunConfiguration *rc = target()->activeRunConfiguration()) {
|
||||
if (auto exeAspect = rc->aspect<ExecutableAspect>())
|
||||
remoteExe = exeAspect->executable().toString();
|
||||
}
|
||||
|
||||
const QString args = m_makeDefault && !remoteExe.isEmpty()
|
||||
? QStringLiteral("--make-default ") + remoteExe
|
||||
: QStringLiteral("--remove-default");
|
||||
m_process.setCommand(
|
||||
{deviceConfiguration()->mapToGlobalPath(Constants::AppcontrollerFilepath), {args}});
|
||||
m_process.start();
|
||||
}
|
||||
|
||||
void stopDeployment() final
|
||||
{
|
||||
m_process.close();
|
||||
handleDeploymentDone();
|
||||
}
|
||||
|
||||
bool m_makeDefault = true;
|
||||
QtcProcess m_process;
|
||||
};
|
||||
|
||||
|
||||
// QdbMakeDefaultAppStep
|
||||
|
||||
class QdbMakeDefaultAppStep final : public RemoteLinux::AbstractRemoteLinuxDeployStep
|
||||
{
|
||||
Q_DECLARE_TR_FUNCTIONS(Qdb::Internal::QdbMakeDefaultAppStep)
|
||||
|
||||
public:
|
||||
QdbMakeDefaultAppStep(BuildStepList *bsl, Utils::Id id);
|
||||
};
|
||||
|
||||
QdbMakeDefaultAppStep::QdbMakeDefaultAppStep(BuildStepList *bsl, Utils::Id id)
|
||||
QdbMakeDefaultAppStep(BuildStepList *bsl, Id id)
|
||||
: AbstractRemoteLinuxDeployStep(bsl, id)
|
||||
{
|
||||
{
|
||||
auto service = createDeployService<QdbMakeDefaultAppService>();
|
||||
|
||||
auto selection = addAspect<SelectionAspect>();
|
||||
@@ -60,7 +123,9 @@ QdbMakeDefaultAppStep::QdbMakeDefaultAppStep(BuildStepList *bsl, Utils::Id id)
|
||||
service->setMakeDefault(selection->value() == 0);
|
||||
return service->isDeploymentPossible();
|
||||
});
|
||||
}
|
||||
}
|
||||
};
|
||||
|
||||
|
||||
// QdbMakeDefaultAppStepFactory
|
||||
|
||||
|
Reference in New Issue
Block a user