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
|
// Copyright (C) 2017 The Qt Company Ltd.
// Copyright (C) 2022 Intel Corporation.
// SPDX-License-Identifier: LicenseRef-Qt-Commercial OR LGPL-3.0-only OR GPL-2.0-only OR GPL-3.0-only
#ifndef QFACTORYLOADER_P_H
#define QFACTORYLOADER_P_H
//
// W A R N I N G
// -------------
//
// This file is not part of the Qt API. It exists purely as an
// implementation detail. This header file may change from version to
// version without notice, or even be removed.
//
// We mean it.
//
#include "QtCore/qglobal.h"
#ifndef QT_NO_QOBJECT
#include "QtCore/private/qplugin_p.h"
#include "QtCore/private/qduplicatetracker_p.h"
#include "QtCore/qcoreapplication.h"
#include "QtCore/qmap.h"
#include "QtCore/qmutex.h"
#include "QtCore/qobject.h"
#include "QtCore/qplugin.h"
#if QT_CONFIG(library)
# include "QtCore/private/qlibrary_p.h"
#endif
QT_BEGIN_NAMESPACE
class QJsonObject;
class QLibraryPrivate;
class Q_CORE_EXPORT QFactoryLoader
{
Q_DECLARE_TR_FUNCTIONS(QFactoryLoader);
public:
explicit QFactoryLoader(const char *iid,
const QString &suffix = QString(),
Qt::CaseSensitivity = Qt::CaseSensitive);
#if QT_CONFIG(library)
~QFactoryLoader();
void setLoadHints(QLibrary::LoadHints hints);
void update();
static void refreshAll();
#if defined(Q_OS_UNIX) && !defined (Q_OS_DARWIN)
QLibraryPrivate *library(const QString &key) const;
#endif // Q_OS_UNIX && !Q_OS_DARWIN
#endif // QT_CONFIG(library)
void setExtraSearchPath(const QString &path);
QMultiMap<int, QString> keyMap() const;
int indexOf(const QString &needle) const;
using MetaDataList = QList<QPluginParsedMetaData>;
MetaDataList metaData() const;
QList<QCborArray> metaDataKeys() const;
QObject *instance(int index) const;
private:
struct Private {
QByteArray iid;
mutable QMutex mutex;
mutable QList<QtPluginInstanceFunction> usedStaticInstances;
#if QT_CONFIG(library)
QDuplicateTracker<QString> loadedPaths;
std::vector<QLibraryPrivate::UniquePtr> libraries;
mutable QList<bool> loadedLibraries;
std::map<QString, QLibraryPrivate*> keyMap;
QString suffix;
QString extraSearchPath;
Qt::CaseSensitivity cs;
QLibrary::LoadHints loadHints;
void updateSinglePath(const QString &pluginDir);
#endif
// for compat when we d was a pointer
auto operator->() { return this; }
auto operator->() const { return this; }
} d;
inline QObject *instanceHelper_locked(int index) const;
};
template <class PluginInterface, class FactoryInterface, typename ...Args>
PluginInterface *qLoadPlugin(const QFactoryLoader *loader, const QString &key, Args &&...args)
{
const int index = loader->indexOf(key);
if (index != -1) {
QObject *factoryObject = loader->instance(index);
if (FactoryInterface *factory = qobject_cast<FactoryInterface *>(factoryObject))
if (PluginInterface *result = factory->create(key, std::forward<Args>(args)...))
return result;
}
return nullptr;
}
template <class PluginInterface, class FactoryInterface, typename Arg>
Q_DECL_DEPRECATED PluginInterface *qLoadPlugin1(const QFactoryLoader *loader, const QString &key, Arg &&arg)
{ return qLoadPlugin<PluginInterface, FactoryInterface>(loader, key, std::forward<Arg>(arg)); }
QT_END_NAMESPACE
#endif // QT_NO_QOBJECT
#endif // QFACTORYLOADER_P_H
|