aboutsummaryrefslogtreecommitdiffstats
path: root/tools/qmlcachegen
diff options
context:
space:
mode:
authorQt Forward Merge Bot <qt_forward_merge_bot@qt-project.org>2019-10-27 01:01:14 +0200
committerQt Forward Merge Bot <qt_forward_merge_bot@qt-project.org>2019-10-27 01:01:15 +0200
commitad987dcd706d4f6bcfd5972e4b02904c4979691d (patch)
tree2707b578f032008f119afddcf9e6f7b57fd89ae2 /tools/qmlcachegen
parent033e797aa5c58bb8f306f82292da272e60fa2fa1 (diff)
parent257319079562368b6ee731f54e3f69647c3417b7 (diff)
Merge remote-tracking branch 'origin/5.15' into dev
Diffstat (limited to 'tools/qmlcachegen')
-rw-r--r--tools/qmlcachegen/qmlcachegen.pro8
-rw-r--r--tools/qmlcachegen/resourcefilemapper.cpp167
-rw-r--r--tools/qmlcachegen/resourcefilemapper.h50
3 files changed, 4 insertions, 221 deletions
diff --git a/tools/qmlcachegen/qmlcachegen.pro b/tools/qmlcachegen/qmlcachegen.pro
index bee0b9a37e..ec65cdb5e6 100644
--- a/tools/qmlcachegen/qmlcachegen.pro
+++ b/tools/qmlcachegen/qmlcachegen.pro
@@ -5,8 +5,10 @@ DEFINES += QT_NO_CAST_TO_ASCII QT_NO_CAST_FROM_ASCII
SOURCES = qmlcachegen.cpp \
resourcefilter.cpp \
- generateloader.cpp \
- resourcefilemapper.cpp
+ generateloader.cpp
+
+include(../shared/shared.pri)
+
TARGET = qmlcachegen
build_integration.files = qmlcache.prf qtquickcompiler.prf
@@ -38,5 +40,3 @@ QMAKE_TARGET_DESCRIPTION = QML Cache Generator
load(qt_tool)
-HEADERS += \
- resourcefilemapper.h
diff --git a/tools/qmlcachegen/resourcefilemapper.cpp b/tools/qmlcachegen/resourcefilemapper.cpp
deleted file mode 100644
index 244874717f..0000000000
--- a/tools/qmlcachegen/resourcefilemapper.cpp
+++ /dev/null
@@ -1,167 +0,0 @@
-/****************************************************************************
-**
-** Copyright (C) 2016 The Qt Company Ltd.
-** Contact: https://www.qt.io/licensing/
-**
-** This file is part of the QtQml module of the Qt Toolkit.
-**
-** $QT_BEGIN_LICENSE:GPL-EXCEPT$
-** Commercial License Usage
-** Licensees holding valid commercial Qt licenses may use this file in
-** accordance with the commercial license agreement provided with the
-** Software or, alternatively, in accordance with the terms contained in
-** a written agreement between you and The Qt Company. For licensing terms
-** and conditions see https://www.qt.io/terms-conditions. For further
-** information use the contact form at https://www.qt.io/contact-us.
-**
-** GNU General Public License Usage
-** Alternatively, this file may be used under the terms of the GNU
-** General Public License version 3 as published by the Free Software
-** Foundation with exceptions as appearing in the file LICENSE.GPL3-EXCEPT
-** included in the packaging of this file. Please review the following
-** information to ensure the GNU General Public License requirements will
-** be met: https://www.gnu.org/licenses/gpl-3.0.html.
-**
-** $QT_END_LICENSE$
-**
-****************************************************************************/
-
-#include "resourcefilemapper.h"
-
-#include <QFileInfo>
-#include <QDir>
-#include <QXmlStreamReader>
-
-ResourceFileMapper::ResourceFileMapper(const QStringList &resourceFiles)
-{
- for (const QString &fileName: resourceFiles) {
- QFile f(fileName);
- if (!f.open(QIODevice::ReadOnly))
- continue;
- populateFromQrcFile(f);
- }
-}
-
-bool ResourceFileMapper::isEmpty() const
-{
- return qrcPathToFileSystemPath.isEmpty();
-}
-
-QStringList ResourceFileMapper::resourcePaths(const QString &fileName)
-{
- const QString absPath = QDir::cleanPath(QDir::current().absoluteFilePath(fileName));
- QStringList resourcePaths;
- for (auto it = qrcPathToFileSystemPath.cbegin(), end = qrcPathToFileSystemPath.cend(); it != end; ++it) {
- if (QFileInfo(it.value()) == QFileInfo(absPath))
- resourcePaths.append(it.key());
- }
- return resourcePaths;
-}
-
-QStringList ResourceFileMapper::qmlCompilerFiles() const
-{
- QStringList files;
- for (auto it = qrcPathToFileSystemPath.constBegin(), end = qrcPathToFileSystemPath.constEnd();
- it != end; ++it) {
- const QString &qrcPath = it.key();
- const QString suffix = QFileInfo(qrcPath).suffix();
- if (suffix != QStringLiteral("qml") && suffix != QStringLiteral("js") && suffix != QStringLiteral("mjs"))
- continue;
- files << qrcPath;
- }
- return files;
-}
-
-void ResourceFileMapper::populateFromQrcFile(QFile &file)
-{
- enum State {
- InitialState,
- InRCC,
- InResource,
- InFile
- };
- State state = InitialState;
-
- QDir qrcDir = QFileInfo(file).absoluteDir();
-
- QString prefix;
- QString currentFileName;
- QXmlStreamAttributes currentFileAttributes;
-
- QXmlStreamReader reader(&file);
- while (!reader.atEnd()) {
- switch (reader.readNext()) {
- case QXmlStreamReader::StartElement:
- if (reader.name() == QStringLiteral("RCC")) {
- if (state != InitialState)
- return;
- state = InRCC;
- continue;
- } else if (reader.name() == QStringLiteral("qresource")) {
- if (state != InRCC)
- return;
- state = InResource;
- QXmlStreamAttributes attributes = reader.attributes();
- if (attributes.hasAttribute(QStringLiteral("prefix")))
- prefix = attributes.value(QStringLiteral("prefix")).toString();
- if (!prefix.startsWith(QLatin1Char('/')))
- prefix.prepend(QLatin1Char('/'));
- if (!prefix.endsWith(QLatin1Char('/')))
- prefix.append(QLatin1Char('/'));
- continue;
- } else if (reader.name() == QStringLiteral("file")) {
- if (state != InResource)
- return;
- state = InFile;
- currentFileAttributes = reader.attributes();
- continue;
- }
- return;
-
- case QXmlStreamReader::EndElement:
- if (reader.name() == QStringLiteral("file")) {
- if (state != InFile)
- return;
- state = InResource;
- continue;
- } else if (reader.name() == QStringLiteral("qresource")) {
- if (state != InResource)
- return;
- state = InRCC;
- continue;
- } else if (reader.name() == QStringLiteral("RCC")) {
- if (state != InRCC)
- return;
- state = InitialState;
- continue;
- }
- return;
-
- case QXmlStreamReader::Characters: {
- if (reader.isWhitespace())
- break;
- if (state != InFile)
- return;
- currentFileName = reader.text().toString();
- if (currentFileName.isEmpty())
- continue;
-
- const QString fsPath = QDir::cleanPath(qrcDir.absoluteFilePath(currentFileName));
-
- if (currentFileAttributes.hasAttribute(QStringLiteral("alias")))
- currentFileName = currentFileAttributes.value(QStringLiteral("alias")).toString();
-
- currentFileName = QDir::cleanPath(currentFileName);
- while (currentFileName.startsWith(QLatin1String("../")))
- currentFileName.remove(0, 3);
-
- const QString qrcPath = prefix + currentFileName;
- if (QFile::exists(fsPath))
- qrcPathToFileSystemPath.insert(qrcPath, fsPath);
- continue;
- }
-
- default: break;
- }
- }
-}
diff --git a/tools/qmlcachegen/resourcefilemapper.h b/tools/qmlcachegen/resourcefilemapper.h
deleted file mode 100644
index 2e0ab45171..0000000000
--- a/tools/qmlcachegen/resourcefilemapper.h
+++ /dev/null
@@ -1,50 +0,0 @@
-/****************************************************************************
-**
-** Copyright (C) 2016 The Qt Company Ltd.
-** Contact: https://www.qt.io/licensing/
-**
-** This file is part of the QtQml module of the Qt Toolkit.
-**
-** $QT_BEGIN_LICENSE:GPL-EXCEPT$
-** Commercial License Usage
-** Licensees holding valid commercial Qt licenses may use this file in
-** accordance with the commercial license agreement provided with the
-** Software or, alternatively, in accordance with the terms contained in
-** a written agreement between you and The Qt Company. For licensing terms
-** and conditions see https://www.qt.io/terms-conditions. For further
-** information use the contact form at https://www.qt.io/contact-us.
-**
-** GNU General Public License Usage
-** Alternatively, this file may be used under the terms of the GNU
-** General Public License version 3 as published by the Free Software
-** Foundation with exceptions as appearing in the file LICENSE.GPL3-EXCEPT
-** included in the packaging of this file. Please review the following
-** information to ensure the GNU General Public License requirements will
-** be met: https://www.gnu.org/licenses/gpl-3.0.html.
-**
-** $QT_END_LICENSE$
-**
-****************************************************************************/
-#ifndef RESOURCEFILEMAPPER_H
-#define RESOURCEFILEMAPPER_H
-
-#include <QStringList>
-#include <QHash>
-#include <QFile>
-
-struct ResourceFileMapper
-{
- ResourceFileMapper(const QStringList &resourceFiles);
-
- bool isEmpty() const;
-
- QStringList resourcePaths(const QString &fileName);
- QStringList qmlCompilerFiles() const;
-
-private:
- void populateFromQrcFile(QFile &file);
-
- QHash<QString, QString> qrcPathToFileSystemPath;
-};
-
-#endif // RESOURCEFILEMAPPER_H