/**************************************************************************** ** ** Copyright (C) 2016 The Qt Company Ltd. ** Copyright (C) 2016 BasysKom GmbH. ** Contact: https://www.qt.io/licensing/ ** ** This file is part of the QtQml module of the Qt Toolkit. ** ** $QT_BEGIN_LICENSE:LGPL$ ** 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. ** ** GNU Lesser General Public License Usage ** Alternatively, this file may be used under the terms of the GNU Lesser ** General Public License version 3 as published by the Free Software ** Foundation and appearing in the file LICENSE.LGPL3 included in the ** packaging of this file. Please review the following information to ** ensure the GNU Lesser General Public License version 3 requirements ** will be met: https://www.gnu.org/licenses/lgpl-3.0.html. ** ** GNU General Public License Usage ** Alternatively, this file may be used under the terms of the GNU ** General Public License version 2.0 or (at your option) the GNU General ** Public license version 3 or any later version approved by the KDE Free ** Qt Foundation. The licenses are as published by the Free Software ** Foundation and appearing in the file LICENSE.GPL2 and LICENSE.GPL3 ** included in the packaging of this file. Please review the following ** information to ensure the GNU General Public License requirements will ** be met: https://www.gnu.org/licenses/gpl-2.0.html and ** https://www.gnu.org/licenses/gpl-3.0.html. ** ** $QT_END_LICENSE$ ** ****************************************************************************/ #ifndef QQMLVMEMETAOBJECT_P_H #define QQMLVMEMETAOBJECT_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 "qqml.h" #include #include #include #include #include #include #include #include "qqmlguard_p.h" #include "qqmlcontext_p.h" #include "qqmlpropertycache_p.h" #include #include #include #include #include QT_BEGIN_NAMESPACE class QQmlVMEMetaObject; class QQmlVMEVariantQObjectPtr : public QQmlGuard { public: inline QQmlVMEVariantQObjectPtr(); inline ~QQmlVMEVariantQObjectPtr(); inline void objectDestroyed(QObject *) override; inline void setGuardedValue(QObject *obj, QQmlVMEMetaObject *target, int index); QQmlVMEMetaObject *m_target; int m_index; }; class Q_QML_PRIVATE_EXPORT QQmlInterceptorMetaObject : public QAbstractDynamicMetaObject { public: QQmlInterceptorMetaObject(QObject *obj, QQmlPropertyCache *cache); ~QQmlInterceptorMetaObject(); void registerInterceptor(QQmlPropertyIndex index, QQmlPropertyValueInterceptor *interceptor); static QQmlInterceptorMetaObject *get(QObject *obj); QAbstractDynamicMetaObject *toDynamicMetaObject(QObject *o) Q_DECL_OVERRIDE; // Used by auto-tests for inspection QQmlPropertyCache *propertyCache() const { return cache; } bool intercepts(QQmlPropertyIndex propertyIndex) const { for (auto it = interceptors; it; it = it->m_next) { if (it->m_propertyIndex == propertyIndex) return true; } if (auto parentInterceptor = ((parent.isT1() && parent.flag()) ? static_cast(parent.asT1()) : 0)) return parentInterceptor->intercepts(propertyIndex); return false; } protected: int metaCall(QObject *o, QMetaObject::Call c, int id, void **a) Q_DECL_OVERRIDE; bool intercept(QMetaObject::Call c, int id, void **a); public: QObject *object; QQmlRefPointer cache; QBiPointer parent; QQmlPropertyValueInterceptor *interceptors; bool hasAssignedMetaObjectData; }; inline QQmlInterceptorMetaObject *QQmlInterceptorMetaObject::get(QObject *obj) { if (obj) { if (QQmlData *data = QQmlData::get(obj)) { if (data->hasInterceptorMetaObject) return static_cast(QObjectPrivate::get(obj)->metaObject); } } return 0; } class QQmlVMEMetaObjectEndpoint; class Q_QML_PRIVATE_EXPORT QQmlVMEMetaObject : public QQmlInterceptorMetaObject { public: QQmlVMEMetaObject(QV4::ExecutionEngine *engine, QObject *obj, QQmlPropertyCache *cache, QV4::CompiledData::CompilationUnit *qmlCompilationUnit, int qmlObjectId); ~QQmlVMEMetaObject(); bool aliasTarget(int index, QObject **target, int *coreIndex, int *valueTypeIndex) const; QV4::ReturnedValue vmeMethod(int index) const; void setVmeMethod(int index, const QV4::Value &function); QV4::ReturnedValue vmeProperty(int index) const; void setVMEProperty(int index, const QV4::Value &v); void connectAliasSignal(int index, bool indexInSignalRange); static inline QQmlVMEMetaObject *get(QObject *o); static QQmlVMEMetaObject *getForProperty(QObject *o, int coreIndex); static QQmlVMEMetaObject *getForMethod(QObject *o, int coreIndex); static QQmlVMEMetaObject *getForSignal(QObject *o, int coreIndex); protected: int metaCall(QObject *o, QMetaObject::Call _c, int _id, void **_a) Q_DECL_OVERRIDE; public: QV4::ExecutionEngine *engine; QQmlGuardedContextData ctxt; inline int propOffset() const; inline int methodOffset() const; inline int signalOffset() const; inline int signalCount() const; QQmlVMEMetaObjectEndpoint *aliasEndpoints; QV4::WeakValue propertyAndMethodStorage; QV4::MemberData *propertyAndMethodStorageAsMemberData() const; int readPropertyAsInt(int id) const; bool readPropertyAsBool(int id) const; double readPropertyAsDouble(int id) const; QString readPropertyAsString(int id) const; QSizeF readPropertyAsSizeF(int id) const; QPointF readPropertyAsPointF(int id) const; QUrl readPropertyAsUrl(int id) const; QDate readPropertyAsDate(int id) const; QDateTime readPropertyAsDateTime(int id); QRectF readPropertyAsRectF(int id) const; QObject *readPropertyAsQObject(int id) const; QList *readPropertyAsList(int id) const; void writeProperty(int id, int v); void writeProperty(int id, bool v); void writeProperty(int id, double v); void writeProperty(int id, const QString& v); void writeProperty(int id, const QPointF& v); void writeProperty(int id, const QSizeF& v); void writeProperty(int id, const QUrl& v); void writeProperty(int id, const QDate& v); void writeProperty(int id, const QDateTime& v); void writeProperty(int id, const QRectF& v); void writeProperty(int id, QObject *v); void ensureQObjectWrapper(); void mark(QV4::ExecutionEngine *e); void connectAlias(int aliasId); QV4::ReturnedValue method(int) const; QV4::ReturnedValue readVarProperty(int) const; void writeVarProperty(int, const QV4::Value &); QVariant readPropertyAsVariant(int) const; void writeProperty(int, const QVariant &); inline QQmlVMEMetaObject *parentVMEMetaObject() const; void activate(QObject *, int, void **); QList varObjectGuards; QQmlVMEVariantQObjectPtr *getQObjectGuardForProperty(int) const; // keep a reference to the compilation unit in order to still // do property access when the context has been invalidated. QQmlRefPointer compilationUnit; const QV4::CompiledData::Object *compiledObject; }; QQmlVMEMetaObject *QQmlVMEMetaObject::get(QObject *obj) { if (obj) { if (QQmlData *data = QQmlData::get(obj)) { if (data->hasVMEMetaObject) return static_cast(QObjectPrivate::get(obj)->metaObject); } } return 0; } int QQmlVMEMetaObject::propOffset() const { return cache->propertyOffset(); } int QQmlVMEMetaObject::methodOffset() const { return cache->methodOffset(); } int QQmlVMEMetaObject::signalOffset() const { return cache->signalOffset(); } int QQmlVMEMetaObject::signalCount() const { return cache->signalCount(); } QQmlVMEMetaObject *QQmlVMEMetaObject::parentVMEMetaObject() const { if (parent.isT1() && parent.flag()) return static_cast(parent.asT1()); return 0; } QT_END_NAMESPACE #endif // QQMLVMEMETAOBJECT_P_H