forked from qt-creator/qt-creator
BareMetal: Dissolve BareMetalRunControlFactory
Less code. Change-Id: Ie3bd75557e4f4b5acff65a9b3a074692ea652253 Reviewed-by: hjk <hjk@qt.io>
This commit is contained in:
@@ -10,7 +10,6 @@ SOURCES += baremetalplugin.cpp \
|
|||||||
baremetalrunconfiguration.cpp \
|
baremetalrunconfiguration.cpp \
|
||||||
baremetalrunconfigurationwidget.cpp \
|
baremetalrunconfigurationwidget.cpp \
|
||||||
baremetalgdbcommandsdeploystep.cpp \
|
baremetalgdbcommandsdeploystep.cpp \
|
||||||
baremetalruncontrolfactory.cpp \
|
|
||||||
baremetaldeviceconfigurationwizardpages.cpp \
|
baremetaldeviceconfigurationwizardpages.cpp \
|
||||||
baremetaldeviceconfigurationwizard.cpp \
|
baremetaldeviceconfigurationwizard.cpp \
|
||||||
baremetaldeviceconfigurationwidget.cpp \
|
baremetaldeviceconfigurationwidget.cpp \
|
||||||
@@ -33,7 +32,6 @@ HEADERS += baremetalplugin.h \
|
|||||||
baremetalrunconfiguration.h \
|
baremetalrunconfiguration.h \
|
||||||
baremetalrunconfigurationwidget.h \
|
baremetalrunconfigurationwidget.h \
|
||||||
baremetalgdbcommandsdeploystep.h \
|
baremetalgdbcommandsdeploystep.h \
|
||||||
baremetalruncontrolfactory.h \
|
|
||||||
baremetaldeviceconfigurationfactory.h \
|
baremetaldeviceconfigurationfactory.h \
|
||||||
baremetaldeviceconfigurationwidget.h \
|
baremetaldeviceconfigurationwidget.h \
|
||||||
baremetaldeviceconfigurationwizard.h \
|
baremetaldeviceconfigurationwizard.h \
|
||||||
|
|||||||
@@ -26,7 +26,6 @@ QtcPlugin {
|
|||||||
"baremetalrunconfiguration.cpp", "baremetalrunconfiguration.h",
|
"baremetalrunconfiguration.cpp", "baremetalrunconfiguration.h",
|
||||||
"baremetalrunconfigurationfactory.cpp", "baremetalrunconfigurationfactory.h",
|
"baremetalrunconfigurationfactory.cpp", "baremetalrunconfigurationfactory.h",
|
||||||
"baremetalrunconfigurationwidget.cpp", "baremetalrunconfigurationwidget.h",
|
"baremetalrunconfigurationwidget.cpp", "baremetalrunconfigurationwidget.h",
|
||||||
"baremetalruncontrolfactory.cpp", "baremetalruncontrolfactory.h",
|
|
||||||
"baremetaldebugsupport.cpp", "baremetaldebugsupport.h",
|
"baremetaldebugsupport.cpp", "baremetaldebugsupport.h",
|
||||||
"gdbserverproviderprocess.cpp", "gdbserverproviderprocess.h",
|
"gdbserverproviderprocess.cpp", "gdbserverproviderprocess.h",
|
||||||
"gdbserverproviderssettingspage.cpp", "gdbserverproviderssettingspage.h",
|
"gdbserverproviderssettingspage.cpp", "gdbserverproviderssettingspage.h",
|
||||||
|
|||||||
@@ -27,7 +27,8 @@
|
|||||||
#include "baremetalplugin.h"
|
#include "baremetalplugin.h"
|
||||||
#include "baremetalconstants.h"
|
#include "baremetalconstants.h"
|
||||||
#include "baremetaldeviceconfigurationfactory.h"
|
#include "baremetaldeviceconfigurationfactory.h"
|
||||||
#include "baremetalruncontrolfactory.h"
|
#include "baremetaldebugsupport.h"
|
||||||
|
#include "baremetalrunconfiguration.h"
|
||||||
#include "baremetalrunconfigurationfactory.h"
|
#include "baremetalrunconfigurationfactory.h"
|
||||||
|
|
||||||
#include "gdbserverproviderssettingspage.h"
|
#include "gdbserverproviderssettingspage.h"
|
||||||
@@ -46,6 +47,8 @@
|
|||||||
#include <QMenu>
|
#include <QMenu>
|
||||||
#include <QtPlugin>
|
#include <QtPlugin>
|
||||||
|
|
||||||
|
using namespace ProjectExplorer;
|
||||||
|
|
||||||
namespace BareMetal {
|
namespace BareMetal {
|
||||||
namespace Internal {
|
namespace Internal {
|
||||||
|
|
||||||
@@ -64,11 +67,22 @@ bool BareMetalPlugin::initialize(const QStringList &arguments, QString *errorStr
|
|||||||
Q_UNUSED(errorString)
|
Q_UNUSED(errorString)
|
||||||
|
|
||||||
addAutoReleasedObject(new BareMetalDeviceConfigurationFactory);
|
addAutoReleasedObject(new BareMetalDeviceConfigurationFactory);
|
||||||
addAutoReleasedObject(new BareMetalRunControlFactory);
|
|
||||||
addAutoReleasedObject(new BareMetalRunConfigurationFactory);
|
addAutoReleasedObject(new BareMetalRunConfigurationFactory);
|
||||||
addAutoReleasedObject(new GdbServerProvidersSettingsPage);
|
addAutoReleasedObject(new GdbServerProvidersSettingsPage);
|
||||||
addAutoReleasedObject(new GdbServerProviderManager);
|
addAutoReleasedObject(new GdbServerProviderManager);
|
||||||
|
|
||||||
|
auto constraint = [](RunConfiguration *runConfig) {
|
||||||
|
const QByteArray idStr = runConfig->id().name();
|
||||||
|
return runConfig->isEnabled() && idStr.startsWith(BareMetalRunConfiguration::IdPrefix);
|
||||||
|
};
|
||||||
|
|
||||||
|
RunControl::registerWorker<BareMetalDebugSupport>
|
||||||
|
(ProjectExplorer::Constants::NORMAL_RUN_MODE, constraint);
|
||||||
|
RunControl::registerWorker<BareMetalDebugSupport>
|
||||||
|
(ProjectExplorer::Constants::DEBUG_RUN_MODE, constraint);
|
||||||
|
RunControl::registerWorker<BareMetalDebugSupport>
|
||||||
|
(ProjectExplorer::Constants::DEBUG_RUN_MODE_WITH_BREAK_ON_MAIN, constraint);
|
||||||
|
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|||||||
@@ -1,61 +0,0 @@
|
|||||||
/****************************************************************************
|
|
||||||
**
|
|
||||||
** Copyright (C) 2016 Tim Sander <tim@krieglstein.org>
|
|
||||||
** Copyright (C) 2016 Denis Shienkov <denis.shienkov@gmail.com>
|
|
||||||
** 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 "baremetalruncontrolfactory.h"
|
|
||||||
#include "baremetaldebugsupport.h"
|
|
||||||
|
|
||||||
using namespace ProjectExplorer;
|
|
||||||
|
|
||||||
namespace BareMetal {
|
|
||||||
namespace Internal {
|
|
||||||
|
|
||||||
BareMetalRunControlFactory::BareMetalRunControlFactory(QObject *parent) :
|
|
||||||
IRunControlFactory(parent)
|
|
||||||
{
|
|
||||||
}
|
|
||||||
|
|
||||||
bool BareMetalRunControlFactory::canRun(RunConfiguration *runConfiguration, Core::Id mode) const
|
|
||||||
{
|
|
||||||
if (mode != ProjectExplorer::Constants::NORMAL_RUN_MODE
|
|
||||||
&& mode != ProjectExplorer::Constants::DEBUG_RUN_MODE
|
|
||||||
&& mode != ProjectExplorer::Constants::DEBUG_RUN_MODE_WITH_BREAK_ON_MAIN) {
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
|
|
||||||
const QByteArray idStr = runConfiguration->id().name();
|
|
||||||
return runConfiguration->isEnabled() && idStr.startsWith(BareMetalRunConfiguration::IdPrefix);
|
|
||||||
}
|
|
||||||
|
|
||||||
RunControl *BareMetalRunControlFactory::create(
|
|
||||||
RunConfiguration *runConfiguration, Core::Id mode, QString *)
|
|
||||||
{
|
|
||||||
auto runControl = new RunControl(runConfiguration, mode);
|
|
||||||
(void) new BareMetalDebugSupport(runControl);
|
|
||||||
return runControl;
|
|
||||||
}
|
|
||||||
|
|
||||||
} // namespace Internal
|
|
||||||
} // namespace BareMetal
|
|
||||||
@@ -1,50 +0,0 @@
|
|||||||
/****************************************************************************
|
|
||||||
**
|
|
||||||
** Copyright (C) 2016 Tim Sander <tim@krieglstein.org>
|
|
||||||
** Copyright (C) 2016 Denis Shienkov <denis.shienkov@gmail.com>
|
|
||||||
** 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 "baremetalrunconfiguration.h"
|
|
||||||
|
|
||||||
#include <projectexplorer/runconfiguration.h>
|
|
||||||
#include <debugger/debuggerstartparameters.h>
|
|
||||||
|
|
||||||
namespace BareMetal {
|
|
||||||
namespace Internal {
|
|
||||||
|
|
||||||
class BareMetalRunControlFactory : public ProjectExplorer::IRunControlFactory
|
|
||||||
{
|
|
||||||
Q_OBJECT
|
|
||||||
|
|
||||||
public:
|
|
||||||
explicit BareMetalRunControlFactory(QObject *parent = 0);
|
|
||||||
|
|
||||||
bool canRun(ProjectExplorer::RunConfiguration *runConfiguration, Core::Id mode) const override;
|
|
||||||
ProjectExplorer::RunControl *create(ProjectExplorer::RunConfiguration *runConfiguration,
|
|
||||||
Core::Id mode, QString *) override;
|
|
||||||
};
|
|
||||||
|
|
||||||
} // namespace Internal
|
|
||||||
} // namespace BareMetal
|
|
||||||
Reference in New Issue
Block a user