-
Notifications
You must be signed in to change notification settings - Fork 2
/
Copy pathpluginmanager.h
183 lines (151 loc) · 5.85 KB
/
pluginmanager.h
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
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
// 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 "extensionsystem_global.h"
#include <aggregation/aggregate.h>
#include <utils/qtcsettings.h>
#include <QObject>
#include <QStringList>
QT_BEGIN_NAMESPACE
class QTextStream;
QT_END_NAMESPACE
namespace ExtensionSystem {
class IPlugin;
class PluginSpec;
namespace Internal {
class PluginManagerPrivate;
}
class EXTENSIONSYSTEM_EXPORT PluginManager : public QObject
{
Q_OBJECT
public:
static auto instance() -> PluginManager *;
PluginManager();
~PluginManager() override;
// Object pool operations
static void addObject(QObject *obj);
static void removeObject(QObject *obj);
static auto allObjects() -> QVector<QObject *>;
static auto listLock() -> QReadWriteLock *;
// This is useful for soft dependencies using pure interfaces.
template<typename T>
static auto getObject() -> T *
{
QReadLocker lock(listLock());
const QVector<QObject *> all = allObjects();
for (QObject *obj : all) {
if (T *result = qobject_cast<T *>(obj))
return result;
}
return nullptr;
}
template<typename T, typename Predicate>
static auto getObject(Predicate predicate) -> T *
{
QReadLocker lock(listLock());
const QVector<QObject *> all = allObjects();
for (QObject *obj : all) {
if (T *result = qobject_cast<T *>(obj))
if (predicate(result))
return result;
}
return 0;
}
template<typename T>
static auto getObjects() -> QVector<T *>
{
QReadLocker lock(listLock());
QVector<T *> results;
QVector<QObject *> all = allObjects();
foreach (QObject *obj, all) {
T *result = qobject_cast<T *>(obj);
if (result)
results += result;
}
return results;
}
template<typename T, typename Predicate>
static auto getObjects(Predicate predicate) -> QVector<T *>
{
QReadLocker lock(listLock());
QVector<T *> results;
QVector<QObject *> all = allObjects();
foreach (QObject *obj, all) {
T *result = qobject_cast<T *>(obj);
if (result && predicate(result))
results += result;
}
return results;
}
static auto getObjectByName(const QString &name) -> QObject *;
// Plugin operations
static auto loadQueue() -> QVector<PluginSpec *>;
static void loadPlugins();
static auto pluginPaths() -> QStringList;
static void setPluginPaths(const QStringList &paths);
static auto pluginIID() -> QString;
static void setPluginIID(const QString &iid);
static auto plugins() -> const QVector<PluginSpec *>;
static auto pluginCollections() -> QHash<QString, QVector<PluginSpec *>>;
static auto hasError() -> bool;
static auto allErrors() -> const QStringList;
static auto pluginsRequiringPlugin(PluginSpec *spec) -> const QSet<PluginSpec *>;
static auto pluginsRequiredByPlugin(PluginSpec *spec) -> const QSet<PluginSpec *>;
static void checkForProblematicPlugins();
static auto specForPlugin(IPlugin *plugin) -> PluginSpec *;
// Settings
static void setSettings(Utils::QtcSettings *settings);
static auto settings() -> Utils::QtcSettings *;
static void setGlobalSettings(Utils::QtcSettings *settings);
static auto globalSettings() -> Utils::QtcSettings *;
static void writeSettings();
// command line arguments
static auto arguments() -> QStringList;
static auto argumentsForRestart() -> QStringList;
static auto parseOptions(const QStringList &args,
const QMap<QString, bool> &appOptions,
QMap<QString, QString> *foundAppOptions,
QString *errorString) -> bool;
static void formatOptions(QTextStream &str, int optionIndentation, int descriptionIndentation);
static void formatPluginOptions(QTextStream &str,
int optionIndentation,
int descriptionIndentation);
static void formatPluginVersions(QTextStream &str);
static auto serializedArguments() -> QString;
static auto testRunRequested() -> bool;
#ifdef WITH_TESTS
static bool registerScenario(const QString &scenarioId, std::function<bool()> scenarioStarter);
static bool isScenarioRequested();
static bool runScenario();
static bool isScenarioRunning(const QString &scenarioId);
// static void triggerScenarioPoint(const QVariant pointData); // ?? called from scenario point
static bool finishScenario();
static void waitForScenarioFullyInitialized();
// signals:
// void scenarioPointTriggered(const QVariant pointData); // ?? e.g. in StringTable::GC() -> post a call to quit into main thread and sleep for 5 seconds in the GC thread
#endif
struct ProcessData
{
QString m_executable;
QStringList m_args;
QString m_workingPath;
QString m_settingsPath;
};
static void setCreatorProcessData(const ProcessData &data);
static auto creatorProcessData() -> ProcessData;
static void profilingReport(const char *what, const PluginSpec *spec = nullptr);
static auto platformName() -> QString;
static auto isInitializationDone() -> bool;
static void remoteArguments(const QString &serializedArguments, QObject *socket);
static void shutdown();
//static QString systemInformation();
signals:
void objectAdded(QObject *obj);
void aboutToRemoveObject(QObject *obj);
void pluginsChanged();
void initializationDone();
void testsFinished(int failedTests);
void scenarioFinished(int exitCode);
friend class Internal::PluginManagerPrivate;
};
} // namespace ExtensionSystem