diff options
Diffstat (limited to 'src/qmlcompiler/qqmljsscopesbyid_p.h')
-rw-r--r-- | src/qmlcompiler/qqmljsscopesbyid_p.h | 30 |
1 files changed, 20 insertions, 10 deletions
diff --git a/src/qmlcompiler/qqmljsscopesbyid_p.h b/src/qmlcompiler/qqmljsscopesbyid_p.h index 77ad1947ab..c9dca9ae34 100644 --- a/src/qmlcompiler/qqmljsscopesbyid_p.h +++ b/src/qmlcompiler/qqmljsscopesbyid_p.h @@ -22,6 +22,12 @@ QT_BEGIN_NAMESPACE +enum QQmlJSScopesByIdOption: char { + Default = 0, + AssumeComponentsAreBound = 1, +}; +Q_DECLARE_FLAGS(QQmlJSScopesByIdOptions, QQmlJSScopesByIdOption); + class QQmlJSScopesById { public: @@ -31,13 +37,15 @@ public: void setSignaturesAreEnforced(bool enforced) { m_signaturesAreEnforced = enforced; } bool signaturesAreEnforced() const { return m_signaturesAreEnforced; } - void setValueTypesAreCopied(bool copied) { m_valueTypesAreCopied = copied; } - bool valueTypesAreCopied() const { return m_valueTypesAreCopied; } + void setValueTypesAreAddressable(bool addressable) { m_valueTypesAreAddressable = addressable; } + bool valueTypesAreAddressable() const { return m_valueTypesAreAddressable; } - QString id(const QQmlJSScope::ConstPtr &scope) const + QString id(const QQmlJSScope::ConstPtr &scope, const QQmlJSScope::ConstPtr &referrer, + QQmlJSScopesByIdOptions options = Default) const { + const QQmlJSScope::ConstPtr referrerRoot = componentRoot(referrer); for (auto it = m_scopesById.begin(), end = m_scopesById.end(); it != end; ++it) { - if (*it == scope) + if (*it == scope && isComponentVisible(componentRoot(*it), referrerRoot, options)) return it.key(); } return QString(); @@ -48,7 +56,8 @@ public: Returns the scope that has id \a id in the component to which \a referrer belongs to. If no such scope exists, a null scope is returned. */ - QQmlJSScope::ConstPtr scope(const QString &id, const QQmlJSScope::ConstPtr &referrer) const + QQmlJSScope::ConstPtr scope(const QString &id, const QQmlJSScope::ConstPtr &referrer, + QQmlJSScopesByIdOptions options = Default) const { Q_ASSERT(!id.isEmpty()); const auto range = m_scopesById.equal_range(id); @@ -57,7 +66,7 @@ public: const QQmlJSScope::ConstPtr referrerRoot = componentRoot(referrer); for (auto it = range.first; it != range.second; ++it) { - if (isComponentVisible(componentRoot(*it), referrerRoot)) + if (isComponentVisible(componentRoot(*it), referrerRoot, options)) return *it; } @@ -94,10 +103,11 @@ private: return scope; } - bool isComponentVisible( - const QQmlJSScope::ConstPtr &observed, const QQmlJSScope::ConstPtr &observer) const + bool isComponentVisible(const QQmlJSScope::ConstPtr &observed, + const QQmlJSScope::ConstPtr &observer, + QQmlJSScopesByIdOptions options) const { - if (!m_componentsAreBound) + if (!m_componentsAreBound && !options.testAnyFlag(AssumeComponentsAreBound)) return observed == observer; for (QQmlJSScope::ConstPtr scope = observer; scope; scope = scope->parentScope()) { @@ -111,7 +121,7 @@ private: QMultiHash<QString, QQmlJSScope::ConstPtr> m_scopesById; bool m_componentsAreBound = false; bool m_signaturesAreEnforced = true; - bool m_valueTypesAreCopied = true; + bool m_valueTypesAreAddressable = false; }; QT_END_NAMESPACE |