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);
35
41
44
45 typedef QHash<int, QQmlTypePrivate *> Ids;
47
50
51 typedef QHash<QUrl, const QQmlTypePrivate *> Files; //For file imported composite types only
53
57
58 // This has to be a multihash because a user can create a compilation unit using arbitrary
59 // static data, via e.g. QQmlComponent::setData() or Qt.createQmlObject(). Since you can also
60 // freely choose the URL and therefore the metatype for those, we can end up we can end up
61 // with multiple compilation units per URL. Some compilation units need special handling on
62 // removal. Therefore we need to hold on to all of them.
66
67 struct VersionedUri {
68 VersionedUri() = default;
69 VersionedUri(const QString &uri, QTypeRevision version)
71 VersionedUri(const std::unique_ptr<QQmlTypeModule> &module);
72
73 friend bool operator==(const VersionedUri &a, const VersionedUri &b)
74 {
75 return a.majorVersion == b.majorVersion && a.uri == b.uri;
76 }
77
78 friend size_t qHash(const VersionedUri &v, size_t seed = 0)
79 {
80 return qHashMulti(seed, v.uri, v.majorVersion);
81 }
82
83 friend bool operator<(const QQmlMetaTypeData::VersionedUri &a,
85 {
86 const int diff = a.uri.compare(b.uri);
87 return diff < 0 || (diff == 0 && a.majorVersion < b.majorVersion);
88 }
89
92 };
93
96 QQmlTypeModule *findTypeModule(const QString &module, QTypeRevision version);
97 QQmlTypeModule *addTypeModule(std::unique_ptr<QQmlTypeModule> module);
98
101
103 bool registerModuleTypes(const QString &uri);
104
107
109
116
117 QQmlPropertyCache::ConstPtr propertyCacheForVersion(int index, QTypeRevision version) const;
119 int index, QTypeRevision version, const QQmlPropertyCache::ConstPtr &cache);
120
121 QQmlPropertyCache::ConstPtr propertyCache(const QMetaObject *metaObject, QTypeRevision version);
122 QQmlPropertyCache::ConstPtr propertyCache(const QQmlType &type, QTypeRevision version);
124
126 QMetaType t, const QQmlMetaTypeData::CompositeTypes::const_iterator &iter);
127
128 void setTypeRegistrationFailures(QStringList *failures)
129 {
130 m_typeRegistrationFailures = failures;
131 }
132
133 void recordTypeRegFailure(const QString &message)
134 {
135 if (m_typeRegistrationFailures)
136 m_typeRegistrationFailures->append(message);
137 else
138 qWarning("%s", message.toUtf8().constData());
139 }
140
141 static void clearCompositeType(const QQmlRefPointer<QV4::CompiledData::CompilationUnit> &cu)
142 {
143 if (cu->isESModule())
144 cu->dependentScripts.clear();
145 }
146
147 void clearCompositeTypes();
149private:
150 QStringList *m_typeRegistrationFailures = nullptr;
151};
152
153QT_END_NAMESPACE
154
155#endif // QQMLMETATYPEDATA_P_H
Combined button and popup list for selecting options.
QQmlListMetaTypeInterface * listType
QHash< QTypeRevision, QQmlPropertyCache::ConstPtr > propertyCaches
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)
static QQmlPropertyCache::ConstPtr propertyCacheForPotentialInlineComponentType(QMetaType t, const QQmlMetaTypeData::CompositeTypes::const_iterator &iter)
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
QQmlPropertyCache::ConstPtr propertyCache(const QQmlType &type, QTypeRevision version)
QList< QQmlPrivate::QmlUnitCacheLookupFunction > lookupCachedQmlUnit
void registerType(QQmlTypePrivate *priv)
QHash< QString, void(*)()> moduleTypeRegistrationFunctions
QList< QQmlPrivate::AutoParentFunction > parentFunctions
QHash< QUrl, CompositeMetaTypes > compositeMetaTypes
CompositeTypes compositeTypes
QMultiHash< const QMetaObject *, const QQmlTypePrivate * > MetaObjects
ModuleImports moduleImports
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 setPropertyCacheForVersion(int index, QTypeRevision version, const QQmlPropertyCache::ConstPtr &cache)
void recordTypeRegFailure(const QString &message)