forked from qt-creator/qt-creator
Rewrite the preference page's tree, using its own model.
Because otherwise implementing drag&drop is impossible.
This commit is contained in:
@@ -46,16 +46,282 @@
|
|||||||
using namespace Core;
|
using namespace Core;
|
||||||
using namespace Core::Internal;
|
using namespace Core::Internal;
|
||||||
|
|
||||||
|
|
||||||
|
static const Qt::ItemFlags TOOLSMENU_ITEM_FLAGS = Qt::ItemIsSelectable | Qt::ItemIsEnabled | Qt::ItemIsDropEnabled;
|
||||||
|
static const Qt::ItemFlags CATEGORY_ITEM_FLAGS = Qt::ItemIsSelectable | Qt::ItemIsEnabled | Qt::ItemIsDropEnabled | Qt::ItemIsEditable;
|
||||||
|
static const Qt::ItemFlags TOOL_ITEM_FLAGS = Qt::ItemIsSelectable | Qt::ItemIsEnabled | Qt::ItemIsDragEnabled | Qt::ItemIsDropEnabled | Qt::ItemIsEditable;
|
||||||
|
|
||||||
|
// #pragma mark -- ExternalToolModel
|
||||||
|
|
||||||
|
ExternalToolModel::ExternalToolModel(QObject *parent)
|
||||||
|
: QAbstractItemModel(parent)
|
||||||
|
{
|
||||||
|
}
|
||||||
|
|
||||||
|
ExternalToolModel::~ExternalToolModel()
|
||||||
|
{
|
||||||
|
QMapIterator<QString, QList<ExternalTool *> > it(m_tools);
|
||||||
|
while (it.hasNext()) {
|
||||||
|
it.next();
|
||||||
|
qDeleteAll(it.value());
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
int ExternalToolModel::columnCount(const QModelIndex &parent) const
|
||||||
|
{
|
||||||
|
if (!parent.isValid() || toolForIndex(parent) || !categoryForIndex(parent).isNull())
|
||||||
|
return 1;
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
QVariant ExternalToolModel::data(const QModelIndex &index, int role) const
|
||||||
|
{
|
||||||
|
if (ExternalTool *tool = toolForIndex(index))
|
||||||
|
return data(tool, role);
|
||||||
|
QString category = categoryForIndex(index);
|
||||||
|
if (!category.isNull())
|
||||||
|
return data(category, role);
|
||||||
|
return QVariant();
|
||||||
|
}
|
||||||
|
|
||||||
|
QVariant ExternalToolModel::data(ExternalTool *tool, int role) const
|
||||||
|
{
|
||||||
|
switch (role) {
|
||||||
|
case Qt::DisplayRole:
|
||||||
|
case Qt::EditRole:
|
||||||
|
return tool->displayName();
|
||||||
|
default:
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
return QVariant();
|
||||||
|
}
|
||||||
|
|
||||||
|
QVariant ExternalToolModel::data(const QString &category, int role) const
|
||||||
|
{
|
||||||
|
switch (role) {
|
||||||
|
case Qt::DisplayRole:
|
||||||
|
case Qt::EditRole:
|
||||||
|
return category.isEmpty() ? tr("External Tools Menu") : category;
|
||||||
|
default:
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
return QVariant();
|
||||||
|
}
|
||||||
|
|
||||||
|
QModelIndex ExternalToolModel::index(int row, int column, const QModelIndex &parent) const
|
||||||
|
{
|
||||||
|
if (column == 0 && parent.isValid()) {
|
||||||
|
QString category = categoryForIndex(parent);
|
||||||
|
if (!category.isNull()) {
|
||||||
|
QList<ExternalTool *> items = m_tools.value(category);
|
||||||
|
if (row < items.count()) {
|
||||||
|
return createIndex(row, 0, items.at(row));
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return createIndex(row, column);
|
||||||
|
}
|
||||||
|
|
||||||
|
QModelIndex ExternalToolModel::parent(const QModelIndex &child) const
|
||||||
|
{
|
||||||
|
if (ExternalTool *tool = toolForIndex(child)) {
|
||||||
|
int categoryIndex = 0;
|
||||||
|
QMapIterator<QString, QList<ExternalTool *> > it(m_tools);
|
||||||
|
while (it.hasNext()) {
|
||||||
|
it.next();
|
||||||
|
if (it.value().contains(tool))
|
||||||
|
return index(categoryIndex, 0);
|
||||||
|
++categoryIndex;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return QModelIndex();
|
||||||
|
}
|
||||||
|
|
||||||
|
int ExternalToolModel::rowCount(const QModelIndex &parent) const
|
||||||
|
{
|
||||||
|
if (!parent.isValid())
|
||||||
|
return m_tools.keys().count();
|
||||||
|
if (toolForIndex(parent)) {
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
QString category = categoryForIndex(parent);
|
||||||
|
if (!category.isNull()) {
|
||||||
|
return m_tools.value(category).count();
|
||||||
|
}
|
||||||
|
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
Qt::ItemFlags ExternalToolModel::flags(const QModelIndex &index) const
|
||||||
|
{
|
||||||
|
if (toolForIndex(index))
|
||||||
|
return TOOL_ITEM_FLAGS;
|
||||||
|
QString category = categoryForIndex(index);
|
||||||
|
if (!category.isNull()) {
|
||||||
|
if (category.isEmpty())
|
||||||
|
return TOOLSMENU_ITEM_FLAGS;
|
||||||
|
return CATEGORY_ITEM_FLAGS;
|
||||||
|
}
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
bool ExternalToolModel::setData(const QModelIndex &modelIndex, const QVariant &value, int role)
|
||||||
|
{
|
||||||
|
if (role != Qt::EditRole)
|
||||||
|
return false;
|
||||||
|
QString string = value.toString();
|
||||||
|
if (ExternalTool *tool = toolForIndex(modelIndex)) {
|
||||||
|
if (string.isEmpty() || tool->displayName() == string)
|
||||||
|
return false;
|
||||||
|
// rename tool
|
||||||
|
tool->setDisplayName(string);
|
||||||
|
emit dataChanged(modelIndex, modelIndex);
|
||||||
|
return true;
|
||||||
|
} else {
|
||||||
|
QString category = categoryForIndex(modelIndex);
|
||||||
|
if (!category.isNull()) {
|
||||||
|
if (string.isEmpty() || m_tools.contains(string))
|
||||||
|
return false;
|
||||||
|
// rename category
|
||||||
|
QList<QString> categories = m_tools.keys();
|
||||||
|
int previousIndex = categories.indexOf(category);
|
||||||
|
categories.append(string);
|
||||||
|
qSort(categories);
|
||||||
|
int newIndex = categories.indexOf(string);
|
||||||
|
beginMoveRows(QModelIndex(), previousIndex, previousIndex, QModelIndex(), newIndex);
|
||||||
|
QList<ExternalTool *> items = m_tools.take(category);
|
||||||
|
m_tools.insert(string, items);
|
||||||
|
endMoveRows();
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
void ExternalToolModel::setTools(const QMap<QString, QList<ExternalTool *> > &tools)
|
||||||
|
{
|
||||||
|
beginResetModel();
|
||||||
|
m_tools = tools;
|
||||||
|
endResetModel();
|
||||||
|
}
|
||||||
|
|
||||||
|
QMap<QString, QList<ExternalTool *> > ExternalToolModel::tools() const
|
||||||
|
{
|
||||||
|
return m_tools;
|
||||||
|
}
|
||||||
|
|
||||||
|
ExternalTool *ExternalToolModel::toolForIndex(const QModelIndex &index) const
|
||||||
|
{
|
||||||
|
return static_cast<ExternalTool *>(index.internalPointer());
|
||||||
|
}
|
||||||
|
|
||||||
|
QString ExternalToolModel::categoryForIndex(const QModelIndex &index) const
|
||||||
|
{
|
||||||
|
if (index.isValid() && !index.parent().isValid() && index.column() == 0 && index.row() >= 0) {
|
||||||
|
const QList<QString> &keys = m_tools.keys();
|
||||||
|
if (index.row() < keys.count())
|
||||||
|
return keys.at(index.row());
|
||||||
|
}
|
||||||
|
return QString();
|
||||||
|
}
|
||||||
|
|
||||||
|
void ExternalToolModel::revertTool(const QModelIndex &modelIndex)
|
||||||
|
{
|
||||||
|
ExternalTool *tool = toolForIndex(modelIndex);
|
||||||
|
QTC_ASSERT(tool, return);
|
||||||
|
QTC_ASSERT(tool->preset() && !tool->preset()->fileName().isEmpty(), return);
|
||||||
|
ExternalTool *resetTool = new ExternalTool(tool->preset().data());
|
||||||
|
resetTool->setPreset(tool->preset());
|
||||||
|
(*tool) = (*resetTool);
|
||||||
|
delete resetTool;
|
||||||
|
emit dataChanged(modelIndex, modelIndex);
|
||||||
|
}
|
||||||
|
|
||||||
|
QModelIndex ExternalToolModel::addCategory()
|
||||||
|
{
|
||||||
|
const QString &categoryBase = tr("New category");
|
||||||
|
QString category = categoryBase;
|
||||||
|
int count = 0;
|
||||||
|
while (m_tools.contains(category)) {
|
||||||
|
++count;
|
||||||
|
category = categoryBase + QString::number(count);
|
||||||
|
}
|
||||||
|
QList<QString> categories = m_tools.keys();
|
||||||
|
categories.append(category);
|
||||||
|
qSort(categories);
|
||||||
|
int pos = categories.indexOf(category);
|
||||||
|
|
||||||
|
beginInsertRows(QModelIndex(), pos, pos);
|
||||||
|
m_tools.insert(category, QList<ExternalTool *>());
|
||||||
|
endInsertRows();
|
||||||
|
return index(pos, 0);
|
||||||
|
}
|
||||||
|
|
||||||
|
QModelIndex ExternalToolModel::addTool(const QModelIndex &atIndex)
|
||||||
|
{
|
||||||
|
QString category = categoryForIndex(atIndex);
|
||||||
|
if (category.isNull())
|
||||||
|
category = categoryForIndex(atIndex.parent());
|
||||||
|
|
||||||
|
ExternalTool *tool = new ExternalTool;
|
||||||
|
tool->setCategory(category);
|
||||||
|
tool->setDisplayName(tr("New tool"));
|
||||||
|
tool->setDescription(tr("This tool prints a line of useful text"));
|
||||||
|
tool->setExecutables(QStringList() << "echo");
|
||||||
|
tool->setArguments(tr("Useful text"));
|
||||||
|
|
||||||
|
int pos;
|
||||||
|
QModelIndex parent;
|
||||||
|
if (atIndex.parent().isValid()) {
|
||||||
|
pos = atIndex.row() + 1;
|
||||||
|
parent = atIndex.parent();
|
||||||
|
} else {
|
||||||
|
pos = m_tools.value(category).count();
|
||||||
|
parent = atIndex;
|
||||||
|
}
|
||||||
|
beginInsertRows(parent, pos, pos);
|
||||||
|
m_tools[category].insert(pos, tool);
|
||||||
|
endInsertRows();
|
||||||
|
return index(pos, 0, parent);
|
||||||
|
}
|
||||||
|
|
||||||
|
void ExternalToolModel::removeTool(const QModelIndex &modelIndex)
|
||||||
|
{
|
||||||
|
ExternalTool *tool = toolForIndex(modelIndex);
|
||||||
|
QTC_ASSERT(tool, return);
|
||||||
|
QTC_ASSERT(!tool->preset(), return);
|
||||||
|
// remove the tool and the tree item
|
||||||
|
int categoryIndex = 0;
|
||||||
|
QMutableMapIterator<QString, QList<ExternalTool *> > it(m_tools);
|
||||||
|
while (it.hasNext()) {
|
||||||
|
it.next();
|
||||||
|
QList<ExternalTool *> &items = it.value();
|
||||||
|
int pos = items.indexOf(tool);
|
||||||
|
if (pos != -1) {
|
||||||
|
beginRemoveRows(index(categoryIndex, 0), pos, pos);
|
||||||
|
items.removeAt(pos);
|
||||||
|
endRemoveRows();
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
++categoryIndex;
|
||||||
|
}
|
||||||
|
delete tool;
|
||||||
|
}
|
||||||
|
|
||||||
|
// #pragma mark -- ExternalToolConfig
|
||||||
|
|
||||||
ExternalToolConfig::ExternalToolConfig(QWidget *parent) :
|
ExternalToolConfig::ExternalToolConfig(QWidget *parent) :
|
||||||
QWidget(parent),
|
QWidget(parent),
|
||||||
ui(new Ui::ExternalToolConfig)
|
ui(new Ui::ExternalToolConfig),
|
||||||
|
m_model(new ExternalToolModel(this))
|
||||||
{
|
{
|
||||||
ui->setupUi(this);
|
ui->setupUi(this);
|
||||||
|
ui->toolTree->setModel(m_model);
|
||||||
ui->toolTree->setEditTriggers(QAbstractItemView::DoubleClicked | QAbstractItemView::EditKeyPressed);
|
ui->toolTree->setEditTriggers(QAbstractItemView::DoubleClicked | QAbstractItemView::EditKeyPressed);
|
||||||
connect(ui->toolTree, SIGNAL(currentItemChanged(QTreeWidgetItem*,QTreeWidgetItem*)),
|
|
||||||
this, SLOT(handleCurrentItemChanged(QTreeWidgetItem*,QTreeWidgetItem*)));
|
connect(ui->toolTree->selectionModel(), SIGNAL(currentChanged(QModelIndex,QModelIndex)),
|
||||||
connect(ui->toolTree, SIGNAL(itemChanged(QTreeWidgetItem*,int)),
|
this, SLOT(handleCurrentChanged(QModelIndex,QModelIndex)));
|
||||||
this, SLOT(updateItemName(QTreeWidgetItem *)));
|
|
||||||
connect(ui->description, SIGNAL(editingFinished()), this, SLOT(updateCurrentItem()));
|
connect(ui->description, SIGNAL(editingFinished()), this, SLOT(updateCurrentItem()));
|
||||||
connect(ui->executable, SIGNAL(editingFinished()), this, SLOT(updateCurrentItem()));
|
connect(ui->executable, SIGNAL(editingFinished()), this, SLOT(updateCurrentItem()));
|
||||||
connect(ui->executable, SIGNAL(browsingFinished()), this, SLOT(updateCurrentItem()));
|
connect(ui->executable, SIGNAL(browsingFinished()), this, SLOT(updateCurrentItem()));
|
||||||
@@ -71,7 +337,7 @@ ExternalToolConfig::ExternalToolConfig(QWidget *parent) :
|
|||||||
ui->removeButton->setIcon(QIcon(QLatin1String(Constants::ICON_MINUS)));
|
ui->removeButton->setIcon(QIcon(QLatin1String(Constants::ICON_MINUS)));
|
||||||
ui->revertButton->setIcon(QIcon(QLatin1String(Constants::ICON_RESET)));
|
ui->revertButton->setIcon(QIcon(QLatin1String(Constants::ICON_RESET)));
|
||||||
connect(ui->revertButton, SIGNAL(clicked()), this, SLOT(revertCurrentItem()));
|
connect(ui->revertButton, SIGNAL(clicked()), this, SLOT(revertCurrentItem()));
|
||||||
connect(ui->addButton, SIGNAL(clicked()), this, SLOT(addTool()));
|
connect(ui->addButton, SIGNAL(clicked()), this, SLOT(add()));
|
||||||
connect(ui->removeButton, SIGNAL(clicked()), this, SLOT(removeTool()));
|
connect(ui->removeButton, SIGNAL(clicked()), this, SLOT(removeTool()));
|
||||||
|
|
||||||
QMenu *menu = new QMenu(ui->addButton);
|
QMenu *menu = new QMenu(ui->addButton);
|
||||||
@@ -80,17 +346,12 @@ ExternalToolConfig::ExternalToolConfig(QWidget *parent) :
|
|||||||
menu->addAction(addCategory);
|
menu->addAction(addCategory);
|
||||||
connect(addCategory, SIGNAL(triggered()), this, SLOT(addCategory()));
|
connect(addCategory, SIGNAL(triggered()), this, SLOT(addCategory()));
|
||||||
|
|
||||||
showInfoForItem(0);
|
showInfoForItem(QModelIndex());
|
||||||
updateButtons(ui->toolTree->currentItem());
|
// updateButtons(ui->toolTree->currentItem());
|
||||||
}
|
}
|
||||||
|
|
||||||
ExternalToolConfig::~ExternalToolConfig()
|
ExternalToolConfig::~ExternalToolConfig()
|
||||||
{
|
{
|
||||||
QMapIterator<QString, QList<ExternalTool *> > it(m_tools);
|
|
||||||
while (it.hasNext()) {
|
|
||||||
it.next();
|
|
||||||
qDeleteAll(it.value());
|
|
||||||
}
|
|
||||||
delete ui;
|
delete ui;
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -109,49 +370,30 @@ QString ExternalToolConfig::searchKeywords() const
|
|||||||
return keywords;
|
return keywords;
|
||||||
}
|
}
|
||||||
|
|
||||||
static const Qt::ItemFlags TOOL_ITEM_FLAGS = Qt::ItemIsSelectable | Qt::ItemIsEnabled | Qt::ItemIsDragEnabled | Qt::ItemIsDropEnabled | Qt::ItemIsEditable;
|
|
||||||
|
|
||||||
|
|
||||||
void ExternalToolConfig::setTools(const QMap<QString, QList<ExternalTool *> > &tools)
|
void ExternalToolConfig::setTools(const QMap<QString, QList<ExternalTool *> > &tools)
|
||||||
{
|
{
|
||||||
|
QMap<QString, QList<ExternalTool *> > toolsCopy;
|
||||||
QMapIterator<QString, QList<ExternalTool *> > it(tools);
|
QMapIterator<QString, QList<ExternalTool *> > it(tools);
|
||||||
while (it.hasNext()) {
|
while (it.hasNext()) {
|
||||||
it.next();
|
it.next();
|
||||||
QList<ExternalTool *> itemCopy;
|
QList<ExternalTool *> itemCopy;
|
||||||
foreach (ExternalTool *tool, it.value())
|
foreach (ExternalTool *tool, it.value())
|
||||||
itemCopy.append(new ExternalTool(tool));
|
itemCopy.append(new ExternalTool(tool));
|
||||||
m_tools.insert(it.key(), itemCopy);
|
toolsCopy.insert(it.key(), itemCopy);
|
||||||
}
|
|
||||||
|
|
||||||
bool blocked = ui->toolTree->blockSignals(true); // block itemChanged
|
|
||||||
QMapIterator<QString, QList<ExternalTool *> > categories(m_tools);
|
|
||||||
while (categories.hasNext()) {
|
|
||||||
categories.next();
|
|
||||||
QString name = (categories.key().isEmpty() ? tr("External Tools Menu") : categories.key());
|
|
||||||
QTreeWidgetItem *category = new QTreeWidgetItem(ui->toolTree, QStringList() << name);
|
|
||||||
category->setFlags(TOOL_ITEM_FLAGS);
|
|
||||||
category->setData(0, Qt::UserRole, name); // save the name in case of category being renamed by user
|
|
||||||
foreach (ExternalTool *tool, categories.value()) {
|
|
||||||
QTreeWidgetItem *item = new QTreeWidgetItem(category, QStringList() << tool->displayName());
|
|
||||||
item->setFlags(TOOL_ITEM_FLAGS);
|
|
||||||
item->setData(0, Qt::UserRole, qVariantFromValue(tool));
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
m_model->setTools(toolsCopy);
|
||||||
ui->toolTree->expandAll();
|
ui->toolTree->expandAll();
|
||||||
ui->toolTree->blockSignals(blocked); // unblock itemChanged
|
|
||||||
}
|
}
|
||||||
|
|
||||||
void ExternalToolConfig::handleCurrentItemChanged(QTreeWidgetItem *now, QTreeWidgetItem *previous)
|
void ExternalToolConfig::handleCurrentChanged(const QModelIndex &now, const QModelIndex &previous)
|
||||||
{
|
{
|
||||||
updateItem(previous);
|
updateItem(previous);
|
||||||
showInfoForItem(now);
|
showInfoForItem(now);
|
||||||
}
|
}
|
||||||
|
|
||||||
void ExternalToolConfig::updateButtons(QTreeWidgetItem *item)
|
void ExternalToolConfig::updateButtons(const QModelIndex &index)
|
||||||
{
|
{
|
||||||
ExternalTool *tool = 0;
|
ExternalTool *tool = m_model->toolForIndex(index);
|
||||||
if (item)
|
|
||||||
tool = item->data(0, Qt::UserRole).value<ExternalTool *>();
|
|
||||||
if (!tool) {
|
if (!tool) {
|
||||||
ui->removeButton->setEnabled(false);
|
ui->removeButton->setEnabled(false);
|
||||||
ui->revertButton->setEnabled(false);
|
ui->revertButton->setEnabled(false);
|
||||||
@@ -168,16 +410,14 @@ void ExternalToolConfig::updateButtons(QTreeWidgetItem *item)
|
|||||||
|
|
||||||
void ExternalToolConfig::updateCurrentItem()
|
void ExternalToolConfig::updateCurrentItem()
|
||||||
{
|
{
|
||||||
QTreeWidgetItem *item = ui->toolTree->currentItem();
|
QModelIndex index = ui->toolTree->selectionModel()->currentIndex();
|
||||||
updateItem(item);
|
updateItem(index);
|
||||||
updateButtons(item);
|
updateButtons(index);
|
||||||
}
|
}
|
||||||
|
|
||||||
void ExternalToolConfig::updateItem(QTreeWidgetItem *item)
|
void ExternalToolConfig::updateItem(const QModelIndex &index)
|
||||||
{
|
{
|
||||||
ExternalTool *tool = 0;
|
ExternalTool *tool = m_model->toolForIndex(index);
|
||||||
if (item)
|
|
||||||
tool = item->data(0, Qt::UserRole).value<ExternalTool *>();
|
|
||||||
if (!tool)
|
if (!tool)
|
||||||
return;
|
return;
|
||||||
tool->setDescription(ui->description->text());
|
tool->setDescription(ui->description->text());
|
||||||
@@ -195,12 +435,10 @@ void ExternalToolConfig::updateItem(QTreeWidgetItem *item)
|
|||||||
tool->setInput(ui->inputText->toPlainText());
|
tool->setInput(ui->inputText->toPlainText());
|
||||||
}
|
}
|
||||||
|
|
||||||
void ExternalToolConfig::showInfoForItem(QTreeWidgetItem *item)
|
void ExternalToolConfig::showInfoForItem(const QModelIndex &index)
|
||||||
{
|
{
|
||||||
updateButtons(item);
|
updateButtons(index);
|
||||||
ExternalTool *tool = 0;
|
ExternalTool *tool = m_model->toolForIndex(index);
|
||||||
if (item)
|
|
||||||
tool = item->data(0, Qt::UserRole).value<ExternalTool *>();
|
|
||||||
if (!tool) {
|
if (!tool) {
|
||||||
ui->description->setText(QString());
|
ui->description->setText(QString());
|
||||||
ui->executable->setPath(QString());
|
ui->executable->setPath(QString());
|
||||||
@@ -218,176 +456,58 @@ void ExternalToolConfig::showInfoForItem(QTreeWidgetItem *item)
|
|||||||
ui->outputBehavior->setCurrentIndex((int)tool->outputHandling());
|
ui->outputBehavior->setCurrentIndex((int)tool->outputHandling());
|
||||||
ui->errorOutputBehavior->setCurrentIndex((int)tool->errorHandling());
|
ui->errorOutputBehavior->setCurrentIndex((int)tool->errorHandling());
|
||||||
ui->modifiesDocumentCheckbox->setChecked(tool->modifiesCurrentDocument());
|
ui->modifiesDocumentCheckbox->setChecked(tool->modifiesCurrentDocument());
|
||||||
|
|
||||||
bool blocked = ui->inputText->blockSignals(true);
|
bool blocked = ui->inputText->blockSignals(true);
|
||||||
ui->inputText->setPlainText(tool->input());
|
ui->inputText->setPlainText(tool->input());
|
||||||
ui->inputText->blockSignals(blocked);
|
ui->inputText->blockSignals(blocked);
|
||||||
|
|
||||||
ui->description->setCursorPosition(0);
|
ui->description->setCursorPosition(0);
|
||||||
ui->arguments->setCursorPosition(0);
|
ui->arguments->setCursorPosition(0);
|
||||||
}
|
}
|
||||||
|
|
||||||
void ExternalToolConfig::updateItemName(QTreeWidgetItem *item)
|
|
||||||
{
|
|
||||||
if (item != ui->toolTree->currentItem())
|
|
||||||
return;
|
|
||||||
ExternalTool *tool = 0;
|
|
||||||
if (item)
|
|
||||||
tool = item->data(0, Qt::UserRole).value<ExternalTool *>();
|
|
||||||
if (tool) {
|
|
||||||
// tool was renamed
|
|
||||||
const QString &newName = item->data(0, Qt::DisplayRole).toString();
|
|
||||||
if (newName == tool->displayName())
|
|
||||||
return;
|
|
||||||
if (newName.isEmpty()) {
|
|
||||||
// prevent empty names
|
|
||||||
bool blocked = ui->toolTree->blockSignals(true); // block itemChanged
|
|
||||||
item->setData(0, Qt::DisplayRole, tool->displayName());
|
|
||||||
ui->toolTree->blockSignals(blocked); // unblock itemChanged
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
tool->setDisplayName(item->data(0, Qt::DisplayRole).toString());
|
|
||||||
} else {
|
|
||||||
// category was renamed
|
|
||||||
const QString &oldName = item->data(0, Qt::UserRole).toString();
|
|
||||||
const QString &newName = item->data(0, Qt::DisplayRole).toString();
|
|
||||||
if (oldName == newName)
|
|
||||||
return;
|
|
||||||
if (newName.isEmpty() && m_tools.contains(newName)) {
|
|
||||||
// prevent empty or duplicate names
|
|
||||||
bool blocked = ui->toolTree->blockSignals(true); // block itemChanged
|
|
||||||
item->setData(0, Qt::DisplayRole, oldName);
|
|
||||||
ui->toolTree->blockSignals(blocked); // unblock itemChanged
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
QTC_ASSERT(m_tools.contains(oldName), return);
|
|
||||||
m_tools.insert(newName, m_tools.value(oldName));
|
|
||||||
m_tools.remove(oldName);
|
|
||||||
|
|
||||||
bool blocked = ui->toolTree->blockSignals(true); // block itemChanged
|
|
||||||
item->setData(0, Qt::UserRole, newName);
|
|
||||||
int currentIndex = ui->toolTree->indexOfTopLevelItem(item);
|
|
||||||
bool wasExpanded = ui->toolTree->isExpanded(ui->toolTree->model()->index(currentIndex, 0));
|
|
||||||
ui->toolTree->takeTopLevelItem(currentIndex);
|
|
||||||
int newIndex = m_tools.keys().indexOf(newName);
|
|
||||||
ui->toolTree->insertTopLevelItem(newIndex, item);
|
|
||||||
if (wasExpanded)
|
|
||||||
ui->toolTree->expand(ui->toolTree->model()->index(newIndex, 0));
|
|
||||||
ui->toolTree->setCurrentItem(item);
|
|
||||||
ui->toolTree->blockSignals(blocked); // unblock itemChanged
|
|
||||||
}
|
|
||||||
updateButtons(item);
|
|
||||||
}
|
|
||||||
|
|
||||||
QMap<QString, QList<ExternalTool *> > ExternalToolConfig::tools() const
|
QMap<QString, QList<ExternalTool *> > ExternalToolConfig::tools() const
|
||||||
{
|
{
|
||||||
return m_tools;
|
return m_model->tools();
|
||||||
}
|
}
|
||||||
|
|
||||||
void ExternalToolConfig::apply()
|
void ExternalToolConfig::apply()
|
||||||
{
|
{
|
||||||
updateItem(ui->toolTree->currentItem());
|
QModelIndex index = ui->toolTree->selectionModel()->currentIndex();
|
||||||
updateButtons(ui->toolTree->currentItem());
|
updateItem(index);
|
||||||
|
updateButtons(index);
|
||||||
}
|
}
|
||||||
|
|
||||||
void ExternalToolConfig::revertCurrentItem()
|
void ExternalToolConfig::revertCurrentItem()
|
||||||
{
|
{
|
||||||
QTreeWidgetItem *currentItem = ui->toolTree->currentItem();
|
QModelIndex index = ui->toolTree->selectionModel()->currentIndex();
|
||||||
QTC_ASSERT(currentItem, return);
|
m_model->revertTool(index);
|
||||||
ExternalTool *tool = currentItem->data(0, Qt::UserRole).value<ExternalTool *>();
|
showInfoForItem(index);
|
||||||
QTC_ASSERT(tool, return);
|
|
||||||
QTC_ASSERT(tool->preset() && !tool->preset()->fileName().isEmpty(), return);
|
|
||||||
ExternalTool *resetTool = new ExternalTool(tool->preset().data());
|
|
||||||
resetTool->setPreset(tool->preset());
|
|
||||||
bool blocked = ui->toolTree->blockSignals(true); // block itemChanged
|
|
||||||
currentItem->setData(0, Qt::UserRole, qVariantFromValue(resetTool));
|
|
||||||
currentItem->setData(0, Qt::DisplayRole, resetTool->displayName());
|
|
||||||
ui->toolTree->blockSignals(blocked); // unblock itemChanged
|
|
||||||
showInfoForItem(currentItem);
|
|
||||||
QMutableMapIterator<QString, QList<ExternalTool *> > it(m_tools);
|
|
||||||
while (it.hasNext()) {
|
|
||||||
it.next();
|
|
||||||
QList<ExternalTool *> &items = it.value();
|
|
||||||
int index = items.indexOf(tool);
|
|
||||||
if (index != -1) {
|
|
||||||
items[index] = resetTool;
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
delete tool;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
void ExternalToolConfig::addTool()
|
void ExternalToolConfig::add()
|
||||||
{
|
{
|
||||||
// find category to use
|
QModelIndex currentIndex = ui->toolTree->selectionModel()->currentIndex();
|
||||||
QTreeWidgetItem *currentItem = ui->toolTree->currentItem();
|
if (!currentIndex.isValid()) {
|
||||||
if (!currentItem) {
|
|
||||||
addCategory();
|
addCategory();
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
QString category;
|
QModelIndex index = m_model->addTool(currentIndex);
|
||||||
QTreeWidgetItem *parent;
|
ui->toolTree->selectionModel()->setCurrentIndex(index, QItemSelectionModel::Clear);
|
||||||
if (currentItem->parent()) {
|
ui->toolTree->selectionModel()->setCurrentIndex(index, QItemSelectionModel::SelectCurrent);
|
||||||
parent = currentItem->parent();
|
ui->toolTree->edit(index);
|
||||||
} else {
|
|
||||||
parent = currentItem;
|
|
||||||
}
|
|
||||||
category = parent->data(0, Qt::UserRole).toString();
|
|
||||||
ExternalTool *tool = new ExternalTool;
|
|
||||||
tool->setCategory(category);
|
|
||||||
tool->setDisplayName(tr("New tool"));
|
|
||||||
tool->setDescription(tr("This tool prints a line of useful text"));
|
|
||||||
tool->setExecutables(QStringList() << "echo");
|
|
||||||
tool->setArguments(tr("Useful text"));
|
|
||||||
// todo ordering
|
|
||||||
m_tools[category].append(tool);
|
|
||||||
bool blocked = ui->toolTree->blockSignals(true); // block itemChanged
|
|
||||||
QTreeWidgetItem *item = new QTreeWidgetItem(parent, QStringList() << tool->displayName());
|
|
||||||
item->setFlags(TOOL_ITEM_FLAGS);
|
|
||||||
item->setData(0, Qt::UserRole, qVariantFromValue(tool));
|
|
||||||
ui->toolTree->blockSignals(blocked); // unblock itemChanged
|
|
||||||
ui->toolTree->setCurrentItem(item);
|
|
||||||
ui->toolTree->editItem(item);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
void ExternalToolConfig::removeTool()
|
void ExternalToolConfig::removeTool()
|
||||||
{
|
{
|
||||||
QTreeWidgetItem *currentItem = ui->toolTree->currentItem();
|
QModelIndex currentIndex = ui->toolTree->selectionModel()->currentIndex();
|
||||||
QTC_ASSERT(currentItem, return);
|
ui->toolTree->selectionModel()->setCurrentIndex(QModelIndex(), QItemSelectionModel::Clear);
|
||||||
ExternalTool *tool = currentItem->data(0, Qt::UserRole).value<ExternalTool *>();
|
m_model->removeTool(currentIndex);
|
||||||
QTC_ASSERT(tool, return);
|
|
||||||
QTC_ASSERT(!tool->preset(), return);
|
|
||||||
// remove the tool and the tree item
|
|
||||||
QMutableMapIterator<QString, QList<ExternalTool *> > it(m_tools);
|
|
||||||
while (it.hasNext()) {
|
|
||||||
it.next();
|
|
||||||
QList<ExternalTool *> &items = it.value();
|
|
||||||
int index = items.indexOf(tool);
|
|
||||||
if (index != -1) {
|
|
||||||
items.removeAt(index);
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
ui->toolTree->setCurrentItem(0);
|
|
||||||
delete currentItem;
|
|
||||||
delete tool;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
void ExternalToolConfig::addCategory()
|
void ExternalToolConfig::addCategory()
|
||||||
{
|
{
|
||||||
const QString &categoryBase = tr("New category");
|
QModelIndex index = m_model->addCategory();
|
||||||
QString category = categoryBase;
|
ui->toolTree->selectionModel()->setCurrentIndex(index, QItemSelectionModel::Clear);
|
||||||
int count = 0;
|
ui->toolTree->selectionModel()->setCurrentIndex(index, QItemSelectionModel::SelectCurrent);
|
||||||
while (m_tools.contains(category)) {
|
ui->toolTree->edit(index);
|
||||||
++count;
|
|
||||||
category = categoryBase + QString::number(count);
|
|
||||||
}
|
|
||||||
bool blocked = ui->toolTree->blockSignals(true); // block itemChanged
|
|
||||||
QTreeWidgetItem *item = new QTreeWidgetItem(QStringList() << category);
|
|
||||||
item->setFlags(TOOL_ITEM_FLAGS);
|
|
||||||
item->setData(0, Qt::UserRole, category); // save name for the renaming stuff
|
|
||||||
m_tools.insert(category, QList<ExternalTool *>());
|
|
||||||
int newIndex = m_tools.keys().indexOf(category);
|
|
||||||
ui->toolTree->insertTopLevelItem(newIndex, item);
|
|
||||||
ui->toolTree->blockSignals(blocked); // unblock itemChanged
|
|
||||||
ui->toolTree->setCurrentItem(item);
|
|
||||||
ui->toolTree->editItem(item);
|
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -37,7 +37,7 @@
|
|||||||
#include "coreplugin/externaltool.h"
|
#include "coreplugin/externaltool.h"
|
||||||
|
|
||||||
#include <QtGui/QWidget>
|
#include <QtGui/QWidget>
|
||||||
#include <QtGui/QTreeWidgetItem>
|
#include <QtCore/QAbstractItemModel>
|
||||||
|
|
||||||
namespace Core {
|
namespace Core {
|
||||||
namespace Internal {
|
namespace Internal {
|
||||||
@@ -46,6 +46,39 @@ namespace Ui {
|
|||||||
class ExternalToolConfig;
|
class ExternalToolConfig;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
class ExternalToolModel : public QAbstractItemModel
|
||||||
|
{
|
||||||
|
Q_OBJECT
|
||||||
|
|
||||||
|
public:
|
||||||
|
explicit ExternalToolModel(QObject *parent);
|
||||||
|
~ExternalToolModel();
|
||||||
|
|
||||||
|
int columnCount(const QModelIndex &parent = QModelIndex()) const;
|
||||||
|
QVariant data(const QModelIndex &modelIndex, int role = Qt::DisplayRole) const;
|
||||||
|
QModelIndex index(int row, int column, const QModelIndex &parent = QModelIndex()) const;
|
||||||
|
QModelIndex parent(const QModelIndex &child) const;
|
||||||
|
int rowCount(const QModelIndex &parent = QModelIndex()) const;
|
||||||
|
Qt::ItemFlags flags(const QModelIndex &modelIndex) const;
|
||||||
|
bool setData(const QModelIndex &modelIndex, const QVariant &value, int role = Qt::EditRole);
|
||||||
|
|
||||||
|
void setTools(const QMap<QString, QList<ExternalTool *> > &tools);
|
||||||
|
QMap<QString, QList<ExternalTool *> > tools() const;
|
||||||
|
|
||||||
|
ExternalTool *toolForIndex(const QModelIndex &modelIndex) const;
|
||||||
|
QString categoryForIndex(const QModelIndex &modelIndex) const;
|
||||||
|
void revertTool(const QModelIndex &modelIndex);
|
||||||
|
QModelIndex addCategory();
|
||||||
|
QModelIndex addTool(const QModelIndex &atIndex);
|
||||||
|
void removeTool(const QModelIndex &modelIndex);
|
||||||
|
private:
|
||||||
|
QVariant data(ExternalTool *tool, int role = Qt::DisplayRole) const;
|
||||||
|
QVariant data(const QString &category, int role = Qt::DisplayRole) const;
|
||||||
|
|
||||||
|
QMap<QString, QList<ExternalTool *> > m_tools;
|
||||||
|
};
|
||||||
|
|
||||||
|
|
||||||
class ExternalToolConfig : public QWidget
|
class ExternalToolConfig : public QWidget
|
||||||
{
|
{
|
||||||
Q_OBJECT
|
Q_OBJECT
|
||||||
@@ -61,20 +94,19 @@ public:
|
|||||||
QString searchKeywords() const;
|
QString searchKeywords() const;
|
||||||
|
|
||||||
private slots:
|
private slots:
|
||||||
void handleCurrentItemChanged(QTreeWidgetItem *now, QTreeWidgetItem *previous);
|
void handleCurrentChanged(const QModelIndex &now, const QModelIndex &previous);
|
||||||
void showInfoForItem(QTreeWidgetItem *item);
|
void showInfoForItem(const QModelIndex &index);
|
||||||
void updateItem(QTreeWidgetItem *item);
|
void updateItem(const QModelIndex &index);
|
||||||
void updateItemName(QTreeWidgetItem *item);
|
|
||||||
void revertCurrentItem();
|
void revertCurrentItem();
|
||||||
void updateButtons(QTreeWidgetItem *item);
|
void updateButtons(const QModelIndex &index);
|
||||||
void updateCurrentItem();
|
void updateCurrentItem();
|
||||||
void addTool();
|
void add();
|
||||||
void removeTool();
|
void removeTool();
|
||||||
void addCategory();
|
void addCategory();
|
||||||
|
|
||||||
private:
|
private:
|
||||||
Ui::ExternalToolConfig *ui;
|
Ui::ExternalToolConfig *ui;
|
||||||
QMap<QString, QList<ExternalTool *> > m_tools;
|
ExternalToolModel *m_model;
|
||||||
};
|
};
|
||||||
|
|
||||||
} // Internal
|
} // Internal
|
||||||
|
|||||||
@@ -17,15 +17,19 @@
|
|||||||
<item>
|
<item>
|
||||||
<layout class="QVBoxLayout" name="verticalLayout">
|
<layout class="QVBoxLayout" name="verticalLayout">
|
||||||
<item>
|
<item>
|
||||||
<widget class="QTreeWidget" name="toolTree">
|
<widget class="QTreeView" name="toolTree">
|
||||||
|
<property name="dragEnabled">
|
||||||
|
<bool>true</bool>
|
||||||
|
</property>
|
||||||
|
<property name="dragDropMode">
|
||||||
|
<enum>QAbstractItemView::InternalMove</enum>
|
||||||
|
</property>
|
||||||
<attribute name="headerVisible">
|
<attribute name="headerVisible">
|
||||||
<bool>false</bool>
|
<bool>false</bool>
|
||||||
</attribute>
|
</attribute>
|
||||||
<column>
|
<attribute name="headerDefaultSectionSize">
|
||||||
<property name="text">
|
<number>0</number>
|
||||||
<string notr="true">1</string>
|
</attribute>
|
||||||
</property>
|
|
||||||
</column>
|
|
||||||
</widget>
|
</widget>
|
||||||
</item>
|
</item>
|
||||||
<item>
|
<item>
|
||||||
@@ -125,7 +129,7 @@ p, li { white-space: pre-wrap; }
|
|||||||
</widget>
|
</widget>
|
||||||
</item>
|
</item>
|
||||||
<item row="1" column="1">
|
<item row="1" column="1">
|
||||||
<widget class="Utils::PathChooser" name="executable" native="true"/>
|
<widget class="Utils::PathChooser" name="executable"/>
|
||||||
</item>
|
</item>
|
||||||
<item row="2" column="0">
|
<item row="2" column="0">
|
||||||
<widget class="QLabel" name="argumentsLabel">
|
<widget class="QLabel" name="argumentsLabel">
|
||||||
@@ -145,7 +149,7 @@ p, li { white-space: pre-wrap; }
|
|||||||
</widget>
|
</widget>
|
||||||
</item>
|
</item>
|
||||||
<item row="3" column="1">
|
<item row="3" column="1">
|
||||||
<widget class="Utils::PathChooser" name="workingDirectory" native="true"/>
|
<widget class="Utils::PathChooser" name="workingDirectory"/>
|
||||||
</item>
|
</item>
|
||||||
<item row="4" column="0">
|
<item row="4" column="0">
|
||||||
<widget class="QLabel" name="outputLabel">
|
<widget class="QLabel" name="outputLabel">
|
||||||
|
|||||||
@@ -109,6 +109,24 @@ ExternalTool::ExternalTool(const ExternalTool *other)
|
|||||||
{
|
{
|
||||||
}
|
}
|
||||||
|
|
||||||
|
ExternalTool &ExternalTool::operator=(const ExternalTool &other)
|
||||||
|
{
|
||||||
|
m_id = other.m_id;
|
||||||
|
m_description = other.m_description;
|
||||||
|
m_displayName = other.m_displayName;
|
||||||
|
m_displayCategory = other.m_displayCategory;
|
||||||
|
m_order = other.m_order;
|
||||||
|
m_executables = other.m_executables;
|
||||||
|
m_arguments = other.m_arguments;
|
||||||
|
m_input = other.m_input;
|
||||||
|
m_workingDirectory = other.m_workingDirectory;
|
||||||
|
m_outputHandling = other.m_outputHandling;
|
||||||
|
m_errorHandling = other.m_errorHandling;
|
||||||
|
m_modifiesCurrentDocument = other.m_modifiesCurrentDocument;
|
||||||
|
m_fileName = other.m_fileName;
|
||||||
|
m_presetTool = other.m_presetTool;
|
||||||
|
}
|
||||||
|
|
||||||
ExternalTool::~ExternalTool()
|
ExternalTool::~ExternalTool()
|
||||||
{
|
{
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -90,6 +90,7 @@ public:
|
|||||||
|
|
||||||
bool operator==(const ExternalTool &other);
|
bool operator==(const ExternalTool &other);
|
||||||
bool operator!=(const ExternalTool &other) { return !((*this) == other); }
|
bool operator!=(const ExternalTool &other) { return !((*this) == other); }
|
||||||
|
ExternalTool &operator=(const ExternalTool &other);
|
||||||
|
|
||||||
void setId(const QString &id);
|
void setId(const QString &id);
|
||||||
void setCategory(const QString &category);
|
void setCategory(const QString &category);
|
||||||
|
|||||||
Reference in New Issue
Block a user