Qt
Internal/Contributor docs for the Qt SDK. Note: These are NOT official API docs; those are found at https://doc.qt.io/
Loading...
Searching...
No Matches
qqmlmetatypedata_p.h
Go to the documentation of this file.
1// Copyright (C) 2019 The Qt Company Ltd.
2// SPDX-License-Identifier: LicenseRef-Qt-Commercial OR LGPL-3.0-only OR GPL-2.0-only OR GPL-3.0-only
3
4#ifndef QQMLMETATYPEDATA_P_H
5#define QQMLMETATYPEDATA_P_H
6
7//
8// W A R N I N G
9// -------------
10//
11// This file is not part of the Qt API. It exists purely as an
12// implementation detail. This header file may change from version to
13// version without notice, or even be removed.
14//
15// We mean it.
16//
17
18#include <private/qhashedstring_p.h>
19#include <private/qqmlmetatype_p.h>
20#include <private/qqmlscriptdata_p.h>
21#include <private/qqmltype_p.h>
22#include <private/qqmlvaluetype_p.h>
23
24#include <QtCore/qset.h>
25#include <QtCore/qvector.h>
26
27QT_BEGIN_NAMESPACE
28
29class QQmlTypePrivate;
31{
34 void registerType(QQmlTypePrivate *priv);
37 typedef QHash<int, QQmlTypePrivate *> Ids;
39
42
43 typedef QHash<QUrl, const QQmlTypePrivate *> Files; //For file imported composite types only
45
50
51 // This has to be a multihash because a user can create a compilation unit using arbitrary
52 // static data, via e.g. QQmlComponent::setData() or Qt.createQmlObject(). Since you can also
53 // freely choose the URL and therefore the metatype for those, we can end up we can end up
54 // with multiple compilation units per URL. Some compilation units need special handling on
55 // removal. Therefore we need to hold on to all of them.
59
60 struct VersionedUri {
61 VersionedUri() = default;
62 VersionedUri(const QString &uri, QTypeRevision version)
64 VersionedUri(const std::unique_ptr<QQmlTypeModule> &module);
65
66 friend bool operator==(const VersionedUri &a, const VersionedUri &b)
67 {
68 return a.majorVersion == b.majorVersion && a.uri == b.uri;
69 }
70
71 friend size_t qHash(const VersionedUri &v, size_t seed = 0)
72 {
73 return qHashMulti(seed, v.uri, v.majorVersion);
74 }
75
76 friend bool operator<(const QQmlMetaTypeData::VersionedUri &a,
78 {
79 const int diff = a.uri.compare(b.uri);
80 return diff < 0 || (diff == 0 && a.majorVersion < b.majorVersion);
81 }
82
85 };
86
89 QQmlTypeModule *findTypeModule(const QString &module, QTypeRevision version);
90 QQmlTypeModule *addTypeModule(std::unique_ptr<QQmlTypeModule> module);
91
94
96 bool registerModuleTypes(const QString &uri);
97
99
102
104
111
112 QQmlPropertyCache::ConstPtr propertyCacheForVersion(int index, QTypeRevision version) const;
114 int index, QTypeRevision version, const QQmlPropertyCache::ConstPtr &cache);
115 void clearPropertyCachesForVersion(int index);
116
117 QQmlPropertyCache::ConstPtr propertyCache(const QMetaObject *metaObject, QTypeRevision version);
118 QQmlPropertyCache::ConstPtr propertyCache(const QQmlType &type, QTypeRevision version);
120
121 void setTypeRegistrationFailures(QStringList *failures)
122 {
123 m_typeRegistrationFailures = failures;
124 }
125
126 void recordTypeRegFailure(const QString &message)
127 {
128 if (m_typeRegistrationFailures)
129 m_typeRegistrationFailures->append(message);
130 else
131 qWarning("%s", message.toUtf8().constData());
132 }
133
134 static void clearCompositeType(const QQmlRefPointer<QV4::CompiledData::CompilationUnit> &cu)
135 {
136 if (cu->isESModule())
137 cu->dependentScripts.clear();
138 }
139
140 void clearCompositeTypes();
142
143private:
144 QStringList *m_typeRegistrationFailures = nullptr;
145};
146
147QT_END_NAMESPACE
148
149#endif // QQMLMETATYPEDATA_P_H
static QQmlPropertyCache::ConstPtr propertyCacheForPotentialInlineComponentType(QMetaType t, const QQmlMetaTypeData::CompositeTypes::const_iterator &iter)
QQmlListMetaTypeInterface * listType
VersionedUri(const std::unique_ptr< QQmlTypeModule > &module)
friend size_t qHash(const VersionedUri &v, size_t seed=0)
friend bool operator<(const QQmlMetaTypeData::VersionedUri &a, const QQmlMetaTypeData::VersionedUri &b)
friend bool operator==(const VersionedUri &a, const VersionedUri &b)
VersionedUri(const QString &uri, QTypeRevision version)
QQmlTypeModule * addTypeModule(std::unique_ptr< QQmlTypeModule > module)
bool registerModuleTypes(const QString &uri)
QHash< int, QQmlTypePrivate * > Ids
MetaObjects metaObjectToType
QQmlTypeModule * findTypeModule(const QString &module, QTypeRevision version)
QHash< int, QQmlValueType * > metaTypeToValueType
QQmlPropertyCache::ConstPtr propertyCache(const QMetaObject *metaObject, QTypeRevision version)
QHash< const QMetaObject *, QQmlPropertyCache::ConstPtr > propertyCaches
QMultiHash< const QMetaObject *, QQmlTypePrivate * > MetaObjects
QQmlPropertyCache::ConstPtr propertyCache(const QQmlType &type, QTypeRevision version)
QVector< QQmlPrivate::QmlUnitCacheLookupFunction > lookupCachedQmlUnit
void registerType(QQmlTypePrivate *priv)
QVector< QHash< QTypeRevision, QQmlPropertyCache::ConstPtr > > typePropertyCaches
QHash< QString, void(*)()> moduleTypeRegistrationFunctions
QList< QQmlPrivate::AutoParentFunction > parentFunctions
QHash< QUrl, CompositeMetaTypes > compositeMetaTypes
CompositeTypes compositeTypes
ModuleImports moduleImports
QList< QQmlType > types
void setTypeRegistrationFailures(QStringList *failures)
QHash< QUrl, const QQmlTypePrivate * > Files
QSet< QQmlType > undeletableTypes
static void clearCompositeType(const QQmlRefPointer< QV4::CompiledData::CompilationUnit > &cu)
QQmlPropertyCache::ConstPtr findPropertyCacheInCompositeTypes(QMetaType t) const
QQmlPropertyCache::ConstPtr propertyCacheForVersion(int index, QTypeRevision version) const
void clearPropertyCachesForVersion(int index)
void setPropertyCacheForVersion(int index, QTypeRevision version, const QQmlPropertyCache::ConstPtr &cache)
void recordTypeRegFailure(const QString &message)