forked from qt-creator/qt-creator
CMakeProjectManager: Use aspect more directly in CMakeInstallStep
Change-Id: Ibdd1fea42b93282b387693ea3d8cb155deeaed8a Reviewed-by: Jarek Kobus <jaroslaw.kobus@qt.io>
This commit is contained in:
@@ -16,6 +16,7 @@
|
|||||||
#include <projectexplorer/project.h>
|
#include <projectexplorer/project.h>
|
||||||
#include <projectexplorer/projectexplorer.h>
|
#include <projectexplorer/projectexplorer.h>
|
||||||
#include <projectexplorer/projectexplorerconstants.h>
|
#include <projectexplorer/projectexplorerconstants.h>
|
||||||
|
|
||||||
#include <utils/layoutbuilder.h>
|
#include <utils/layoutbuilder.h>
|
||||||
|
|
||||||
using namespace Core;
|
using namespace Core;
|
||||||
@@ -24,14 +25,20 @@ using namespace Utils;
|
|||||||
|
|
||||||
namespace CMakeProjectManager::Internal {
|
namespace CMakeProjectManager::Internal {
|
||||||
|
|
||||||
const char CMAKE_ARGUMENTS_KEY[] = "CMakeProjectManager.InstallStep.CMakeArguments";
|
|
||||||
|
|
||||||
// CMakeInstallStep
|
// CMakeInstallStep
|
||||||
|
|
||||||
class CMakeInstallStep : public CMakeAbstractProcessStep
|
class CMakeInstallStep : public CMakeAbstractProcessStep
|
||||||
{
|
{
|
||||||
public:
|
public:
|
||||||
CMakeInstallStep(ProjectExplorer::BuildStepList *bsl, Id id);
|
CMakeInstallStep(BuildStepList *bsl, Id id)
|
||||||
|
: CMakeAbstractProcessStep(bsl, id)
|
||||||
|
{
|
||||||
|
cmakeArguments.setSettingsKey("CMakeProjectManager.InstallStep.CMakeArguments");
|
||||||
|
cmakeArguments.setLabelText(Tr::tr("CMake arguments:"));
|
||||||
|
cmakeArguments.setDisplayStyle(StringAspect::LineEditDisplay);
|
||||||
|
|
||||||
|
setCommandLineProvider([this] { return cmakeCommand(); });
|
||||||
|
}
|
||||||
|
|
||||||
private:
|
private:
|
||||||
CommandLine cmakeCommand() const;
|
CommandLine cmakeCommand() const;
|
||||||
@@ -41,20 +48,9 @@ private:
|
|||||||
void setupOutputFormatter(OutputFormatter *formatter) override;
|
void setupOutputFormatter(OutputFormatter *formatter) override;
|
||||||
QWidget *createConfigWidget() override;
|
QWidget *createConfigWidget() override;
|
||||||
|
|
||||||
StringAspect *m_cmakeArguments = nullptr;
|
StringAspect cmakeArguments{this};
|
||||||
};
|
};
|
||||||
|
|
||||||
CMakeInstallStep::CMakeInstallStep(BuildStepList *bsl, Id id)
|
|
||||||
: CMakeAbstractProcessStep(bsl, id)
|
|
||||||
{
|
|
||||||
m_cmakeArguments = addAspect<StringAspect>();
|
|
||||||
m_cmakeArguments->setSettingsKey(CMAKE_ARGUMENTS_KEY);
|
|
||||||
m_cmakeArguments->setLabelText(Tr::tr("CMake arguments:"));
|
|
||||||
m_cmakeArguments->setDisplayStyle(StringAspect::LineEditDisplay);
|
|
||||||
|
|
||||||
setCommandLineProvider([this] { return cmakeCommand(); });
|
|
||||||
}
|
|
||||||
|
|
||||||
void CMakeInstallStep::setupOutputFormatter(OutputFormatter *formatter)
|
void CMakeInstallStep::setupOutputFormatter(OutputFormatter *formatter)
|
||||||
{
|
{
|
||||||
CMakeParser *cmakeParser = new CMakeParser;
|
CMakeParser *cmakeParser = new CMakeParser;
|
||||||
@@ -82,8 +78,7 @@ CommandLine CMakeInstallStep::cmakeCommand() const
|
|||||||
cmd.addArg(bs->cmakeBuildType());
|
cmd.addArg(bs->cmakeBuildType());
|
||||||
}
|
}
|
||||||
|
|
||||||
if (!m_cmakeArguments->value().isEmpty())
|
cmd.addArgs(cmakeArguments(), CommandLine::Raw);
|
||||||
cmd.addArgs(m_cmakeArguments->value(), CommandLine::Raw);
|
|
||||||
|
|
||||||
return cmd;
|
return cmd;
|
||||||
}
|
}
|
||||||
@@ -107,11 +102,11 @@ QWidget *CMakeInstallStep::createConfigWidget()
|
|||||||
setDisplayName(Tr::tr("Install", "ConfigWidget display name."));
|
setDisplayName(Tr::tr("Install", "ConfigWidget display name."));
|
||||||
|
|
||||||
using namespace Layouting;
|
using namespace Layouting;
|
||||||
auto widget = Form { m_cmakeArguments, noMargin }.emerge();
|
auto widget = Form { cmakeArguments, noMargin }.emerge();
|
||||||
|
|
||||||
updateDetails();
|
updateDetails();
|
||||||
|
|
||||||
connect(m_cmakeArguments, &StringAspect::changed, this, updateDetails);
|
connect(&cmakeArguments, &StringAspect::changed, this, updateDetails);
|
||||||
|
|
||||||
connect(ProjectExplorerPlugin::instance(),
|
connect(ProjectExplorerPlugin::instance(),
|
||||||
&ProjectExplorerPlugin::settingsChanged,
|
&ProjectExplorerPlugin::settingsChanged,
|
||||||
|
Reference in New Issue
Block a user