Meson: Merge tooltreeitem into toolsmodel

Change-Id: I949e36740545ea1521a22efb6b1db16548dfae64
Reviewed-by: Jarek Kobus <jaroslaw.kobus@qt.io>
This commit is contained in:
hjk
2024-07-24 09:06:49 +02:00
parent 4fb63e4c9d
commit 1decf593b1
8 changed files with 150 additions and 193 deletions

View File

@@ -57,8 +57,6 @@ add_qtc_plugin(MesonProjectManager
toolssettingsaccessor.h
toolssettingspage.cpp
toolssettingspage.h
tooltreeitem.cpp
tooltreeitem.h
versionhelper.h
)

View File

@@ -73,8 +73,6 @@ Project {
"toolssettingsaccessor.h",
"toolssettingspage.cpp",
"toolssettingspage.h",
"tooltreeitem.cpp",
"tooltreeitem.h",
"versionhelper.h",
]
}

View File

@@ -4,7 +4,7 @@
#include "toolitemsettings.h"
#include "mesonprojectmanagertr.h"
#include "tooltreeitem.h"
#include "toolsmodel.h"
#include <utils/layoutbuilder.h>
#include <utils/pathchooser.h>

View File

@@ -3,24 +3,129 @@
#include "toolsmodel.h"
#include "tooltreeitem.h"
#include "mesonprojectmanagertr.h"
#include "mesontools.h"
#include <projectexplorer/projectexplorerconstants.h>
#include <utils/qtcassert.h>
#include <utils/stringutils.h>
#include <utils/utilsicons.h>
namespace MesonProjectManager {
namespace Internal {
using namespace Utils;
namespace MesonProjectManager::Internal {
// ToolTreeItem
ToolTreeItem::ToolTreeItem(const QString &name)
: m_name{name}
, m_id(Id::generate())
, m_autoDetected{false}
, m_unsavedChanges{true}
{
self_check();
update_tooltip();
}
ToolTreeItem::ToolTreeItem(const MesonTools::Tool_t &tool)
: m_name{tool->name()}
, m_executable{tool->exe()}
, m_id{tool->id()}
, m_autoDetected{tool->autoDetected()}
{
m_tooltip = Tr::tr("Version: %1").arg(tool->version().toQString());
self_check();
}
ToolTreeItem::ToolTreeItem(const ToolTreeItem &other)
: m_name{Tr::tr("Clone of %1").arg(other.m_name)}
, m_executable{other.m_executable}
, m_id{Id::generate()}
, m_autoDetected{false}
, m_unsavedChanges{true}
{
self_check();
update_tooltip();
}
QVariant ToolTreeItem::data(int column, int role) const
{
switch (role) {
case Qt::DisplayRole: {
switch (column) {
case 0: {
return m_name;
}
case 1: {
return m_executable.toUserOutput();
}
} // switch (column)
return QVariant();
}
case Qt::FontRole: {
QFont font;
font.setBold(m_unsavedChanges);
return font;
}
case Qt::ToolTipRole: {
if (!m_pathExists)
return Tr::tr("Meson executable path does not exist.");
if (!m_pathIsFile)
return Tr::tr("Meson executable path is not a file.");
if (!m_pathIsExecutable)
return Tr::tr("Meson executable path is not executable.");
return m_tooltip;
}
case Qt::DecorationRole: {
if (column == 0 && (!m_pathExists || !m_pathIsFile || !m_pathIsExecutable))
return Icons::CRITICAL.icon();
return {};
}
}
return {};
}
void ToolTreeItem::update(const QString &name, const FilePath &exe)
{
m_unsavedChanges = true;
m_name = name;
if (exe != m_executable) {
m_executable = exe;
self_check();
update_tooltip();
}
}
void ToolTreeItem::self_check()
{
m_pathExists = m_executable.exists();
m_pathIsFile = m_executable.toFileInfo().isFile();
m_pathIsExecutable = m_executable.toFileInfo().isExecutable();
}
void ToolTreeItem::update_tooltip(const Version &version)
{
if (version.isValid)
m_tooltip = Tr::tr("Version: %1").arg(version.toQString());
else
m_tooltip = Tr::tr("Cannot get tool version.");
}
void ToolTreeItem::update_tooltip()
{
update_tooltip(ToolWrapper::read_version(m_executable));
}
// ToolsModel
ToolsModel::ToolsModel()
{
setHeader({Tr::tr("Name"), Tr::tr("Location")});
rootItem()->appendChild(
new Utils::StaticTreeItem({ProjectExplorer::Constants::msgAutoDetected()},
new StaticTreeItem({ProjectExplorer::Constants::msgAutoDetected()},
{ProjectExplorer::Constants::msgAutoDetectedToolTip()}));
rootItem()->appendChild(new Utils::StaticTreeItem(ProjectExplorer::Constants::msgManual()));
rootItem()->appendChild(new StaticTreeItem(ProjectExplorer::Constants::msgManual()));
for (const auto &tool : MesonTools::tools())
addMesonToolHelper(tool);
}
@@ -30,7 +135,7 @@ ToolTreeItem *ToolsModel::mesoneToolTreeItem(const QModelIndex &index) const
return itemForIndexAtLevel<2>(index);
}
void ToolsModel::updateItem(const Utils::Id &itemId, const QString &name, const Utils::FilePath &exe)
void ToolsModel::updateItem(const Id &itemId, const QString &name, const FilePath &exe)
{
auto treeItem = findItemAtLevel<2>([itemId](ToolTreeItem *n) { return n->id() == itemId; });
QTC_ASSERT(treeItem, return );
@@ -45,7 +150,7 @@ void ToolsModel::addMesonTool()
void ToolsModel::removeMesonTool(ToolTreeItem *item)
{
QTC_ASSERT(item, return );
const Utils::Id id = item->id();
const Id id = item->id();
destroyItem(item);
m_itemsToRemove.enqueue(id);
}
@@ -83,19 +188,18 @@ void ToolsModel::addMesonToolHelper(const MesonTools::Tool_t &tool)
QString ToolsModel::uniqueName(const QString &baseName)
{
QStringList names;
forItemsAtLevel<2>([&names](auto *item) { names << item->name(); });
forItemsAtLevel<2>([&names](ToolTreeItem *item) { names << item->name(); });
return Utils::makeUniquelyNumbered(baseName, names);
}
Utils::TreeItem *ToolsModel::autoDetectedGroup() const
TreeItem *ToolsModel::autoDetectedGroup() const
{
return rootItem()->childAt(0);
}
Utils::TreeItem *ToolsModel::manualGroup() const
TreeItem *ToolsModel::manualGroup() const
{
return rootItem()->childAt(1);
}
} // namespace Internal
} // namespace MesonProjectManager
} // MesonProjectManager::Internal

View File

@@ -7,13 +7,40 @@
#include <utils/treemodel.h>
#include <QCoreApplication>
#include <QQueue>
namespace MesonProjectManager {
namespace Internal {
namespace MesonProjectManager::Internal {
class ToolTreeItem;
class ToolTreeItem final : public Utils::TreeItem
{
public:
ToolTreeItem(const QString &name);
ToolTreeItem(const MesonTools::Tool_t &tool);
ToolTreeItem(const ToolTreeItem &other);
QVariant data(int column, int role) const override;
bool isAutoDetected() const noexcept { return m_autoDetected; }
QString name() const noexcept { return m_name; }
Utils::FilePath executable() const noexcept { return m_executable; }
Utils::Id id() const noexcept { return m_id; }
bool hasUnsavedChanges() const noexcept { return m_unsavedChanges; }
void setSaved() { m_unsavedChanges = false; }
void update(const QString &name, const Utils::FilePath &exe);
private:
void self_check();
void update_tooltip(const Version &version);
void update_tooltip();
QString m_name;
QString m_tooltip;
Utils::FilePath m_executable;
Utils::Id m_id;
bool m_autoDetected;
bool m_pathExists;
bool m_pathIsFile;
bool m_pathIsExecutable;
bool m_unsavedChanges = false;
};
class ToolsModel final : public Utils::TreeModel<Utils::TreeItem, Utils::TreeItem, ToolTreeItem>
{
@@ -35,5 +62,4 @@ private:
QQueue<Utils::Id> m_itemsToRemove;
};
} // namespace Internal
} // namespace MesonProjectManager
} // MesonProjectManager::Internal

View File

@@ -7,7 +7,6 @@
#include "mesonprojectmanagertr.h"
#include "toolitemsettings.h"
#include "toolsmodel.h"
#include "tooltreeitem.h"
#include <coreplugin/dialogs/ioptionspage.h>

View File

@@ -1,115 +0,0 @@
// Copyright (C) 2020 Alexis Jeandet.
// SPDX-License-Identifier: LicenseRef-Qt-Commercial OR GPL-3.0-only WITH Qt-GPL-exception-1.0
#include "tooltreeitem.h"
#include "mesonprojectmanagertr.h"
#include <utils/utilsicons.h>
#include <QFileInfo>
namespace MesonProjectManager {
namespace Internal {
ToolTreeItem::ToolTreeItem(const QString &name)
: m_name{name}
, m_autoDetected{false}
, m_id(Utils::Id::generate())
, m_unsavedChanges{true}
{
self_check();
update_tooltip();
}
ToolTreeItem::ToolTreeItem(const MesonTools::Tool_t &tool)
: m_name{tool->name()}
, m_executable{tool->exe()}
, m_autoDetected{tool->autoDetected()}
, m_id{tool->id()}
{
m_tooltip = Tr::tr("Version: %1").arg(tool->version().toQString());
self_check();
}
ToolTreeItem::ToolTreeItem(const ToolTreeItem &other)
: m_name{Tr::tr("Clone of %1").arg(other.m_name)}
, m_executable{other.m_executable}
, m_autoDetected{false}
, m_id{Utils::Id::generate()}
, m_unsavedChanges{true}
{
self_check();
update_tooltip();
}
QVariant ToolTreeItem::data(int column, int role) const
{
switch (role) {
case Qt::DisplayRole: {
switch (column) {
case 0: {
return m_name;
}
case 1: {
return m_executable.toUserOutput();
}
} // switch (column)
return QVariant();
}
case Qt::FontRole: {
QFont font;
font.setBold(m_unsavedChanges);
return font;
}
case Qt::ToolTipRole: {
if (!m_pathExists)
return Tr::tr("Meson executable path does not exist.");
if (!m_pathIsFile)
return Tr::tr("Meson executable path is not a file.");
if (!m_pathIsExecutable)
return Tr::tr("Meson executable path is not executable.");
return m_tooltip;
}
case Qt::DecorationRole: {
if (column == 0 && (!m_pathExists || !m_pathIsFile || !m_pathIsExecutable))
return Utils::Icons::CRITICAL.icon();
return {};
}
}
return {};
}
void ToolTreeItem::update(const QString &name, const Utils::FilePath &exe)
{
m_unsavedChanges = true;
m_name = name;
if (exe != m_executable) {
m_executable = exe;
self_check();
update_tooltip();
}
}
void ToolTreeItem::self_check()
{
m_pathExists = m_executable.exists();
m_pathIsFile = m_executable.toFileInfo().isFile();
m_pathIsExecutable = m_executable.toFileInfo().isExecutable();
}
void ToolTreeItem::update_tooltip(const Version &version)
{
if (version.isValid)
m_tooltip = Tr::tr("Version: %1").arg(version.toQString());
else
m_tooltip = Tr::tr("Cannot get tool version.");
}
void ToolTreeItem::update_tooltip()
{
update_tooltip(ToolWrapper::read_version(m_executable));
}
} // namespace Internal
} // namespace MesonProjectManager

View File

@@ -1,53 +0,0 @@
// Copyright (C) 2020 Alexis Jeandet.
// SPDX-License-Identifier: LicenseRef-Qt-Commercial OR GPL-3.0-only WITH Qt-GPL-exception-1.0
#pragma once
#include "mesontools.h"
#include <utils/fileutils.h>
#include <utils/id.h>
#include <utils/treemodel.h>
#include <QCoreApplication>
#include <QString>
#include <optional>
namespace MesonProjectManager {
namespace Internal {
class ToolTreeItem final : public Utils::TreeItem
{
public:
ToolTreeItem(const QString &name);
ToolTreeItem(const MesonTools::Tool_t &tool);
ToolTreeItem(const ToolTreeItem &other);
QVariant data(int column, int role) const override;
inline bool isAutoDetected() const noexcept { return m_autoDetected; }
inline QString name() const noexcept { return m_name; }
inline Utils::FilePath executable() const noexcept { return m_executable; }
inline Utils::Id id() const noexcept { return m_id; }
inline bool hasUnsavedChanges() const noexcept { return m_unsavedChanges; }
inline void setSaved() { m_unsavedChanges = false; }
void update(const QString &name, const Utils::FilePath &exe);
private:
void self_check();
void update_tooltip(const Version &version);
void update_tooltip();
QString m_name;
QString m_tooltip;
Utils::FilePath m_executable;
bool m_autoDetected;
bool m_pathExists;
bool m_pathIsFile;
bool m_pathIsExecutable;
Utils::Id m_id;
bool m_unsavedChanges = false;
};
} // namespace Internal
} // namespace MesonProjectManager