// Copyright (C) 2016 The Qt Company Ltd. // SPDX-License-Identifier: LicenseRef-Qt-Commercial OR LGPL-3.0-only OR GPL-2.0-only OR GPL-3.0-only #ifndef QQMLDIRPARSER_P_H #define QQMLDIRPARSER_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 #include #include #include #include #include QT_BEGIN_NAMESPACE class QQmlEngine; class Q_QML_COMPILER_EXPORT QQmlDirParser { public: void clear(); bool parse(const QString &source); void disambiguateFileSelectors(); bool hasError() const { return !_errors.isEmpty(); } void setError(const QQmlJS::DiagnosticMessage &); QList errors(const QString &uri) const; QString typeNamespace() const { return _typeNamespace; } void setTypeNamespace(const QString &s) { _typeNamespace = s; } static void checkNonRelative(const char *item, const QString &typeName, const QString &fileName) { if (fileName.startsWith(QLatin1Char('/'))) { qWarning() << item << typeName << "is specified with non-relative URL" << fileName << "in a qmldir file." << "URLs in qmldir files should be relative to the qmldir file's directory."; } } struct Plugin { Plugin() = default; Plugin(const QString &name, const QString &path, bool optional) : name(name), path(path), optional(optional) { checkNonRelative("Plugin", name, path); } QString name; QString path; bool optional = false; }; struct Component { Component() = default; Component(const QString &typeName, const QString &fileName, QTypeRevision version) : typeName(typeName), fileName(fileName), version(version), internal(false), singleton(false) { checkNonRelative("Component", typeName, fileName); } QString typeName; QString fileName; QTypeRevision version = QTypeRevision::zero(); bool internal = false; bool singleton = false; }; struct Script { Script() = default; Script(const QString &nameSpace, const QString &fileName, QTypeRevision version) : nameSpace(nameSpace), fileName(fileName), version(version) { checkNonRelative("Script", nameSpace, fileName); } QString nameSpace; QString fileName; QTypeRevision version = QTypeRevision::zero(); }; struct Import { enum Flag { Default = 0x0, Auto = 0x1, // forward the version of the importing module Optional = 0x2, // is not automatically imported but only a tooling hint OptionalDefault = 0x4, // tooling hint only, denotes this entry should be imported by tooling }; Q_DECLARE_FLAGS(Flags, Flag) Import() = default; Import(QString module, QTypeRevision version, Flags flags) : module(module), version(version), flags(flags) { } QString module; QTypeRevision version; // invalid version is latest version, unless Flag::Auto Flags flags; friend bool operator==(const Import &a, const Import &b) { return a.module == b.module && a.version == b.version && a.flags == b.flags; } }; QMultiHash components() const { return _components; } QList dependencies() const { return _dependencies; } QList imports() const { return _imports; } QList