1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
|
// Copyright (C) 2020 Alexis Jeandet.
// SPDX-License-Identifier: LicenseRef-Qt-Commercial OR GPL-3.0+ OR GPL-3.0 WITH Qt-GPL-exception-1.0
#include "tooltreeitem.h"
#include <utils/utilsicons.h>
#include <QFileInfo>
#include <QUuid>
namespace MesonProjectManager {
namespace Internal {
ToolTreeItem::ToolTreeItem(const QString &name)
: m_name{name}
, m_autoDetected{false}
, m_id(Utils::Id::fromString(QUuid::createUuid().toString()))
, 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("Version: %1").arg(tool->version().toQString());
self_check();
}
ToolTreeItem::ToolTreeItem(const ToolTreeItem &other)
: m_name{tr("Clone of %1").arg(other.m_name)}
, m_executable{other.m_executable}
, m_autoDetected{false}
, m_id{Utils::Id::fromString(QUuid::createUuid().toString())}
, 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 QCoreApplication::translate("MesonProjectManager::Internal::ToolTreeItem",
"Meson executable path does not exist.");
if (!m_pathIsFile)
return QCoreApplication::translate("MesonProjectManager::Internal::ToolTreeItem",
"Meson executable path is not a file.");
if (!m_pathIsExecutable)
return QCoreApplication::translate("MesonProjectManager::Internal::ToolTreeItem",
"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("Version: %1").arg(version.toQString());
else
m_tooltip = tr("Cannot get tool version.");
}
void ToolTreeItem::update_tooltip()
{
update_tooltip(MesonWrapper::read_version(m_executable));
}
} // namespace Internal
} // namespace MesonProjectManager
|