aboutsummaryrefslogtreecommitdiffstats
path: root/src/qmlcompiler/qqmljsregistercontent.cpp
diff options
context:
space:
mode:
Diffstat (limited to 'src/qmlcompiler/qqmljsregistercontent.cpp')
-rw-r--r--src/qmlcompiler/qqmljsregistercontent.cpp199
1 files changed, 199 insertions, 0 deletions
diff --git a/src/qmlcompiler/qqmljsregistercontent.cpp b/src/qmlcompiler/qqmljsregistercontent.cpp
new file mode 100644
index 0000000000..3efb738e46
--- /dev/null
+++ b/src/qmlcompiler/qqmljsregistercontent.cpp
@@ -0,0 +1,199 @@
+// Copyright (C) 2021 The Qt Company Ltd.
+// SPDX-License-Identifier: LicenseRef-Qt-Commercial OR GPL-3.0-only WITH Qt-GPL-exception-1.0
+
+#include "qqmljsregistercontent_p.h"
+
+QT_BEGIN_NAMESPACE
+
+using namespace Qt::StringLiterals;
+
+QString QQmlJSRegisterContent::descriptiveName() const
+{
+ if (m_storedType.isNull() && containedType().isNull())
+ return u"(invalid type)"_s;
+
+ const auto scope = [this]() -> QString {
+ if (m_scope.isNull())
+ return u"(invalid type)::"_s;
+ return (m_scope->internalName().isEmpty()
+ ? (m_scope->filePath().isEmpty()
+ ? u"??"_s
+ : (u"(component in "_s + m_scope->filePath() + u")"_s))
+ : m_scope->internalName())
+ + u"::"_s;
+ };
+
+ QString result;
+ switch (m_content.index()) {
+ case Type: {
+ const QQmlJSScope::ConstPtr contained = type();
+ result += contained->internalName();
+ if (m_storedType && m_storedType->internalName() != contained->internalName())
+ result += u" stored as "_s + m_storedType->internalName();
+ return result;
+ }
+ case Property: {
+ const QQmlJSMetaProperty prop = property();
+ result += scope() + prop.propertyName() + u" with type "_s + prop.typeName();
+ if (m_storedType && m_storedType->internalName() != prop.typeName())
+ result += u" (stored as "_s + m_storedType->internalName() + u")";
+ return result;
+ }
+ case Method: {
+ const auto methods = method();
+ if (methods.isEmpty())
+ result = scope() + u"(unknown method)"_s;
+ else
+ result = scope() + methods[0].methodName() + u"(...)"_s;
+ if (m_storedType)
+ return result + u" (stored as "_s + m_storedType->internalName() + u")";
+ return result;
+ }
+ case Enum: {
+ const QString enumName = enumeration().name();
+ const QString memberName = enumMember();
+ if (memberName.isEmpty())
+ result = scope() + enumName;
+ else
+ result = scope() + enumName + u"::"_s + memberName;
+ if (m_storedType)
+ return result + u" (stored as "_s + m_storedType->internalName() + u")";
+ return result;
+ }
+ case ImportNamespace: {
+ return u"import namespace %1"_s.arg(importNamespace());
+ }
+ case Conversion: {
+ return u"conversion to %1"_s.arg(conversionResult()->internalName());
+ }
+ }
+
+ Q_UNREACHABLE_RETURN(result + u"wat?"_s);
+}
+
+QString QQmlJSRegisterContent::containedTypeName() const
+{
+ QQmlJSScope::ConstPtr type;
+
+ // Use the type proper instead of the attached type
+ switch (variant()) {
+ case QQmlJSRegisterContent::ScopeAttached:
+ case QQmlJSRegisterContent::MetaType:
+ type = scopeType();
+ break;
+ default:
+ type = containedType();
+ break;
+ }
+
+ return QQmlJSScope::prettyName(
+ type->internalName().isEmpty() ? type->baseTypeName() : type->internalName());
+}
+
+bool QQmlJSRegisterContent::isList() const
+{
+ switch (m_content.index()) {
+ case Type:
+ return std::get<std::pair<QQmlJSScope::ConstPtr, int>>(m_content).first->accessSemantics()
+ == QQmlJSScope::AccessSemantics::Sequence;
+ case Property:
+ return std::get<PropertyLookup>(m_content).property.type()->accessSemantics()
+ == QQmlJSScope::AccessSemantics::Sequence;
+ case Conversion:
+ return std::get<ConvertedTypes>(m_content).result->accessSemantics()
+ == QQmlJSScope::AccessSemantics::Sequence;
+ default:
+ return false;
+ }
+}
+
+bool QQmlJSRegisterContent::isWritable() const
+{
+ switch (m_content.index()) {
+ case Property:
+ return std::get<PropertyLookup>(m_content).property.isWritable();
+
+ // TODO: What can we actually write?
+ default:
+ break;
+ }
+
+ return true;
+}
+
+QQmlJSScope::ConstPtr QQmlJSRegisterContent::containedType() const
+{
+ if (isType())
+ return type();
+ if (isProperty())
+ return property().type();
+ if (isEnumeration())
+ return enumeration().type();
+ if (isMethod())
+ return methodType();
+ if (isImportNamespace())
+ return importNamespaceType();
+ if (isConversion())
+ return conversionResult();
+
+ Q_UNREACHABLE_RETURN({});
+}
+
+QQmlJSRegisterContent QQmlJSRegisterContent::create(
+ const QQmlJSScope::ConstPtr &type, int resultLookupIndex,
+ QQmlJSRegisterContent::ContentVariant variant, const QQmlJSScope::ConstPtr &scope)
+{
+ QQmlJSRegisterContent result(scope, variant);
+ result.m_content = std::make_pair(type, resultLookupIndex);
+ return result;
+}
+
+QQmlJSRegisterContent QQmlJSRegisterContent::create(
+ const QQmlJSMetaProperty &property, int baseLookupIndex, int resultLookupIndex,
+ QQmlJSRegisterContent::ContentVariant variant, const QQmlJSScope::ConstPtr &scope)
+{
+ QQmlJSRegisterContent result(scope, variant);
+ result.m_content = PropertyLookup { property, baseLookupIndex, resultLookupIndex};
+ return result;
+}
+
+QQmlJSRegisterContent QQmlJSRegisterContent::create(
+ const QQmlJSMetaEnum &enumeration, const QString &enumMember,
+ QQmlJSRegisterContent::ContentVariant variant, const QQmlJSScope::ConstPtr &scope)
+{
+ QQmlJSRegisterContent result(scope, variant);
+ result.m_content = std::make_pair(enumeration, enumMember);
+ return result;
+}
+
+QQmlJSRegisterContent QQmlJSRegisterContent::create(
+ const QList<QQmlJSMetaMethod> &methods, const QQmlJSScope::ConstPtr &methodType,
+ QQmlJSRegisterContent::ContentVariant variant, const QQmlJSScope::ConstPtr &scope)
+{
+ // Methods can only be stored in QJSValue.
+ Q_ASSERT(methodType->internalName() == u"QJSValue"_s);
+ QQmlJSRegisterContent result(scope, variant);
+ result.m_content = std::make_pair(methods, methodType);
+ return result;
+}
+
+QQmlJSRegisterContent QQmlJSRegisterContent::create(
+ uint importNamespaceStringId, const QQmlJSScope::ConstPtr &importNamespaceType,
+ QQmlJSRegisterContent::ContentVariant variant, const QQmlJSScope::ConstPtr &scope)
+{
+ QQmlJSRegisterContent result(scope, variant);
+ result.m_content = std::make_pair(importNamespaceStringId, importNamespaceType);
+ return result;
+}
+
+QQmlJSRegisterContent QQmlJSRegisterContent::create(
+ const QList<QQmlJSScope::ConstPtr> &origins, const QQmlJSScope::ConstPtr &conversion,
+ const QQmlJSScope::ConstPtr &conversionScope, ContentVariant variant,
+ const QQmlJSScope::ConstPtr &scope)
+{
+ QQmlJSRegisterContent result(scope, variant);
+ result.m_content = ConvertedTypes { origins, conversion, conversionScope };
+ return result;
+}
+
+QT_END_NAMESPACE