/**************************************************************************** ** ** Copyright (C) 2009 Nokia Corporation and/or its subsidiary(-ies). ** Contact: Qt Software Information (qt-info@nokia.com) ** ** This file is part of the QtDeclarative module of the Qt Toolkit. ** ** $QT_BEGIN_LICENSE:LGPL$ ** No Commercial Usage ** This file contains pre-release code and may not be distributed. ** You may use this file in accordance with the terms and conditions ** contained in the either Technology Preview License Agreement or the ** Beta Release License Agreement. ** ** GNU Lesser General Public License Usage ** Alternatively, this file may be used under the terms of the GNU Lesser ** General Public License version 2.1 as published by the Free Software ** Foundation and appearing in the file LICENSE.LGPL included in the ** packaging of this file. Please review the following information to ** ensure the GNU Lesser General Public License version 2.1 requirements ** will be met: http://www.gnu.org/licenses/old-licenses/lgpl-2.1.html. ** ** In addition, as a special exception, Nokia gives you certain ** additional rights. These rights are described in the Nokia Qt LGPL ** Exception version 1.0, included in the file LGPL_EXCEPTION.txt in this ** package. ** ** GNU General Public License Usage ** Alternatively, this file may be used under the terms of the GNU ** General Public License version 3.0 as published by the Free Software ** Foundation and appearing in the file LICENSE.GPL included in the ** packaging of this file. Please review the following information to ** ensure the GNU General Public License version 3.0 requirements will be ** met: http://www.gnu.org/copyleft/gpl.html. ** ** If you are unsure which license is appropriate for your use, please ** contact the sales department at qt-sales@nokia.com. ** $QT_END_LICENSE$ ** ****************************************************************************/ #ifndef QMLPRIVATE_H #define QMLPRIVATE_H #include #ifndef Q_OS_WIN #include #endif #include QT_BEGIN_HEADER QT_BEGIN_NAMESPACE QT_MODULE(Declarative) typedef QObject *(*QmlAttachedPropertiesFunc)(QObject *); namespace QmlPrivate { class ListInterface { public: virtual ~ListInterface() {} virtual int type() const = 0; virtual void append(void *) = 0; virtual void insert(int, void *) = 0; virtual void removeAt(int) = 0; virtual void at(int, void *) const = 0; virtual int count() const = 0; virtual void clear() = 0; }; enum ListOp { Append, Set, Insert, Prepend, Length, FromObject, Object, Create, Value, Clear }; template int list_op(ListOp op, int val, const QVariant &vlist, const QVariant &value, void **out); template int list_nocreate_op(ListOp op, int val, const QVariant &vlist, const QVariant &value, void **out); template int list_interface_op(ListOp op, int val, const QVariant &vlist, const QVariant &value, void **out); template struct StaticCastSelectorClass { static inline int cast() { return -1; } }; template struct StaticCastSelectorClass { #ifndef Q_OS_SYMBIAN static inline int cast() { return (int)((intptr_t)static_cast((From *)0x10000000)) - 0x10000000; } #else static inline int cast() { return (int)(static_cast((From *)0x10000000)) - 0x10000000; } #endif }; template struct StaticCastSelector { typedef int yes_type; typedef char no_type; static yes_type check(To *); static no_type check(...); static inline int cast() { return StaticCastSelectorClass::cast(); } }; #if defined(Q_CC_MSVC) template class has_attachedPropertiesMember { public: __if_exists(T::qmlAttachedProperties) { static bool const value = true; } __if_not_exists(T::qmlAttachedProperties) { static bool const value = false; } }; #else template class has_attachedPropertiesMember { typedef int yes_type; typedef char no_type; template struct Selector {}; template static yes_type test(Selector*); template static no_type test(...); public: static bool const value = sizeof(test(0)) == sizeof(yes_type); }; #endif template class has_attachedPropertiesMethod { typedef int yes_type; typedef char no_type; template static yes_type check(ReturnType *(*)(QObject *)); static no_type check(...); public: static bool const value = sizeof(check(&T::qmlAttachedProperties)) == sizeof(yes_type); }; template class has_attachedPropertiesMethod { public: static bool const value = false; }; template class AttachedPropertySelector { public: static inline QmlAttachedPropertiesFunc func() { return 0; } static inline const QMetaObject *metaObject() { return 0; } }; template class AttachedPropertySelector { static inline QObject *attachedProperties(QObject *obj) { return T::qmlAttachedProperties(obj); } template static inline const QMetaObject *attachedPropertiesMetaObject(ReturnType *(*)(QObject *)) { return &ReturnType::staticMetaObject; } public: static inline QmlAttachedPropertiesFunc func() { return &attachedProperties; } static inline const QMetaObject *metaObject() { return attachedPropertiesMetaObject(&T::qmlAttachedProperties); } }; template inline QmlAttachedPropertiesFunc attachedPropertiesFunc() { return AttachedPropertySelector::value>::value>::func(); } template inline const QMetaObject *attachedPropertiesMetaObject() { return AttachedPropertySelector::value>::value>::metaObject(); } struct MetaTypeIds { int typeId; int listId; int qmlListId; }; typedef int (*Func)(QmlPrivate::ListOp, int, const QVariant &, const QVariant &, void **); typedef QObject *(*CreateFunc)(QObject *); template struct CreateParent { static QObject *create(QObject *other) { return new T(other); } }; template struct CreateNoParent { static QObject *create() { return new T; } }; struct Q_DECLARATIVE_EXPORT InstanceType { InstanceType(int); }; template struct Define { static InstanceType instance; }; template struct ExtCreate { static QObject *create(QObject *other) { return new T(other); } }; } template int QmlPrivate::list_op(QmlPrivate::ListOp op, int val, const QVariant &vlist, const QVariant &value, void **out) { if (op == QmlPrivate::Create) { QObject *obj = static_cast(new T); *((QObject **)out) = obj; return 0; } QList *list = vlist.value *>(); switch(op) { case QmlPrivate::Append: list->append(value.value()); break; case QmlPrivate::Set: (*list)[val] = value.value(); break; case QmlPrivate::Insert: list->insert(val, value.value()); break; case QmlPrivate::Prepend: list->prepend(value.value()); break; case QmlPrivate::Length: return list->count(); break; case QmlPrivate::Clear: list->clear(); return 0; break; case QmlPrivate::Create: break; case QmlPrivate::Object: *out = static_cast(value.value()); break; case QmlPrivate::FromObject: { QObject *fromObj = value.value(); T *me = qobject_cast(fromObj); if (me) { *((QVariant *)*out) = QVariant::fromValue(me); } } break; case QmlPrivate::Value: *((QVariant *)*out) = QVariant::fromValue(list->at(val)); break; } return 0; } template int QmlPrivate::list_nocreate_op(QmlPrivate::ListOp op, int val, const QVariant &vlist, const QVariant &value, void **out) { QList *list = vlist.value *>(); switch(op) { case QmlPrivate::Append: list->append(value.value()); break; case QmlPrivate::Set: (*list)[val] = value.value(); break; case QmlPrivate::Insert: list->insert(val, value.value()); break; case QmlPrivate::Prepend: list->prepend(value.value()); break; case QmlPrivate::Length: return list->count(); break; case QmlPrivate::Clear: list->clear(); return 0; break; case QmlPrivate::Create: break; case QmlPrivate::Object: *out = static_cast(value.value()); break; case QmlPrivate::FromObject: { QObject *fromObj = value.value(); T *me = qobject_cast(fromObj); if (me) { *((QVariant *)*out) = QVariant::fromValue(me); } } break; case QmlPrivate::Value: *((QVariant *)*out) = QVariant::fromValue(list->at(val)); break; } return 0; } template int QmlPrivate::list_interface_op(QmlPrivate::ListOp op, int val, const QVariant &vlist, const QVariant &value, void **out) { QList *list = vlist.value *>(); switch(op) { case QmlPrivate::Append: list->append(value.value()); break; case QmlPrivate::Set: (*list)[val] = value.value(); break; case QmlPrivate::Insert: list->insert(val, value.value()); break; case QmlPrivate::Prepend: list->prepend(value.value()); break; case QmlPrivate::Length: return list->count(); break; case QmlPrivate::Clear: list->clear(); return 0; break; case QmlPrivate::Create: break; case QmlPrivate::Object: break; case QmlPrivate::FromObject: break; case QmlPrivate::Value: *((QVariant *)*out) = QVariant::fromValue(list->at(val)); break; } return 0; } QT_END_NAMESPACE QT_END_HEADER #endif // QMLPRIVATE_H