/**************************************************************************** ** ** Copyright (C) 2021 The Qt Company Ltd. ** Contact: https://www.qt.io/licensing/ ** ** This file is part of the QtQml module of the Qt Toolkit. ** ** $QT_BEGIN_LICENSE:COMM$ ** ** Commercial License Usage ** Licensees holding valid commercial Qt licenses may use this file in ** accordance with the commercial license agreement provided with the ** Software or, alternatively, in accordance with the terms contained in ** a written agreement between you and The Qt Company. For licensing terms ** and conditions see https://www.qt.io/terms-conditions. For further ** information use the contact form at https://www.qt.io/contact-us. ** ** $QT_END_LICENSE$ ** ** ** ** ** ** ** ** ** ** ** ** ** ** ** ** ** ** ** ****************************************************************************/ #ifndef QQMLTYPE_P_P_H #define QQMLTYPE_P_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 #include #include #include #include #include QT_BEGIN_NAMESPACE class QQmlTypePrivate : public QQmlRefCount { Q_DISABLE_COPY_MOVE(QQmlTypePrivate) public: QQmlTypePrivate(QQmlType::RegistrationType type); void init() const; void initEnums(QQmlEnginePrivate *engine) const; void insertEnums(const QMetaObject *metaObject) const; void insertEnumsFromPropertyCache(const QQmlPropertyCache *cache) const; void setContainingType(QQmlType *containingType); QUrl sourceUrl() const { switch (regType) { case QQmlType::CompositeType: return extraData.fd->url; case QQmlType::CompositeSingletonType: return extraData.sd->singletonInstanceInfo->url; case QQmlType::InlineComponentType: return extraData.id->url; default: return QUrl(); } } const QQmlTypePrivate *attachedPropertiesBase(QQmlEnginePrivate *engine) const { for (const QQmlTypePrivate *d = this; d; d = d->resolveCompositeBaseType(engine).d.data()) { if (d->regType == QQmlType::CppType) return d->extraData.cd->attachedPropertiesType ? d : nullptr; if (d->regType != QQmlType::CompositeType) return nullptr; } return nullptr; } bool isComposite() const { return regType == QQmlType::CompositeType || regType == QQmlType::CompositeSingletonType; } QQmlType resolveCompositeBaseType(QQmlEnginePrivate *engine) const; QQmlPropertyCache *compositePropertyCache(QQmlEnginePrivate *engine) const; QQmlType::RegistrationType regType; struct QQmlCppTypeData { int allocationSize; void (*newFunc)(void *); QString noCreationReason; int parserStatusCast; QObject *(*extFunc)(QObject *); const QMetaObject *extMetaObject; QQmlCustomParser *customParser; QQmlAttachedPropertiesFunc attachedPropertiesFunc; const QMetaObject *attachedPropertiesType; int propertyValueSourceCast; int propertyValueInterceptorCast; bool registerEnumClassesUnscoped; }; struct QQmlSingletonTypeData { QQmlType::SingletonInstanceInfo *singletonInstanceInfo; }; struct QQmlCompositeTypeData { QUrl url; }; struct QQmlInlineTypeData { QUrl url = QUrl(); // The containing type stores a pointer to the inline component type // Using QQmlType here would create a reference cycle // As the inline component type cannot outlive the containing type // this should still be fine QQmlTypePrivate const * containingType = nullptr; QString inlineComponentName = QString(); int objectId = -1; }; union extraData { QQmlCppTypeData* cd; QQmlSingletonTypeData* sd; QQmlCompositeTypeData* fd; QQmlInlineTypeData* id; } extraData; const char *iid; QHashedString module; QString name; QString elementName; int version_maj; int version_min; int typeId; int listId; int revision; mutable bool containsRevisionedAttributes; mutable QQmlType superType; const QMetaObject *baseMetaObject; int index; mutable volatile bool isSetup:1; mutable volatile bool isEnumFromCacheSetup:1; mutable volatile bool isEnumFromBaseSetup:1; mutable bool haveSuperType:1; mutable QList metaObjects; mutable QStringHash enums; mutable QStringHash scopedEnumIndex; // maps from enum name to index in scopedEnums mutable QList*> scopedEnums; void setName(const QString &uri, const QString &element); mutable QHash namesToInlineComponentObjectIndex; mutable QHash objectIdToICType; private: ~QQmlTypePrivate() override; struct EnumInfo { QStringList path; QString metaObjectName; QString enumName; QString enumKey; QString metaEnumScope; bool scoped; }; void createListOfPossibleConflictingItems(const QMetaObject *metaObject, QList &enumInfoList, QStringList path) const; void createEnumConflictReport(const QMetaObject *metaObject, const QString &conflictingKey) const; }; QT_END_NAMESPACE #endif // QQMLTYPE_P_P_H