forked from qt-creator/qt-creator
Allow overriding make command and specifying parameters
For the generic project manager.
This commit is contained in:
@@ -30,6 +30,7 @@
|
|||||||
#include "genericmakestep.h"
|
#include "genericmakestep.h"
|
||||||
#include "genericprojectconstants.h"
|
#include "genericprojectconstants.h"
|
||||||
#include "genericproject.h"
|
#include "genericproject.h"
|
||||||
|
#include "ui_genericmakestep.h"
|
||||||
|
|
||||||
#include <extensionsystem/pluginmanager.h>
|
#include <extensionsystem/pluginmanager.h>
|
||||||
#include <projectexplorer/toolchain.h>
|
#include <projectexplorer/toolchain.h>
|
||||||
@@ -98,11 +99,21 @@ bool GenericMakeStep::init(const QString &buildConfiguration)
|
|||||||
|
|
||||||
setEnabled(buildConfiguration, true);
|
setEnabled(buildConfiguration, true);
|
||||||
setWorkingDirectory(buildConfiguration, m_pro->buildDirectory(buildConfiguration));
|
setWorkingDirectory(buildConfiguration, m_pro->buildDirectory(buildConfiguration));
|
||||||
|
|
||||||
|
QString command = value(buildConfiguration, "makeCommand").toString();
|
||||||
|
if (command.isEmpty()) {
|
||||||
if (ProjectExplorer::ToolChain *toolChain = m_pro->toolChain())
|
if (ProjectExplorer::ToolChain *toolChain = m_pro->toolChain())
|
||||||
setCommand(buildConfiguration, toolChain->makeCommand());
|
command = toolChain->makeCommand();
|
||||||
else
|
else
|
||||||
setCommand(buildConfiguration, "make");
|
command = QLatin1String("make");
|
||||||
setArguments(buildConfiguration, value(buildConfiguration, "buildTargets").toStringList()); // TODO
|
}
|
||||||
|
setCommand(buildConfiguration, command);
|
||||||
|
|
||||||
|
const QStringList targets = value(buildConfiguration, "buildTargets").toStringList();
|
||||||
|
QStringList arguments = value(buildConfiguration, "makeArguments").toStringList();
|
||||||
|
arguments.append(targets);
|
||||||
|
setArguments(buildConfiguration, arguments);
|
||||||
|
|
||||||
setEnvironment(buildConfiguration, m_pro->environment(buildConfiguration));
|
setEnvironment(buildConfiguration, m_pro->environment(buildConfiguration));
|
||||||
return AbstractProcessStep::init(buildConfiguration);
|
return AbstractProcessStep::init(buildConfiguration);
|
||||||
}
|
}
|
||||||
@@ -231,25 +242,23 @@ void GenericMakeStep::setBuildTarget(const QString &buildConfiguration, const QS
|
|||||||
GenericMakeStepConfigWidget::GenericMakeStepConfigWidget(GenericMakeStep *makeStep)
|
GenericMakeStepConfigWidget::GenericMakeStepConfigWidget(GenericMakeStep *makeStep)
|
||||||
: m_makeStep(makeStep)
|
: m_makeStep(makeStep)
|
||||||
{
|
{
|
||||||
QFormLayout *fl = new QFormLayout(this);
|
m_ui = new Ui::GenericMakeStep;
|
||||||
setLayout(fl);
|
m_ui->setupUi(this);
|
||||||
|
|
||||||
m_targetsList = new QListWidget;
|
|
||||||
fl->addRow("Targets:", m_targetsList);
|
|
||||||
|
|
||||||
// TODO update this list also on rescans of the GenericLists.txt
|
// TODO update this list also on rescans of the GenericLists.txt
|
||||||
GenericProject *pro = m_makeStep->project();
|
GenericProject *pro = m_makeStep->project();
|
||||||
foreach(const QString& target, pro->targets()) {
|
foreach (const QString &target, pro->targets()) {
|
||||||
QListWidgetItem *item = new QListWidgetItem(target, m_targetsList);
|
QListWidgetItem *item = new QListWidgetItem(target, m_ui->targetsList);
|
||||||
item->setFlags(item->flags() | Qt::ItemIsUserCheckable);
|
item->setFlags(item->flags() | Qt::ItemIsUserCheckable);
|
||||||
item->setCheckState(Qt::Unchecked);
|
item->setCheckState(Qt::Unchecked);
|
||||||
}
|
}
|
||||||
connect(m_targetsList, SIGNAL(itemChanged(QListWidgetItem*)), this, SLOT(itemChanged(QListWidgetItem*)));
|
|
||||||
}
|
|
||||||
|
|
||||||
void GenericMakeStepConfigWidget::itemChanged(QListWidgetItem *item)
|
connect(m_ui->targetsList, SIGNAL(itemChanged(QListWidgetItem*)),
|
||||||
{
|
this, SLOT(itemChanged(QListWidgetItem*)));
|
||||||
m_makeStep->setBuildTarget(m_buildConfiguration, item->text(), item->checkState() & Qt::Checked);
|
connect(m_ui->makeLineEdit, SIGNAL(textEdited(const QString&)),
|
||||||
|
this, SLOT(makeLineEditTextEdited()));
|
||||||
|
connect(m_ui->makeArgumentsLineEdit, SIGNAL(textEdited(const QString&)),
|
||||||
|
this, SLOT(makeArgumentsLineEditTextEdited()));
|
||||||
}
|
}
|
||||||
|
|
||||||
QString GenericMakeStepConfigWidget::displayName() const
|
QString GenericMakeStepConfigWidget::displayName() const
|
||||||
@@ -259,18 +268,48 @@ QString GenericMakeStepConfigWidget::displayName() const
|
|||||||
|
|
||||||
void GenericMakeStepConfigWidget::init(const QString &buildConfiguration)
|
void GenericMakeStepConfigWidget::init(const QString &buildConfiguration)
|
||||||
{
|
{
|
||||||
// TODO
|
|
||||||
|
|
||||||
// disconnect to make the changes to the items
|
|
||||||
disconnect(m_targetsList, SIGNAL(itemChanged(QListWidgetItem*)), this, SLOT(itemChanged(QListWidgetItem*)));
|
|
||||||
m_buildConfiguration = buildConfiguration;
|
m_buildConfiguration = buildConfiguration;
|
||||||
int count = m_targetsList->count();
|
|
||||||
for(int i = 0; i < count; ++i) {
|
// TODO: Label should update when tool chain is changed
|
||||||
QListWidgetItem *item = m_targetsList->item(i);
|
m_ui->makeLabel->setText(tr("Override %1:").arg(m_makeStep->command(buildConfiguration)));
|
||||||
|
|
||||||
|
const QString &makeCommand = m_makeStep->value(buildConfiguration, "makeCommand").toString();
|
||||||
|
m_ui->makeLineEdit->setText(makeCommand);
|
||||||
|
|
||||||
|
const QStringList &makeArguments =
|
||||||
|
m_makeStep->value(buildConfiguration, "makeArguments").toStringList();
|
||||||
|
m_ui->makeArgumentsLineEdit->setText(ProjectExplorer::Environment::joinArgumentList(makeArguments));
|
||||||
|
|
||||||
|
// Disconnect to make the changes to the items
|
||||||
|
disconnect(m_ui->targetsList, SIGNAL(itemChanged(QListWidgetItem*)), this, SLOT(itemChanged(QListWidgetItem*)));
|
||||||
|
|
||||||
|
int count = m_ui->targetsList->count();
|
||||||
|
for (int i = 0; i < count; ++i) {
|
||||||
|
QListWidgetItem *item = m_ui->targetsList->item(i);
|
||||||
item->setCheckState(m_makeStep->buildsTarget(buildConfiguration, item->text()) ? Qt::Checked : Qt::Unchecked);
|
item->setCheckState(m_makeStep->buildsTarget(buildConfiguration, item->text()) ? Qt::Checked : Qt::Unchecked);
|
||||||
}
|
}
|
||||||
|
|
||||||
// and connect again
|
// and connect again
|
||||||
connect(m_targetsList, SIGNAL(itemChanged(QListWidgetItem*)), this, SLOT(itemChanged(QListWidgetItem*)));
|
connect(m_ui->targetsList, SIGNAL(itemChanged(QListWidgetItem*)), this, SLOT(itemChanged(QListWidgetItem*)));
|
||||||
|
}
|
||||||
|
|
||||||
|
void GenericMakeStepConfigWidget::itemChanged(QListWidgetItem *item)
|
||||||
|
{
|
||||||
|
QTC_ASSERT(!m_buildConfiguration.isNull(), return);
|
||||||
|
m_makeStep->setBuildTarget(m_buildConfiguration, item->text(), item->checkState() & Qt::Checked);
|
||||||
|
}
|
||||||
|
|
||||||
|
void GenericMakeStepConfigWidget::makeLineEditTextEdited()
|
||||||
|
{
|
||||||
|
QTC_ASSERT(!m_buildConfiguration.isNull(), return);
|
||||||
|
m_makeStep->setValue(m_buildConfiguration, "makeCommand", m_ui->makeLineEdit->text());
|
||||||
|
}
|
||||||
|
|
||||||
|
void GenericMakeStepConfigWidget::makeArgumentsLineEditTextEdited()
|
||||||
|
{
|
||||||
|
QTC_ASSERT(!m_buildConfiguration.isNull(), return);
|
||||||
|
m_makeStep->setValue(m_buildConfiguration, "makeArguments",
|
||||||
|
ProjectExplorer::Environment::parseCombinedArgString(m_ui->makeArgumentsLineEdit->text()));
|
||||||
}
|
}
|
||||||
|
|
||||||
//
|
//
|
||||||
|
|||||||
@@ -27,17 +27,19 @@
|
|||||||
**
|
**
|
||||||
**************************************************************************/
|
**************************************************************************/
|
||||||
|
|
||||||
#ifndef MAKESTEP_H
|
#ifndef GENERICMAKESTEP_H
|
||||||
#define MAKESTEP_H
|
#define GENERICMAKESTEP_H
|
||||||
|
|
||||||
#include <projectexplorer/abstractprocessstep.h>
|
#include <projectexplorer/abstractprocessstep.h>
|
||||||
|
|
||||||
QT_BEGIN_NAMESPACE
|
QT_BEGIN_NAMESPACE
|
||||||
class QLineEdit;
|
|
||||||
class QListWidget;
|
|
||||||
class QListWidgetItem;
|
class QListWidgetItem;
|
||||||
QT_END_NAMESPACE
|
QT_END_NAMESPACE
|
||||||
|
|
||||||
|
namespace Ui {
|
||||||
|
class GenericMakeStep;
|
||||||
|
}
|
||||||
|
|
||||||
namespace GenericProjectManager {
|
namespace GenericProjectManager {
|
||||||
namespace Internal {
|
namespace Internal {
|
||||||
|
|
||||||
@@ -82,10 +84,12 @@ public:
|
|||||||
virtual void init(const QString &buildConfiguration);
|
virtual void init(const QString &buildConfiguration);
|
||||||
private slots:
|
private slots:
|
||||||
void itemChanged(QListWidgetItem*);
|
void itemChanged(QListWidgetItem*);
|
||||||
|
void makeLineEditTextEdited();
|
||||||
|
void makeArgumentsLineEditTextEdited();
|
||||||
private:
|
private:
|
||||||
QString m_buildConfiguration;
|
QString m_buildConfiguration;
|
||||||
|
Ui::GenericMakeStep *m_ui;
|
||||||
GenericMakeStep *m_makeStep;
|
GenericMakeStep *m_makeStep;
|
||||||
QListWidget *m_targetsList;
|
|
||||||
};
|
};
|
||||||
|
|
||||||
class GenericMakeStepFactory : public ProjectExplorer::IBuildStepFactory
|
class GenericMakeStepFactory : public ProjectExplorer::IBuildStepFactory
|
||||||
@@ -99,4 +103,4 @@ class GenericMakeStepFactory : public ProjectExplorer::IBuildStepFactory
|
|||||||
} // namespace Internal
|
} // namespace Internal
|
||||||
} // namespace GenericProjectManager
|
} // namespace GenericProjectManager
|
||||||
|
|
||||||
#endif // MAKESTEP_H
|
#endif // GENERICMAKESTEP_H
|
||||||
|
|||||||
73
src/plugins/genericprojectmanager/genericmakestep.ui
Normal file
73
src/plugins/genericprojectmanager/genericmakestep.ui
Normal file
@@ -0,0 +1,73 @@
|
|||||||
|
<?xml version="1.0" encoding="UTF-8"?>
|
||||||
|
<ui version="4.0">
|
||||||
|
<class>GenericMakeStep</class>
|
||||||
|
<widget class="QWidget" name="GenericMakeStep">
|
||||||
|
<property name="geometry">
|
||||||
|
<rect>
|
||||||
|
<x>0</x>
|
||||||
|
<y>0</y>
|
||||||
|
<width>274</width>
|
||||||
|
<height>392</height>
|
||||||
|
</rect>
|
||||||
|
</property>
|
||||||
|
<property name="windowTitle">
|
||||||
|
<string>Form</string>
|
||||||
|
</property>
|
||||||
|
<layout class="QVBoxLayout" name="verticalLayout">
|
||||||
|
<item>
|
||||||
|
<widget class="QLabel" name="makeLabel">
|
||||||
|
<property name="text">
|
||||||
|
<string>Override %1:</string>
|
||||||
|
</property>
|
||||||
|
<property name="buddy">
|
||||||
|
<cstring>makeLineEdit</cstring>
|
||||||
|
</property>
|
||||||
|
</widget>
|
||||||
|
</item>
|
||||||
|
<item>
|
||||||
|
<widget class="QLineEdit" name="makeLineEdit"/>
|
||||||
|
</item>
|
||||||
|
<item>
|
||||||
|
<widget class="QLabel" name="makeArgumentsLabel">
|
||||||
|
<property name="text">
|
||||||
|
<string>Make arguments:</string>
|
||||||
|
</property>
|
||||||
|
<property name="buddy">
|
||||||
|
<cstring>makeArgumentsLineEdit</cstring>
|
||||||
|
</property>
|
||||||
|
</widget>
|
||||||
|
</item>
|
||||||
|
<item>
|
||||||
|
<widget class="QLineEdit" name="makeArgumentsLineEdit"/>
|
||||||
|
</item>
|
||||||
|
<item>
|
||||||
|
<widget class="QLabel" name="targetsLabel">
|
||||||
|
<property name="text">
|
||||||
|
<string>Targets:</string>
|
||||||
|
</property>
|
||||||
|
<property name="buddy">
|
||||||
|
<cstring>targetsList</cstring>
|
||||||
|
</property>
|
||||||
|
</widget>
|
||||||
|
</item>
|
||||||
|
<item>
|
||||||
|
<widget class="QListWidget" name="targetsList"/>
|
||||||
|
</item>
|
||||||
|
<item>
|
||||||
|
<spacer name="verticalSpacer">
|
||||||
|
<property name="orientation">
|
||||||
|
<enum>Qt::Vertical</enum>
|
||||||
|
</property>
|
||||||
|
<property name="sizeHint" stdset="0">
|
||||||
|
<size>
|
||||||
|
<width>20</width>
|
||||||
|
<height>40</height>
|
||||||
|
</size>
|
||||||
|
</property>
|
||||||
|
</spacer>
|
||||||
|
</item>
|
||||||
|
</layout>
|
||||||
|
</widget>
|
||||||
|
<resources/>
|
||||||
|
<connections/>
|
||||||
|
</ui>
|
||||||
@@ -20,3 +20,4 @@ SOURCES = genericproject.cpp \
|
|||||||
pkgconfigtool.cpp \
|
pkgconfigtool.cpp \
|
||||||
genericmakestep.cpp
|
genericmakestep.cpp
|
||||||
RESOURCES += genericproject.qrc
|
RESOURCES += genericproject.qrc
|
||||||
|
FORMS += genericmakestep.ui
|
||||||
|
|||||||
Reference in New Issue
Block a user