From 4255220c35414dee49ab1c1c48bb96d44e4a241a Mon Sep 17 00:00:00 2001 From: Thomas Hartmann Date: Tue, 19 Oct 2010 16:15:32 +0200 Subject: QmlJS: Fixing type hierarchy for holes (non exported types) Done-with: Christian Kamm --- src/libs/qmljs/qmljsinterpreter.h | 13 +++++++++++-- 1 file changed, 11 insertions(+), 2 deletions(-) (limited to 'src/libs/qmljs/qmljsinterpreter.h') diff --git a/src/libs/qmljs/qmljsinterpreter.h b/src/libs/qmljs/qmljsinterpreter.h index 8288d7871c4..586e8a81629 100644 --- a/src/libs/qmljs/qmljsinterpreter.h +++ b/src/libs/qmljs/qmljsinterpreter.h @@ -383,7 +383,8 @@ private: class QMLJS_EXPORT QmlObjectValue: public ObjectValue { public: - QmlObjectValue(const FakeMetaObject *metaObject, int exportIndex, Engine *engine); + QmlObjectValue(const FakeMetaObject *metaObject, const QString &className, + const QString &packageName, const ComponentVersion version, Engine *engine); virtual ~QmlObjectValue(); virtual void processMembers(MemberProcessor *processor) const; @@ -404,7 +405,8 @@ protected: private: const FakeMetaObject *_metaObject; - const int _exportIndex; + const QString _packageName; + const ComponentVersion _componentVersion; mutable QHash _metaSignature; }; @@ -534,7 +536,14 @@ public: QHash types() const { return _typesByFullyQualifiedName; } + static QString qualifiedName(const QString &package, const QString &type, ComponentVersion version); + QmlObjectValue *typeByQualifiedName(const QString &name) const; + QmlObjectValue *typeByQualifiedName(const QString &package, const QString &type, ComponentVersion version) const; + private: + QmlObjectValue *getOrCreate(const QString &package, const QString &cppName, const FakeMetaObject *metaObject, Engine *engine, bool *created); + + QHash > _typesByPackage; QHash _typesByFullyQualifiedName; }; -- cgit v1.2.3