// Copyright (C) 2016 The Qt Company Ltd. // SPDX-License-Identifier: LicenseRef-Qt-Commercial OR GPL-3.0 WITH Qt-GPL-exception-1.0 #pragma once #include "pluginspec.h" #include "pluginmanager.h" #include #include #include #include #include #include #include #include #include #include QT_BEGIN_NAMESPACE class QTime; class QTimer; class QEventLoop; QT_END_NAMESPACE namespace Utils { class QtcSettings; } namespace ExtensionSystem { class PluginManager; namespace Internal { class PluginSpecPrivate; class EXTENSIONSYSTEM_EXPORT PluginManagerPrivate : public QObject { Q_OBJECT public: PluginManagerPrivate(PluginManager *pluginManager); ~PluginManagerPrivate() override; // Object pool operations void addObject(QObject *obj); void removeObject(QObject *obj); // Plugin operations void checkForProblematicPlugins(); void loadPlugins(); void shutdown(); void setPluginPaths(const QStringList &paths); const QVector loadQueue(); void loadPlugin(PluginSpec *spec, PluginSpec::State destState); void resolveDependencies(); void enableDependenciesIndirectly(); void initProfiling(); void profilingSummary() const; void profilingReport(const char *what, const PluginSpec *spec = nullptr); void setSettings(Utils::QtcSettings *settings); void setGlobalSettings(Utils::QtcSettings *settings); void readSettings(); void writeSettings(); class TestSpec { public: TestSpec(PluginSpec *pluginSpec, const QStringList &testFunctionsOrObjects = QStringList()) : pluginSpec(pluginSpec) , testFunctionsOrObjects(testFunctionsOrObjects) {} PluginSpec *pluginSpec = nullptr; QStringList testFunctionsOrObjects; }; bool containsTestSpec(PluginSpec *pluginSpec) const { return Utils::contains(testSpecs, [pluginSpec](const TestSpec &s) { return s.pluginSpec == pluginSpec; }); } void removeTestSpec(PluginSpec *pluginSpec) { testSpecs = Utils::filtered(testSpecs, [pluginSpec](const TestSpec &s) { return s.pluginSpec != pluginSpec; }); } QHash> pluginCategories; QVector pluginSpecs; std::vector testSpecs; QStringList pluginPaths; QString pluginIID; QVector allObjects; // ### make this a QVector > > ? QStringList defaultDisabledPlugins; // Plugins/Ignored from install settings QStringList defaultEnabledPlugins; // Plugins/ForceEnabled from install settings QStringList disabledPlugins; QStringList forceEnabledPlugins; // delayed initialization QTimer *delayedInitializeTimer = nullptr; std::queue delayedInitializeQueue; // ansynchronous shutdown QSet asynchronousPlugins; // plugins that have requested async shutdown QEventLoop *shutdownEventLoop = nullptr; // used for async shutdown QStringList arguments; QStringList argumentsForRestart; QScopedPointer m_profileTimer; QHash m_profileTotal; int m_profileElapsedMS = 0; unsigned m_profilingVerbosity = 0; Utils::QtcSettings *settings = nullptr; Utils::QtcSettings *globalSettings = nullptr; // Look in argument descriptions of the specs for the option. PluginSpec *pluginForOption(const QString &option, bool *requiresArgument) const; PluginSpec *pluginByName(const QString &name) const; // used by tests static PluginSpec *createSpec(); static PluginSpecPrivate *privateSpec(PluginSpec *spec); mutable QReadWriteLock m_lock; bool m_isInitializationDone = false; bool enableCrashCheck = true; QHash> m_scenarios; QString m_requestedScenario; std::atomic_bool m_isScenarioRunning = false; // if it's running, the running one is m_requestedScenario std::atomic_bool m_isScenarioFinished = false; // if it's running, the running one is m_requestedScenario bool m_scenarioFullyInitialized = false; QMutex m_scenarioMutex; QWaitCondition m_scenarioWaitCondition; PluginManager::ProcessData m_creatorProcessData; private: PluginManager *q; void nextDelayedInitialize(); void readPluginPaths(); bool loadQueue(PluginSpec *spec, QVector &queue, QVector &circularityCheckQueue); void stopAll(); void deleteAll(); #ifdef WITH_TESTS void startTests(); #endif }; } // namespace Internal } // namespace ExtensionSystem