blob: ece9a872cebb55a8ef3263581f077f1951a291d8 (
plain)
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
118
119
120
121
122
123
|
// Copyright (C) 2016 The Qt Company Ltd.
// SPDX-License-Identifier: LicenseRef-Qt-Commercial OR GPL-3.0-only WITH Qt-GPL-exception-1.0
#pragma once
#include "debugger_global.h"
#include "debuggerconstants.h"
#include <projectexplorer/abi.h>
#include <utils/filepath.h>
#include <utils/environment.h>
#include <utils/store.h>
#include <QDateTime>
namespace Debugger {
namespace Internal {
class DebuggerConfigWidget;
class DebuggerItemConfigWidget;
class DebuggerItemModel;
} // namespace Internal
// -----------------------------------------------------------------------
// DebuggerItem
// -----------------------------------------------------------------------
class DEBUGGER_EXPORT DebuggerItem
{
public:
struct TechnicalData
{
static Utils::expected_str<DebuggerItem::TechnicalData> extract(
const Utils::FilePath &fromExecutable,
const std::optional<Utils::Environment> &customEnvironment);
bool isEmpty() const;
DebuggerEngineType engineType = NoEngineType;
ProjectExplorer::Abis abis;
QString version;
};
DebuggerItem() = default;
DebuggerItem(const Utils::Store &data);
void createId();
bool canClone() const { return true; }
bool isValid() const;
QString engineTypeName() const;
Utils::Store toMap() const;
QVariant id() const { return m_id; }
QString displayName() const;
QString unexpandedDisplayName() const { return m_unexpandedDisplayName; }
void setUnexpandedDisplayName(const QString &unexpandedDisplayName);
DebuggerEngineType engineType() const { return m_technicalData.engineType; }
void setEngineType(const DebuggerEngineType &engineType);
Utils::FilePath command() const { return m_command; }
void setCommand(const Utils::FilePath &command);
bool isAutoDetected() const { return m_isAutoDetected; }
void setAutoDetected(bool isAutoDetected);
QString version() const;
void setVersion(const QString &version);
const ProjectExplorer::Abis &abis() const { return m_technicalData.abis; }
void setAbis(const ProjectExplorer::Abis &abis);
void setAbi(const ProjectExplorer::Abi &abi);
enum MatchLevel { DoesNotMatch, MatchesSomewhat, MatchesWell, MatchesPerfectly, MatchesPerfectlyInPath };
MatchLevel matchTarget(const ProjectExplorer::Abi &targetAbi) const;
QStringList abiNames() const;
QDateTime lastModified() const;
void setLastModified(const QDateTime ×tamp);
// Keep enum sorted ascending by goodness.
enum class Problem { NoEngine, InvalidCommand, InvalidWorkingDir, None };
Problem problem() const;
QIcon decoration() const;
QString validityMessage() const;
bool operator==(const DebuggerItem &other) const;
bool operator!=(const DebuggerItem &other) const { return !operator==(other); }
void reinitializeFromFile(QString *error = nullptr, Utils::Environment *env = nullptr);
Utils::FilePath workingDirectory() const { return m_workingDirectory; }
void setWorkingDirectory(const Utils::FilePath &workingPath) { m_workingDirectory = workingPath; }
QString detectionSource() const { return m_detectionSource; }
void setDetectionSource(const QString &source) { m_detectionSource = source; }
bool isGeneric() const;
void setGeneric(bool on);
static bool addAndroidLldbPythonEnv(const Utils::FilePath &lldbCmd, Utils::Environment &env);
private:
DebuggerItem(const QVariant &id);
void initMacroExpander();
QVariant m_id;
QString m_unexpandedDisplayName;
TechnicalData m_technicalData;
Utils::FilePath m_command;
Utils::FilePath m_workingDirectory;
bool m_isAutoDetected = false;
QDateTime m_lastModified;
QString m_detectionSource;
friend class Internal::DebuggerConfigWidget;
friend class Internal::DebuggerItemConfigWidget;
friend class Internal::DebuggerItemModel;
};
} // namespace Debugger
|