forked from qt-creator/qt-creator
Add a comand line editor for environment variables
Task-number: QTCREATORBUG-6499 Change-Id: I43df7bddd10776e0fdb192c668ab0d99a6fea7e6 Reviewed-by: Daniel Teske <daniel.teske@nokia.com> Reviewed-by: hjk <qthjk@ovi.com>
This commit is contained in:
@@ -38,6 +38,16 @@
|
|||||||
|
|
||||||
namespace Utils {
|
namespace Utils {
|
||||||
|
|
||||||
|
static bool sortEnvironmentItem(const EnvironmentItem &a, const EnvironmentItem &b)
|
||||||
|
{
|
||||||
|
return a.name < b.name;
|
||||||
|
}
|
||||||
|
|
||||||
|
void EnvironmentItem::sort(QList<EnvironmentItem> *list)
|
||||||
|
{
|
||||||
|
qSort(list->begin(), list->end(), &sortEnvironmentItem);
|
||||||
|
}
|
||||||
|
|
||||||
QList<EnvironmentItem> EnvironmentItem::fromStringList(const QStringList &list)
|
QList<EnvironmentItem> EnvironmentItem::fromStringList(const QStringList &list)
|
||||||
{
|
{
|
||||||
QList<EnvironmentItem> result;
|
QList<EnvironmentItem> result;
|
||||||
|
|||||||
@@ -58,6 +58,7 @@ public:
|
|||||||
return unset == other.unset && name == other.name && value == other.value;
|
return unset == other.unset && name == other.name && value == other.value;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static void sort(QList<EnvironmentItem> *list);
|
||||||
static QList<EnvironmentItem> fromStringList(const QStringList &list);
|
static QList<EnvironmentItem> fromStringList(const QStringList &list);
|
||||||
static QStringList toStringList(const QList<EnvironmentItem> &list);
|
static QStringList toStringList(const QList<EnvironmentItem> &list);
|
||||||
};
|
};
|
||||||
|
|||||||
@@ -366,6 +366,7 @@ void EnvironmentModel::setUserChanges(QList<Utils::EnvironmentItem> list)
|
|||||||
d->m_items = list;
|
d->m_items = list;
|
||||||
d->updateResultEnvironment();
|
d->updateResultEnvironment();
|
||||||
endResetModel();
|
endResetModel();
|
||||||
|
emit userChangesChanged();
|
||||||
}
|
}
|
||||||
|
|
||||||
} // namespace Utils
|
} // namespace Utils
|
||||||
|
|||||||
154
src/plugins/projectexplorer/environmentitemswidget.cpp
Normal file
154
src/plugins/projectexplorer/environmentitemswidget.cpp
Normal file
@@ -0,0 +1,154 @@
|
|||||||
|
/**************************************************************************
|
||||||
|
**
|
||||||
|
** This file is part of Qt Creator
|
||||||
|
**
|
||||||
|
** Copyright (c) 2011 Nokia Corporation and/or its subsidiary(-ies).
|
||||||
|
**
|
||||||
|
** Contact: Nokia Corporation (qt-info@nokia.com)
|
||||||
|
**
|
||||||
|
**
|
||||||
|
** GNU Lesser General Public License Usage
|
||||||
|
**
|
||||||
|
** 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, Nokia gives you certain additional
|
||||||
|
** rights. These rights are described in the Nokia Qt LGPL Exception
|
||||||
|
** version 1.1, included in the file LGPL_EXCEPTION.txt in this package.
|
||||||
|
**
|
||||||
|
** Other Usage
|
||||||
|
**
|
||||||
|
** Alternatively, this file may be used in accordance with the terms and
|
||||||
|
** conditions contained in a signed written agreement between you and Nokia.
|
||||||
|
**
|
||||||
|
** If you have questions regarding the use of this file, please contact
|
||||||
|
** Nokia at qt-info@nokia.com.
|
||||||
|
**
|
||||||
|
**************************************************************************/
|
||||||
|
|
||||||
|
#include "environmentitemswidget.h"
|
||||||
|
|
||||||
|
#include <utils/environment.h>
|
||||||
|
#include <texteditor/snippets/snippeteditor.h>
|
||||||
|
#include <texteditor/texteditorsettings.h>
|
||||||
|
|
||||||
|
#include <QtGui/QVBoxLayout>
|
||||||
|
#include <QtGui/QDialogButtonBox>
|
||||||
|
|
||||||
|
namespace ProjectExplorer {
|
||||||
|
|
||||||
|
class EnvironmentItemsWidgetPrivate
|
||||||
|
{
|
||||||
|
public:
|
||||||
|
QList<Utils::EnvironmentItem> cleanUp(
|
||||||
|
const QList<Utils::EnvironmentItem> &items) const;
|
||||||
|
TextEditor::BaseTextEditorWidget *m_editor;
|
||||||
|
};
|
||||||
|
|
||||||
|
QList<Utils::EnvironmentItem> EnvironmentItemsWidgetPrivate::cleanUp(
|
||||||
|
const QList<Utils::EnvironmentItem> &items) const
|
||||||
|
{
|
||||||
|
QList<Utils::EnvironmentItem> uniqueItems;
|
||||||
|
QSet<QString> uniqueSet;
|
||||||
|
for (int i = items.count() - 1; i >= 0; i--) {
|
||||||
|
Utils::EnvironmentItem item = items.at(i);
|
||||||
|
#if defined(Q_OS_WIN)
|
||||||
|
item.name = item.name.toUpper();
|
||||||
|
#endif
|
||||||
|
const QString &itemName = item.name;
|
||||||
|
QString emptyName = itemName;
|
||||||
|
emptyName.remove(QLatin1Char(' '));
|
||||||
|
if (!emptyName.isEmpty() && !uniqueSet.contains(itemName)) {
|
||||||
|
uniqueItems.prepend(item);
|
||||||
|
uniqueSet.insert(itemName);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return uniqueItems;
|
||||||
|
}
|
||||||
|
|
||||||
|
EnvironmentItemsWidget::EnvironmentItemsWidget(QWidget *parent) :
|
||||||
|
QWidget(parent), d(new EnvironmentItemsWidgetPrivate)
|
||||||
|
{
|
||||||
|
d->m_editor = new TextEditor::SnippetEditorWidget(this);
|
||||||
|
TextEditor::TextEditorSettings *settings = TextEditor::TextEditorSettings::instance();
|
||||||
|
d->m_editor->setFontSettings(settings->fontSettings());
|
||||||
|
QVBoxLayout *layout = new QVBoxLayout(this);
|
||||||
|
layout->addWidget(d->m_editor);
|
||||||
|
}
|
||||||
|
|
||||||
|
EnvironmentItemsWidget::~EnvironmentItemsWidget()
|
||||||
|
{
|
||||||
|
delete d;
|
||||||
|
}
|
||||||
|
|
||||||
|
void EnvironmentItemsWidget::setEnvironmentItems(const QList<Utils::EnvironmentItem> &items)
|
||||||
|
{
|
||||||
|
QList<Utils::EnvironmentItem> sortedItems = items;
|
||||||
|
Utils::EnvironmentItem::sort(&sortedItems);
|
||||||
|
QStringList list = Utils::EnvironmentItem::toStringList(sortedItems);
|
||||||
|
d->m_editor->document()->setPlainText(list.join(QLatin1String("\n")));
|
||||||
|
}
|
||||||
|
|
||||||
|
QList<Utils::EnvironmentItem> EnvironmentItemsWidget::environmentItems() const
|
||||||
|
{
|
||||||
|
const QStringList list = d->m_editor->document()->toPlainText().split(QLatin1String("\n"));
|
||||||
|
QList<Utils::EnvironmentItem> items = Utils::EnvironmentItem::fromStringList(list);
|
||||||
|
return d->cleanUp(items);
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
class EnvironmentItemsDialogPrivate
|
||||||
|
{
|
||||||
|
public:
|
||||||
|
EnvironmentItemsWidget *m_editor;
|
||||||
|
};
|
||||||
|
|
||||||
|
EnvironmentItemsDialog::EnvironmentItemsDialog(QWidget *parent) :
|
||||||
|
QDialog(parent), d(new EnvironmentItemsDialogPrivate)
|
||||||
|
{
|
||||||
|
resize(640, 480);
|
||||||
|
d->m_editor = new EnvironmentItemsWidget(this);
|
||||||
|
QDialogButtonBox *box = new QDialogButtonBox(
|
||||||
|
QDialogButtonBox::Ok | QDialogButtonBox::Cancel, Qt::Horizontal, this);
|
||||||
|
connect(box, SIGNAL(accepted()), this, SLOT(accept()));
|
||||||
|
connect(box, SIGNAL(rejected()), this, SLOT(reject()));
|
||||||
|
QVBoxLayout *layout = new QVBoxLayout(this);
|
||||||
|
layout->addWidget(d->m_editor);
|
||||||
|
layout->addWidget(box);
|
||||||
|
setWindowTitle(tr("Edit Environment"));
|
||||||
|
}
|
||||||
|
|
||||||
|
EnvironmentItemsDialog::~EnvironmentItemsDialog()
|
||||||
|
{
|
||||||
|
delete d;
|
||||||
|
}
|
||||||
|
|
||||||
|
void EnvironmentItemsDialog::setEnvironmentItems(const QList<Utils::EnvironmentItem> &items)
|
||||||
|
{
|
||||||
|
d->m_editor->setEnvironmentItems(items);
|
||||||
|
}
|
||||||
|
|
||||||
|
QList<Utils::EnvironmentItem> EnvironmentItemsDialog::environmentItems() const
|
||||||
|
{
|
||||||
|
return d->m_editor->environmentItems();
|
||||||
|
}
|
||||||
|
|
||||||
|
QList<Utils::EnvironmentItem> EnvironmentItemsDialog::getEnvironmentItems(QWidget *parent,
|
||||||
|
const QList<Utils::EnvironmentItem> &initial, bool *ok)
|
||||||
|
{
|
||||||
|
EnvironmentItemsDialog dlg(parent);
|
||||||
|
dlg.setEnvironmentItems(initial);
|
||||||
|
bool result = dlg.exec() == QDialog::Accepted;
|
||||||
|
if (ok)
|
||||||
|
*ok = result;
|
||||||
|
if (result)
|
||||||
|
return dlg.environmentItems();
|
||||||
|
return QList<Utils::EnvironmentItem>();
|
||||||
|
}
|
||||||
|
|
||||||
|
} // namespace ProjectExplorer
|
||||||
81
src/plugins/projectexplorer/environmentitemswidget.h
Normal file
81
src/plugins/projectexplorer/environmentitemswidget.h
Normal file
@@ -0,0 +1,81 @@
|
|||||||
|
/**************************************************************************
|
||||||
|
**
|
||||||
|
** This file is part of Qt Creator
|
||||||
|
**
|
||||||
|
** Copyright (c) 2011 Nokia Corporation and/or its subsidiary(-ies).
|
||||||
|
**
|
||||||
|
** Contact: Nokia Corporation (qt-info@nokia.com)
|
||||||
|
**
|
||||||
|
**
|
||||||
|
** GNU Lesser General Public License Usage
|
||||||
|
**
|
||||||
|
** 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, Nokia gives you certain additional
|
||||||
|
** rights. These rights are described in the Nokia Qt LGPL Exception
|
||||||
|
** version 1.1, included in the file LGPL_EXCEPTION.txt in this package.
|
||||||
|
**
|
||||||
|
** Other Usage
|
||||||
|
**
|
||||||
|
** Alternatively, this file may be used in accordance with the terms and
|
||||||
|
** conditions contained in a signed written agreement between you and Nokia.
|
||||||
|
**
|
||||||
|
** If you have questions regarding the use of this file, please contact
|
||||||
|
** Nokia at qt-info@nokia.com.
|
||||||
|
**
|
||||||
|
**************************************************************************/
|
||||||
|
|
||||||
|
#ifndef ENVIRONMENTITEMSWIDGET_H
|
||||||
|
#define ENVIRONMENTITEMSWIDGET_H
|
||||||
|
|
||||||
|
#include <QDialog>
|
||||||
|
|
||||||
|
namespace Utils {
|
||||||
|
class EnvironmentItem;
|
||||||
|
}
|
||||||
|
|
||||||
|
namespace ProjectExplorer {
|
||||||
|
class EnvironmentItemsWidgetPrivate;
|
||||||
|
|
||||||
|
class EnvironmentItemsWidget : public QWidget
|
||||||
|
{
|
||||||
|
Q_OBJECT
|
||||||
|
public:
|
||||||
|
explicit EnvironmentItemsWidget(QWidget *parent = 0);
|
||||||
|
~EnvironmentItemsWidget();
|
||||||
|
|
||||||
|
void setEnvironmentItems(const QList<Utils::EnvironmentItem> &items);
|
||||||
|
QList<Utils::EnvironmentItem> environmentItems() const;
|
||||||
|
|
||||||
|
private:
|
||||||
|
EnvironmentItemsWidgetPrivate *d;
|
||||||
|
};
|
||||||
|
|
||||||
|
|
||||||
|
class EnvironmentItemsDialogPrivate;
|
||||||
|
|
||||||
|
class EnvironmentItemsDialog : public QDialog
|
||||||
|
{
|
||||||
|
Q_OBJECT
|
||||||
|
public:
|
||||||
|
explicit EnvironmentItemsDialog(QWidget *parent = 0);
|
||||||
|
~EnvironmentItemsDialog();
|
||||||
|
|
||||||
|
void setEnvironmentItems(const QList<Utils::EnvironmentItem> &items);
|
||||||
|
QList<Utils::EnvironmentItem> environmentItems() const;
|
||||||
|
|
||||||
|
static QList<Utils::EnvironmentItem> getEnvironmentItems(QWidget *parent,
|
||||||
|
const QList<Utils::EnvironmentItem> &initial, bool *ok = 0);
|
||||||
|
|
||||||
|
private:
|
||||||
|
EnvironmentItemsDialogPrivate *d;
|
||||||
|
};
|
||||||
|
|
||||||
|
} // namespace ProjectExplorer
|
||||||
|
|
||||||
|
#endif // ENVIRONMENTITEMSWIDGET_H
|
||||||
@@ -31,6 +31,7 @@
|
|||||||
**************************************************************************/
|
**************************************************************************/
|
||||||
|
|
||||||
#include "environmentwidget.h"
|
#include "environmentwidget.h"
|
||||||
|
#include "environmentitemswidget.h"
|
||||||
|
|
||||||
#include <utils/detailswidget.h>
|
#include <utils/detailswidget.h>
|
||||||
#include <utils/environment.h>
|
#include <utils/environment.h>
|
||||||
@@ -61,6 +62,7 @@ public:
|
|||||||
QPushButton *m_addButton;
|
QPushButton *m_addButton;
|
||||||
QPushButton *m_resetButton;
|
QPushButton *m_resetButton;
|
||||||
QPushButton *m_unsetButton;
|
QPushButton *m_unsetButton;
|
||||||
|
QPushButton *m_batchEditButton;
|
||||||
};
|
};
|
||||||
|
|
||||||
EnvironmentWidget::EnvironmentWidget(QWidget *parent, QWidget *additionalDetailsWidget)
|
EnvironmentWidget::EnvironmentWidget(QWidget *parent, QWidget *additionalDetailsWidget)
|
||||||
@@ -127,6 +129,11 @@ EnvironmentWidget::EnvironmentWidget(QWidget *parent, QWidget *additionalDetails
|
|||||||
|
|
||||||
QSpacerItem *verticalSpacer = new QSpacerItem(20, 40, QSizePolicy::Minimum, QSizePolicy::Expanding);
|
QSpacerItem *verticalSpacer = new QSpacerItem(20, 40, QSizePolicy::Minimum, QSizePolicy::Expanding);
|
||||||
buttonLayout->addItem(verticalSpacer);
|
buttonLayout->addItem(verticalSpacer);
|
||||||
|
|
||||||
|
d->m_batchEditButton = new QPushButton(this);
|
||||||
|
d->m_batchEditButton->setText(tr("&Batch Edit..."));
|
||||||
|
buttonLayout->addWidget(d->m_batchEditButton);
|
||||||
|
|
||||||
horizontalLayout->addLayout(buttonLayout);
|
horizontalLayout->addLayout(buttonLayout);
|
||||||
vbox2->addLayout(horizontalLayout);
|
vbox2->addLayout(horizontalLayout);
|
||||||
|
|
||||||
@@ -143,6 +150,8 @@ EnvironmentWidget::EnvironmentWidget(QWidget *parent, QWidget *additionalDetails
|
|||||||
this, SLOT(removeEnvironmentButtonClicked()));
|
this, SLOT(removeEnvironmentButtonClicked()));
|
||||||
connect(d->m_unsetButton, SIGNAL(clicked(bool)),
|
connect(d->m_unsetButton, SIGNAL(clicked(bool)),
|
||||||
this, SLOT(unsetEnvironmentButtonClicked()));
|
this, SLOT(unsetEnvironmentButtonClicked()));
|
||||||
|
connect(d->m_batchEditButton, SIGNAL(clicked(bool)),
|
||||||
|
this, SLOT(batchEditEnvironmentButtonClicked()));
|
||||||
connect(d->m_environmentView->selectionModel(), SIGNAL(currentChanged(QModelIndex,QModelIndex)),
|
connect(d->m_environmentView->selectionModel(), SIGNAL(currentChanged(QModelIndex,QModelIndex)),
|
||||||
this, SLOT(environmentCurrentIndexChanged(QModelIndex)));
|
this, SLOT(environmentCurrentIndexChanged(QModelIndex)));
|
||||||
|
|
||||||
@@ -187,15 +196,10 @@ void EnvironmentWidget::setUserChanges(const QList<Utils::EnvironmentItem> &list
|
|||||||
updateSummaryText();
|
updateSummaryText();
|
||||||
}
|
}
|
||||||
|
|
||||||
bool sortEnvironmentItem(const Utils::EnvironmentItem &a, const Utils::EnvironmentItem &b)
|
|
||||||
{
|
|
||||||
return a.name < b.name;
|
|
||||||
}
|
|
||||||
|
|
||||||
void EnvironmentWidget::updateSummaryText()
|
void EnvironmentWidget::updateSummaryText()
|
||||||
{
|
{
|
||||||
QList<Utils::EnvironmentItem> list = d->m_model->userChanges();
|
QList<Utils::EnvironmentItem> list = d->m_model->userChanges();
|
||||||
qSort(list.begin(), list.end(), &sortEnvironmentItem);
|
Utils::EnvironmentItem::sort(&list);
|
||||||
|
|
||||||
QString text;
|
QString text;
|
||||||
foreach (const Utils::EnvironmentItem &item, list) {
|
foreach (const Utils::EnvironmentItem &item, list) {
|
||||||
@@ -261,6 +265,16 @@ void EnvironmentWidget::unsetEnvironmentButtonClicked()
|
|||||||
d->m_model->unsetVariable(name);
|
d->m_model->unsetVariable(name);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void EnvironmentWidget::batchEditEnvironmentButtonClicked()
|
||||||
|
{
|
||||||
|
const QList<Utils::EnvironmentItem> changes = d->m_model->userChanges();
|
||||||
|
|
||||||
|
bool ok;
|
||||||
|
const QList<Utils::EnvironmentItem> newChanges = EnvironmentItemsDialog::getEnvironmentItems(this, changes, &ok);
|
||||||
|
if (ok)
|
||||||
|
d->m_model->setUserChanges(newChanges);
|
||||||
|
}
|
||||||
|
|
||||||
void EnvironmentWidget::environmentCurrentIndexChanged(const QModelIndex ¤t)
|
void EnvironmentWidget::environmentCurrentIndexChanged(const QModelIndex ¤t)
|
||||||
{
|
{
|
||||||
if (current.isValid()) {
|
if (current.isValid()) {
|
||||||
|
|||||||
@@ -70,6 +70,7 @@ private slots:
|
|||||||
void addEnvironmentButtonClicked();
|
void addEnvironmentButtonClicked();
|
||||||
void removeEnvironmentButtonClicked();
|
void removeEnvironmentButtonClicked();
|
||||||
void unsetEnvironmentButtonClicked();
|
void unsetEnvironmentButtonClicked();
|
||||||
|
void batchEditEnvironmentButtonClicked();
|
||||||
void environmentCurrentIndexChanged(const QModelIndex ¤t);
|
void environmentCurrentIndexChanged(const QModelIndex ¤t);
|
||||||
void invalidateCurrentIndex();
|
void invalidateCurrentIndex();
|
||||||
void updateSummaryText();
|
void updateSummaryText();
|
||||||
|
|||||||
@@ -102,7 +102,8 @@ HEADERS += projectexplorer.h \
|
|||||||
gcctoolchainfactories.h \
|
gcctoolchainfactories.h \
|
||||||
appoutputpane.h \
|
appoutputpane.h \
|
||||||
codestylesettingspropertiespage.h \
|
codestylesettingspropertiespage.h \
|
||||||
settingsaccessor.h
|
settingsaccessor.h \
|
||||||
|
environmentitemswidget.h
|
||||||
|
|
||||||
SOURCES += projectexplorer.cpp \
|
SOURCES += projectexplorer.cpp \
|
||||||
abi.cpp \
|
abi.cpp \
|
||||||
@@ -188,7 +189,8 @@ SOURCES += projectexplorer.cpp \
|
|||||||
publishing/publishingwizardselectiondialog.cpp \
|
publishing/publishingwizardselectiondialog.cpp \
|
||||||
appoutputpane.cpp \
|
appoutputpane.cpp \
|
||||||
codestylesettingspropertiespage.cpp \
|
codestylesettingspropertiespage.cpp \
|
||||||
settingsaccessor.cpp
|
settingsaccessor.cpp \
|
||||||
|
environmentitemswidget.cpp
|
||||||
|
|
||||||
FORMS += processstep.ui \
|
FORMS += processstep.ui \
|
||||||
toolchainoptionspage.ui \
|
toolchainoptionspage.ui \
|
||||||
|
|||||||
Reference in New Issue
Block a user