Merge "Merge remote-tracking branch 'origin/dev' into wip/qt6"
This commit is contained in:
commit
05b90be3c5
@ -2,6 +2,7 @@ load(qt_build_config)
|
|||||||
CONFIG += warning_clean
|
CONFIG += warning_clean
|
||||||
|
|
||||||
DEFINES += QT_NO_JAVA_STYLE_ITERATORS
|
DEFINES += QT_NO_JAVA_STYLE_ITERATORS
|
||||||
|
DEFINES += QT_NO_LINKED_LIST
|
||||||
|
|
||||||
QT_SOURCE_TREE = $$PWD
|
QT_SOURCE_TREE = $$PWD
|
||||||
QT_BUILD_TREE = $$shadowed($$PWD)
|
QT_BUILD_TREE = $$shadowed($$PWD)
|
||||||
|
@ -1092,7 +1092,7 @@ foreach my $lib (@modules_to_sync) {
|
|||||||
# }
|
# }
|
||||||
my $class_header = "$class ";
|
my $class_header = "$class ";
|
||||||
$pri_install_gfiles .= $class_header
|
$pri_install_gfiles .= $class_header
|
||||||
unless ($shadow || $pri_install_gfiles =~ $class_header);
|
unless ($shadow || $pri_install_gfiles =~ m/\b$class_header/);
|
||||||
$injection .= ":$class";
|
$injection .= ":$class";
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -1,2 +1 @@
|
|||||||
TARGET = arch
|
|
||||||
SOURCES = arch.cpp
|
SOURCES = arch.cpp
|
||||||
|
@ -1,2 +1,2 @@
|
|||||||
option(host_build)
|
option(host_build)
|
||||||
include(arch.pro)
|
SOURCES = arch.cpp
|
||||||
|
2
configure
vendored
2
configure
vendored
@ -358,7 +358,7 @@ if [ -z "$QT_MAJOR_VERSION" ]; then
|
|||||||
fi
|
fi
|
||||||
|
|
||||||
#-------------------------------------------------------------------------------
|
#-------------------------------------------------------------------------------
|
||||||
# initalize variables
|
# initialize variables
|
||||||
#-------------------------------------------------------------------------------
|
#-------------------------------------------------------------------------------
|
||||||
|
|
||||||
# QTDIR may be set and point to an old or system-wide Qt installation
|
# QTDIR may be set and point to an old or system-wide Qt installation
|
||||||
|
@ -252,12 +252,14 @@
|
|||||||
"label": "target architecture",
|
"label": "target architecture",
|
||||||
"type": "architecture",
|
"type": "architecture",
|
||||||
"test": "arch",
|
"test": "arch",
|
||||||
|
"output": "arch",
|
||||||
"log": "arch"
|
"log": "arch"
|
||||||
},
|
},
|
||||||
"host_architecture": {
|
"host_architecture": {
|
||||||
"label": "host architecture",
|
"label": "host architecture",
|
||||||
"type": "architecture",
|
"type": "architecture",
|
||||||
"test": "arch",
|
"test": "arch",
|
||||||
|
"output": "arch_host",
|
||||||
"host": true,
|
"host": true,
|
||||||
"pro": "arch_host.pro",
|
"pro": "arch_host.pro",
|
||||||
"log": "arch"
|
"log": "arch"
|
||||||
@ -1323,7 +1325,7 @@
|
|||||||
"ccache": {
|
"ccache": {
|
||||||
"label": "Using ccache",
|
"label": "Using ccache",
|
||||||
"autoDetect": false,
|
"autoDetect": false,
|
||||||
"condition": "config.unix && tests.ccache",
|
"condition": "tests.ccache",
|
||||||
"output": [ "privateConfig" ]
|
"output": [ "privateConfig" ]
|
||||||
},
|
},
|
||||||
"msvc_mp": {
|
"msvc_mp": {
|
||||||
|
@ -286,20 +286,39 @@ defineTest(qtConfTest_architecture) {
|
|||||||
!qtConfTest_compile($${1}): \
|
!qtConfTest_compile($${1}): \
|
||||||
error("Could not determine $$eval($${1}.label). See config.log for details.")
|
error("Could not determine $$eval($${1}.label). See config.log for details.")
|
||||||
|
|
||||||
|
host = $$eval($${1}.host)
|
||||||
|
isEmpty(host): host = false
|
||||||
|
file_prefix =
|
||||||
|
exts = -
|
||||||
|
$$host {
|
||||||
|
equals(QMAKE_HOST.os, Windows): \
|
||||||
|
exts = .exe
|
||||||
|
} else {
|
||||||
|
win32 {
|
||||||
|
exts = .exe
|
||||||
|
} else:android {
|
||||||
|
file_prefix = lib
|
||||||
|
exts = .so
|
||||||
|
} else:wasm {
|
||||||
|
exts = .wasm .o
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
test = $$eval($${1}.test)
|
test = $$eval($${1}.test)
|
||||||
|
output = $$eval($${1}.output)
|
||||||
test_out_dir = $$OUT_PWD/$$basename(QMAKE_CONFIG_TESTS_DIR)/$$test
|
test_out_dir = $$OUT_PWD/$$basename(QMAKE_CONFIG_TESTS_DIR)/$$test
|
||||||
unix:exists($$test_out_dir/arch): \
|
test_out_file =
|
||||||
content = $$cat($$test_out_dir/arch, blob)
|
for(ext, exts) {
|
||||||
else: win32:exists($$test_out_dir/arch.exe): \
|
equals(ext, -): ext =
|
||||||
content = $$cat($$test_out_dir/arch.exe, blob)
|
f = $$test_out_dir/$$file_prefix$$output$$ext
|
||||||
else: android:exists($$test_out_dir/libarch.so): \
|
exists($$f) {
|
||||||
content = $$cat($$test_out_dir/libarch.so, blob)
|
test_out_file = $$f
|
||||||
else: wasm:exists($$test_out_dir/arch.wasm): \
|
break()
|
||||||
content = $$cat($$test_out_dir/arch.wasm, blob)
|
}
|
||||||
else: wasm:exists($$test_out_dir/arch.o): \
|
}
|
||||||
content = $$cat($$test_out_dir/arch.o, blob)
|
isEmpty(test_out_file): \
|
||||||
else: \
|
|
||||||
error("$$eval($${1}.label) detection binary not found.")
|
error("$$eval($${1}.label) detection binary not found.")
|
||||||
|
content = $$cat($$test_out_file, blob)
|
||||||
|
|
||||||
arch_magic = ".*==Qt=magic=Qt== Architecture:([^\\0]*).*"
|
arch_magic = ".*==Qt=magic=Qt== Architecture:([^\\0]*).*"
|
||||||
subarch_magic = ".*==Qt=magic=Qt== Sub-architecture:([^\\0]*).*"
|
subarch_magic = ".*==Qt=magic=Qt== Sub-architecture:([^\\0]*).*"
|
||||||
|
@ -140,10 +140,10 @@ void GLWidget::initializeGL()
|
|||||||
{
|
{
|
||||||
initializeOpenGLFunctions();
|
initializeOpenGLFunctions();
|
||||||
|
|
||||||
qglClearColor(qtPurple.dark());
|
qglClearColor(qtPurple.darker());
|
||||||
|
|
||||||
logo = new QtLogo(this, 64);
|
logo = new QtLogo(this, 64);
|
||||||
logo->setColor(qtGreen.dark());
|
logo->setColor(qtGreen.darker());
|
||||||
|
|
||||||
glEnable(GL_DEPTH_TEST);
|
glEnable(GL_DEPTH_TEST);
|
||||||
glEnable(GL_CULL_FACE);
|
glEnable(GL_CULL_FACE);
|
||||||
|
@ -130,7 +130,7 @@ void GLWidget::initializeGL()
|
|||||||
glEnable(GL_MULTISAMPLE);
|
glEnable(GL_MULTISAMPLE);
|
||||||
|
|
||||||
logo = new QtLogo(this);
|
logo = new QtLogo(this);
|
||||||
logo->setColor(qtGreen.dark());
|
logo->setColor(qtGreen.darker());
|
||||||
}
|
}
|
||||||
//! [2]
|
//! [2]
|
||||||
|
|
||||||
@ -163,7 +163,7 @@ void GLWidget::paintEvent(QPaintEvent *event)
|
|||||||
//! [4]
|
//! [4]
|
||||||
|
|
||||||
//! [6]
|
//! [6]
|
||||||
qglClearColor(qtPurple.dark());
|
qglClearColor(qtPurple.darker());
|
||||||
glShadeModel(GL_SMOOTH);
|
glShadeModel(GL_SMOOTH);
|
||||||
glEnable(GL_DEPTH_TEST);
|
glEnable(GL_DEPTH_TEST);
|
||||||
glEnable(GL_CULL_FACE);
|
glEnable(GL_CULL_FACE);
|
||||||
|
@ -91,6 +91,9 @@ FragmentToy::FragmentToy(const QString &fragmentSource, QObject *parent)
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
FragmentToy::~FragmentToy()
|
||||||
|
= default;
|
||||||
|
|
||||||
void FragmentToy::draw(const QSize &windowSize)
|
void FragmentToy::draw(const QSize &windowSize)
|
||||||
{
|
{
|
||||||
if (!m_program)
|
if (!m_program)
|
||||||
@ -120,7 +123,7 @@ void FragmentToy::draw(const QSize &windowSize)
|
|||||||
if (!m_vertex_shader->compileSourceCode(vertex_shader)) {
|
if (!m_vertex_shader->compileSourceCode(vertex_shader)) {
|
||||||
qWarning() << "Failed to compile the vertex shader:" << m_vertex_shader->log();
|
qWarning() << "Failed to compile the vertex shader:" << m_vertex_shader->log();
|
||||||
}
|
}
|
||||||
if (!m_program->addShader(m_vertex_shader.data())) {
|
if (!m_program->addShader(m_vertex_shader.get())) {
|
||||||
qWarning() << "Failed to add vertex shader to program:" << m_program->log();
|
qWarning() << "Failed to add vertex shader to program:" << m_program->log();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -153,7 +156,7 @@ void FragmentToy::draw(const QSize &windowSize)
|
|||||||
}
|
}
|
||||||
|
|
||||||
if (m_fragment_shader) {
|
if (m_fragment_shader) {
|
||||||
if (!m_program->addShader(m_fragment_shader.data())) {
|
if (!m_program->addShader(m_fragment_shader.get())) {
|
||||||
qWarning() << "Failed to add fragment shader to program:" << m_program->log();
|
qWarning() << "Failed to add fragment shader to program:" << m_program->log();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -197,14 +200,14 @@ void FragmentToy::fileChanged(const QString &path)
|
|||||||
m_fragment_file_last_modified = fragment_source.lastModified();
|
m_fragment_file_last_modified = fragment_source.lastModified();
|
||||||
m_recompile_shaders = true;
|
m_recompile_shaders = true;
|
||||||
if (m_program) {
|
if (m_program) {
|
||||||
m_program->removeShader(m_fragment_shader.data());
|
m_program->removeShader(m_fragment_shader.get());
|
||||||
m_fragment_shader.reset(nullptr);
|
m_fragment_shader.reset(nullptr);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
m_recompile_shaders = true;
|
m_recompile_shaders = true;
|
||||||
if (m_program) {
|
if (m_program) {
|
||||||
m_program->removeShader(m_fragment_shader.data());
|
m_program->removeShader(m_fragment_shader.get());
|
||||||
m_fragment_shader.reset(nullptr);
|
m_fragment_shader.reset(nullptr);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -62,11 +62,14 @@
|
|||||||
#include <QOpenGLShaderProgram>
|
#include <QOpenGLShaderProgram>
|
||||||
#include <QOpenGLFunctions>
|
#include <QOpenGLFunctions>
|
||||||
|
|
||||||
|
#include <memory>
|
||||||
|
|
||||||
class FragmentToy : public QObject, protected QOpenGLFunctions
|
class FragmentToy : public QObject, protected QOpenGLFunctions
|
||||||
{
|
{
|
||||||
Q_OBJECT
|
Q_OBJECT
|
||||||
public:
|
public:
|
||||||
FragmentToy(const QString &fragmentSource, QObject *parent = 0);
|
explicit FragmentToy(const QString &fragmentSource, QObject *parent = nullptr);
|
||||||
|
~FragmentToy();
|
||||||
|
|
||||||
void draw(const QSize &windowSize);
|
void draw(const QSize &windowSize);
|
||||||
|
|
||||||
@ -79,9 +82,9 @@ private:
|
|||||||
QString m_fragment_file;
|
QString m_fragment_file;
|
||||||
QDateTime m_fragment_file_last_modified;
|
QDateTime m_fragment_file_last_modified;
|
||||||
|
|
||||||
QScopedPointer<QOpenGLShaderProgram> m_program;
|
std::unique_ptr<QOpenGLShaderProgram> m_program;
|
||||||
QScopedPointer<QOpenGLShader> m_vertex_shader;
|
std::unique_ptr<QOpenGLShader> m_vertex_shader;
|
||||||
QScopedPointer<QOpenGLShader> m_fragment_shader;
|
std::unique_ptr<QOpenGLShader> m_fragment_shader;
|
||||||
QOpenGLVertexArrayObject m_vao;
|
QOpenGLVertexArrayObject m_vao;
|
||||||
QOpenGLBuffer m_vertex_buffer;
|
QOpenGLBuffer m_vertex_buffer;
|
||||||
GLuint m_vertex_coord_pos;
|
GLuint m_vertex_coord_pos;
|
||||||
|
@ -160,9 +160,10 @@ void Window::iconActivated(QSystemTrayIcon::ActivationReason reason)
|
|||||||
void Window::showMessage()
|
void Window::showMessage()
|
||||||
{
|
{
|
||||||
showIconCheckBox->setChecked(true);
|
showIconCheckBox->setChecked(true);
|
||||||
QSystemTrayIcon::MessageIcon msgIcon = QSystemTrayIcon::MessageIcon(
|
int selectedIcon = typeComboBox->itemData(typeComboBox->currentIndex()).toInt();
|
||||||
typeComboBox->itemData(typeComboBox->currentIndex()).toInt());
|
QSystemTrayIcon::MessageIcon msgIcon = QSystemTrayIcon::MessageIcon(selectedIcon);
|
||||||
if (msgIcon == QSystemTrayIcon::NoIcon) {
|
|
||||||
|
if (selectedIcon == -1) { // custom icon
|
||||||
QIcon icon(iconComboBox->itemIcon(iconComboBox->currentIndex()));
|
QIcon icon(iconComboBox->itemIcon(iconComboBox->currentIndex()));
|
||||||
trayIcon->showMessage(titleEdit->text(), bodyEdit->toPlainText(), icon,
|
trayIcon->showMessage(titleEdit->text(), bodyEdit->toPlainText(), icon,
|
||||||
durationSpinBox->value() * 1000);
|
durationSpinBox->value() * 1000);
|
||||||
@ -222,7 +223,7 @@ void Window::createMessageGroupBox()
|
|||||||
QStyle::SP_MessageBoxCritical), tr("Critical"),
|
QStyle::SP_MessageBoxCritical), tr("Critical"),
|
||||||
QSystemTrayIcon::Critical);
|
QSystemTrayIcon::Critical);
|
||||||
typeComboBox->addItem(QIcon(), tr("Custom icon"),
|
typeComboBox->addItem(QIcon(), tr("Custom icon"),
|
||||||
QSystemTrayIcon::NoIcon);
|
-1);
|
||||||
typeComboBox->setCurrentIndex(1);
|
typeComboBox->setCurrentIndex(1);
|
||||||
|
|
||||||
durationLabel = new QLabel(tr("Duration:"));
|
durationLabel = new QLabel(tr("Duration:"));
|
||||||
|
@ -317,7 +317,7 @@ void Dialog::setInteger()
|
|||||||
{
|
{
|
||||||
//! [0]
|
//! [0]
|
||||||
bool ok;
|
bool ok;
|
||||||
int i = QInputDialog::getInt(this, tr("QInputDialog::getInteger()"),
|
int i = QInputDialog::getInt(this, tr("QInputDialog::getInt()"),
|
||||||
tr("Percentage:"), 25, 0, 100, 1, &ok);
|
tr("Percentage:"), 25, 0, 100, 1, &ok);
|
||||||
if (ok)
|
if (ok)
|
||||||
integerLabel->setText(tr("%1%").arg(i));
|
integerLabel->setText(tr("%1%").arg(i));
|
||||||
|
@ -457,7 +457,7 @@ void ArthurStyle::polish(QWidget *widget)
|
|||||||
|
|
||||||
QPalette pal = widget->palette();
|
QPalette pal = widget->palette();
|
||||||
if (widget->isWindow()) {
|
if (widget->isWindow()) {
|
||||||
pal.setColor(QPalette::Background, QColor(241, 241, 241));
|
pal.setColor(QPalette::Window, QColor(241, 241, 241));
|
||||||
widget->setPalette(pal);
|
widget->setPalette(pal);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -474,7 +474,7 @@ void ArthurStyle::unpolish(QWidget *widget)
|
|||||||
|
|
||||||
void ArthurStyle::polish(QPalette &palette)
|
void ArthurStyle::polish(QPalette &palette)
|
||||||
{
|
{
|
||||||
palette.setColor(QPalette::Background, QColor(241, 241, 241));
|
palette.setColor(QPalette::Window, QColor(241, 241, 241));
|
||||||
}
|
}
|
||||||
|
|
||||||
QRect ArthurStyle::subElementRect(SubElement element, const QStyleOption *option, const QWidget *widget) const
|
QRect ArthurStyle::subElementRect(SubElement element, const QStyleOption *option, const QWidget *widget) const
|
||||||
|
@ -153,7 +153,7 @@ void ArthurFrame::paintEvent(QPaintEvent *e)
|
|||||||
|
|
||||||
int o = 10;
|
int o = 10;
|
||||||
|
|
||||||
QBrush bg = palette().brush(QPalette::Background);
|
QBrush bg = palette().brush(QPalette::Window);
|
||||||
painter.fillRect(0, 0, o, o, bg);
|
painter.fillRect(0, 0, o, o, bg);
|
||||||
painter.fillRect(width() - o, 0, o, o, bg);
|
painter.fillRect(width() - o, 0, o, o, bg);
|
||||||
painter.fillRect(0, height() - o, o, o, bg);
|
painter.fillRect(0, height() - o, o, o, bg);
|
||||||
|
@ -105,7 +105,7 @@ public:
|
|||||||
m_green = new LightWidget(Qt::green);
|
m_green = new LightWidget(Qt::green);
|
||||||
vbox->addWidget(m_green);
|
vbox->addWidget(m_green);
|
||||||
QPalette pal = palette();
|
QPalette pal = palette();
|
||||||
pal.setColor(QPalette::Background, Qt::black);
|
pal.setColor(QPalette::Window, Qt::black);
|
||||||
setPalette(pal);
|
setPalette(pal);
|
||||||
setAutoFillBackground(true);
|
setAutoFillBackground(true);
|
||||||
}
|
}
|
||||||
|
@ -26,6 +26,10 @@ contains(CMAKE_INSTALL_LIBS_DIR, ^(/usr)?/lib(64)?.*): CMAKE_USR_MOVE_WORKAROUND
|
|||||||
|
|
||||||
CMAKE_OUT_DIR = $$MODULE_BASE_OUTDIR/lib/cmake
|
CMAKE_OUT_DIR = $$MODULE_BASE_OUTDIR/lib/cmake
|
||||||
|
|
||||||
|
internal_module {
|
||||||
|
MODULE = "$${MODULE}_private"
|
||||||
|
}
|
||||||
|
|
||||||
# Core, Network, an external module named Foo
|
# Core, Network, an external module named Foo
|
||||||
CMAKE_MODULE_NAME = $$cmakeModuleName($${MODULE})
|
CMAKE_MODULE_NAME = $$cmakeModuleName($${MODULE})
|
||||||
|
|
||||||
@ -112,6 +116,10 @@ win32:!static:!staticlib {
|
|||||||
|
|
||||||
static|staticlib:CMAKE_STATIC_TYPE = true
|
static|staticlib:CMAKE_STATIC_TYPE = true
|
||||||
|
|
||||||
|
internal_module {
|
||||||
|
CMAKE_INTERNAL_MODULE = true
|
||||||
|
}
|
||||||
|
|
||||||
CMAKE_DEBUG_TYPE =
|
CMAKE_DEBUG_TYPE =
|
||||||
CMAKE_RELEASE_TYPE =
|
CMAKE_RELEASE_TYPE =
|
||||||
|
|
||||||
@ -133,6 +141,24 @@ equals(QMAKE_HOST.os, Windows): CMAKE_BIN_SUFFIX = ".exe"
|
|||||||
if(build_all|CONFIG(debug, debug|release)): CMAKE_DEBUG_TYPE = debug
|
if(build_all|CONFIG(debug, debug|release)): CMAKE_DEBUG_TYPE = debug
|
||||||
if(build_all|CONFIG(release, debug|release)): CMAKE_RELEASE_TYPE = release
|
if(build_all|CONFIG(release, debug|release)): CMAKE_RELEASE_TYPE = release
|
||||||
|
|
||||||
|
# CMAKE_DEBUG_AND_RELEASE is used to tell the _populate_$${CMAKE_MODULE_NAME}_target_properties
|
||||||
|
# functions whether a Configuration specific generator expression needs to be added to the values
|
||||||
|
# of INTERFACE_LINK_LIBRARIES and INTERFACE_LINK_OPTIONS. For debug_and_release builds, we do need
|
||||||
|
# configuration specific values. For singular builds (only release or only debug), we want the
|
||||||
|
# values to be applied regardless of the configuration.
|
||||||
|
# This would allow on Linux and macOS (and with a recent enough version of CMake on Windows) to
|
||||||
|
# build a Debug configuration of an application, even if Qt was built in a Release configuration.
|
||||||
|
#
|
||||||
|
# All IMPORTED_LOCATION_<CONFIG> paths are automatically considered by CMake if there is no
|
||||||
|
# <CONFIG> equivalent to the value specified by CMAKE_BUILD_TYPE.
|
||||||
|
# This means that when Qt was built in a Release configuration, and the application in a Debug
|
||||||
|
# configuration, IMPORTED_LOCATION_RELEASE will be used for the Qt libraries.
|
||||||
|
debug_and_release {
|
||||||
|
CMAKE_DEBUG_AND_RELEASE = TRUE
|
||||||
|
} else {
|
||||||
|
CMAKE_DEBUG_AND_RELEASE = FALSE
|
||||||
|
}
|
||||||
|
|
||||||
contains(CONFIG, plugin) {
|
contains(CONFIG, plugin) {
|
||||||
!isEmpty(PLUGIN_EXTENDS):!equals(PLUGIN_EXTENDS, -) {
|
!isEmpty(PLUGIN_EXTENDS):!equals(PLUGIN_EXTENDS, -) {
|
||||||
count(PLUGIN_EXTENDS, 1, greaterThan): \
|
count(PLUGIN_EXTENDS, 1, greaterThan): \
|
||||||
@ -341,7 +367,7 @@ cmake_qt5_module_files.path = $$[QT_INSTALL_LIBS]/cmake/Qt5$${CMAKE_MODULE_NAME}
|
|||||||
# Other modules should either create proper tests in tests/auto/cmake or, as
|
# Other modules should either create proper tests in tests/auto/cmake or, as
|
||||||
# a temporary measure, disable the generation of cmake files
|
# a temporary measure, disable the generation of cmake files
|
||||||
# with 'CONFIG -= create_cmake'
|
# with 'CONFIG -= create_cmake'
|
||||||
!equals(CMAKE_MODULE_TESTS, -) {
|
!internal_module:!equals(CMAKE_MODULE_TESTS, -) {
|
||||||
isEmpty(CMAKE_MODULE_TESTS): CMAKE_MODULE_TESTS = $$MODULE_BASE_INDIR/tests/auto/cmake
|
isEmpty(CMAKE_MODULE_TESTS): CMAKE_MODULE_TESTS = $$MODULE_BASE_INDIR/tests/auto/cmake
|
||||||
!exists($$CMAKE_MODULE_TESTS): \
|
!exists($$CMAKE_MODULE_TESTS): \
|
||||||
error("Missing CMake tests. Either create tests in tests/auto/cmake," \
|
error("Missing CMake tests. Either create tests in tests/auto/cmake," \
|
||||||
|
@ -75,7 +75,7 @@ function(_qt5_$${CMAKE_MODULE_NAME}_process_prl_file prl_file_location Configura
|
|||||||
# Handle normal libraries passed as -lfoo
|
# Handle normal libraries passed as -lfoo
|
||||||
set(_lib \"${CMAKE_MATCH_1}\")
|
set(_lib \"${CMAKE_MATCH_1}\")
|
||||||
foreach(_standard_library ${_standard_libraries})
|
foreach(_standard_library ${_standard_libraries})
|
||||||
if(_standard_library MATCHES \"^${_lib}(\\.lib)?$\")
|
if(_standard_library MATCHES \"^${_lib}(\\\\.lib)?$\")
|
||||||
set(_lib_is_default_linked TRUE)
|
set(_lib_is_default_linked TRUE)
|
||||||
break()
|
break()
|
||||||
endif()
|
endif()
|
||||||
@ -119,7 +119,8 @@ endfunction()
|
|||||||
!!ENDIF
|
!!ENDIF
|
||||||
|
|
||||||
!!IF !equals(TEMPLATE, aux)
|
!!IF !equals(TEMPLATE, aux)
|
||||||
macro(_populate_$${CMAKE_MODULE_NAME}_target_properties Configuration LIB_LOCATION IMPLIB_LOCATION)
|
macro(_populate_$${CMAKE_MODULE_NAME}_target_properties Configuration LIB_LOCATION IMPLIB_LOCATION
|
||||||
|
IsDebugAndRelease)
|
||||||
set_property(TARGET Qt5::$${CMAKE_MODULE_NAME} APPEND PROPERTY IMPORTED_CONFIGURATIONS ${Configuration})
|
set_property(TARGET Qt5::$${CMAKE_MODULE_NAME} APPEND PROPERTY IMPORTED_CONFIGURATIONS ${Configuration})
|
||||||
|
|
||||||
!!IF isEmpty(CMAKE_DLL_DIR_IS_ABSOLUTE)
|
!!IF isEmpty(CMAKE_DLL_DIR_IS_ABSOLUTE)
|
||||||
@ -130,24 +131,48 @@ macro(_populate_$${CMAKE_MODULE_NAME}_target_properties Configuration LIB_LOCATI
|
|||||||
_qt5_$${CMAKE_MODULE_NAME}_check_file_exists(${imported_location})
|
_qt5_$${CMAKE_MODULE_NAME}_check_file_exists(${imported_location})
|
||||||
set(_deps
|
set(_deps
|
||||||
${_Qt5$${CMAKE_MODULE_NAME}_LIB_DEPENDENCIES}
|
${_Qt5$${CMAKE_MODULE_NAME}_LIB_DEPENDENCIES}
|
||||||
|
)
|
||||||
|
set(_static_deps
|
||||||
!!IF !isEmpty(CMAKE_STATIC_TYPE)
|
!!IF !isEmpty(CMAKE_STATIC_TYPE)
|
||||||
${_Qt5$${CMAKE_MODULE_NAME}_STATIC_${Configuration}_LIB_DEPENDENCIES}
|
${_Qt5$${CMAKE_MODULE_NAME}_STATIC_${Configuration}_LIB_DEPENDENCIES}
|
||||||
!!ENDIF
|
!!ENDIF
|
||||||
)
|
)
|
||||||
|
|
||||||
set_target_properties(Qt5::$${CMAKE_MODULE_NAME} PROPERTIES
|
set_target_properties(Qt5::$${CMAKE_MODULE_NAME} PROPERTIES
|
||||||
\"INTERFACE_LINK_LIBRARIES\" \"${_deps}\"
|
|
||||||
\"IMPORTED_LOCATION_${Configuration}\" ${imported_location}
|
\"IMPORTED_LOCATION_${Configuration}\" ${imported_location}
|
||||||
!!IF !isEmpty(CMAKE_LIB_SONAME)
|
!!IF !isEmpty(CMAKE_LIB_SONAME)
|
||||||
\"IMPORTED_SONAME_${Configuration}\" \"$${CMAKE_LIB_SONAME}\"
|
\"IMPORTED_SONAME_${Configuration}\" \"$${CMAKE_LIB_SONAME}\"
|
||||||
!!ENDIF
|
!!ENDIF
|
||||||
# For backward compatibility with CMake < 2.8.12
|
# For backward compatibility with CMake < 2.8.12
|
||||||
\"IMPORTED_LINK_INTERFACE_LIBRARIES_${Configuration}\" \"${_deps}\"
|
\"IMPORTED_LINK_INTERFACE_LIBRARIES_${Configuration}\" \"${_deps};${_static_deps}\"
|
||||||
|
)
|
||||||
|
set_property(TARGET Qt5::$${CMAKE_MODULE_NAME} APPEND PROPERTY INTERFACE_LINK_LIBRARIES
|
||||||
|
\"${_deps}\"
|
||||||
)
|
)
|
||||||
!!IF !isEmpty(CMAKE_STATIC_TYPE)
|
|
||||||
|
|
||||||
if(NOT CMAKE_VERSION VERSION_LESS \"3.13\")
|
!!IF !isEmpty(CMAKE_STATIC_TYPE)
|
||||||
set_target_properties(Qt5::$${CMAKE_MODULE_NAME} PROPERTIES
|
if(NOT "${IsDebugAndRelease}")
|
||||||
\"INTERFACE_LINK_OPTIONS\" \"${_Qt5$${CMAKE_MODULE_NAME}_STATIC_${Configuration}_LINK_FLAGS}\"
|
set(_genex_condition \"1\")
|
||||||
|
else()
|
||||||
|
if("${Configuration}" STREQUAL "DEBUG")
|
||||||
|
set(_genex_condition \"$<CONFIG:Debug>\")
|
||||||
|
else()
|
||||||
|
set(_genex_condition \"$<NOT:$<CONFIG:Debug>>\")
|
||||||
|
endif()
|
||||||
|
endif()
|
||||||
|
|
||||||
|
if(_static_deps)
|
||||||
|
set(_static_deps_genex \"$<${_genex_condition}:${_static_deps}>\")
|
||||||
|
set_property(TARGET Qt5::$${CMAKE_MODULE_NAME} APPEND PROPERTY INTERFACE_LINK_LIBRARIES
|
||||||
|
\"${_static_deps_genex}\"
|
||||||
|
)
|
||||||
|
endif()
|
||||||
|
|
||||||
|
set(_static_link_flags \"${_Qt5$${CMAKE_MODULE_NAME}_STATIC_${Configuration}_LINK_FLAGS}\")
|
||||||
|
if(NOT CMAKE_VERSION VERSION_LESS \"3.13\" AND _static_link_flags)
|
||||||
|
set(_static_link_flags_genex \"$<${_genex_condition}:${_static_link_flags}>\")
|
||||||
|
set_property(TARGET Qt5::$${CMAKE_MODULE_NAME} APPEND PROPERTY INTERFACE_LINK_OPTIONS
|
||||||
|
\"${_static_link_flags_genex}\"
|
||||||
)
|
)
|
||||||
endif()
|
endif()
|
||||||
!!ENDIF
|
!!ENDIF
|
||||||
@ -382,9 +407,9 @@ if (NOT TARGET Qt5::$${CMAKE_MODULE_NAME})
|
|||||||
!!IF !equals(TEMPLATE, aux)
|
!!IF !equals(TEMPLATE, aux)
|
||||||
!!IF !isEmpty(CMAKE_RELEASE_TYPE)
|
!!IF !isEmpty(CMAKE_RELEASE_TYPE)
|
||||||
!!IF !isEmpty(CMAKE_STATIC_WINDOWS_BUILD)
|
!!IF !isEmpty(CMAKE_STATIC_WINDOWS_BUILD)
|
||||||
_populate_$${CMAKE_MODULE_NAME}_target_properties(RELEASE \"$${CMAKE_IMPLIB_FILE_LOCATION_RELEASE}\" \"\" )
|
_populate_$${CMAKE_MODULE_NAME}_target_properties(RELEASE \"$${CMAKE_IMPLIB_FILE_LOCATION_RELEASE}\" \"\" $${CMAKE_DEBUG_AND_RELEASE})
|
||||||
!!ELSE
|
!!ELSE
|
||||||
_populate_$${CMAKE_MODULE_NAME}_target_properties(RELEASE \"$${CMAKE_LIB_FILE_LOCATION_RELEASE}\" \"$${CMAKE_IMPLIB_FILE_LOCATION_RELEASE}\" )
|
_populate_$${CMAKE_MODULE_NAME}_target_properties(RELEASE \"$${CMAKE_LIB_FILE_LOCATION_RELEASE}\" \"$${CMAKE_IMPLIB_FILE_LOCATION_RELEASE}\" $${CMAKE_DEBUG_AND_RELEASE})
|
||||||
!!ENDIF // CMAKE_STATIC_WINDOWS_BUILD
|
!!ENDIF // CMAKE_STATIC_WINDOWS_BUILD
|
||||||
|
|
||||||
!!IF !isEmpty(CMAKE_FIND_OTHER_LIBRARY_BUILD)
|
!!IF !isEmpty(CMAKE_FIND_OTHER_LIBRARY_BUILD)
|
||||||
@ -395,7 +420,7 @@ if (NOT TARGET Qt5::$${CMAKE_MODULE_NAME})
|
|||||||
!!ELSE // CMAKE_LIB_DIR_IS_ABSOLUTE
|
!!ELSE // CMAKE_LIB_DIR_IS_ABSOLUTE
|
||||||
if (EXISTS \"$${CMAKE_IMPLIB_FILE_LOCATION_DEBUG}\" )
|
if (EXISTS \"$${CMAKE_IMPLIB_FILE_LOCATION_DEBUG}\" )
|
||||||
!!ENDIF // CMAKE_LIB_DIR_IS_ABSOLUTE
|
!!ENDIF // CMAKE_LIB_DIR_IS_ABSOLUTE
|
||||||
_populate_$${CMAKE_MODULE_NAME}_target_properties(DEBUG \"$${CMAKE_IMPLIB_FILE_LOCATION_DEBUG}\" \"\" )
|
_populate_$${CMAKE_MODULE_NAME}_target_properties(DEBUG \"$${CMAKE_IMPLIB_FILE_LOCATION_DEBUG}\" \"\" $${CMAKE_DEBUG_AND_RELEASE})
|
||||||
!!ELSE // CMAKE_STATIC_WINDOWS_BUILD
|
!!ELSE // CMAKE_STATIC_WINDOWS_BUILD
|
||||||
if (EXISTS
|
if (EXISTS
|
||||||
!!IF isEmpty(CMAKE_DLL_DIR_IS_ABSOLUTE)
|
!!IF isEmpty(CMAKE_DLL_DIR_IS_ABSOLUTE)
|
||||||
@ -409,7 +434,7 @@ if (NOT TARGET Qt5::$${CMAKE_MODULE_NAME})
|
|||||||
!!ELSE
|
!!ELSE
|
||||||
\"$${CMAKE_IMPLIB_FILE_LOCATION_DEBUG}\" )
|
\"$${CMAKE_IMPLIB_FILE_LOCATION_DEBUG}\" )
|
||||||
!!ENDIF
|
!!ENDIF
|
||||||
_populate_$${CMAKE_MODULE_NAME}_target_properties(DEBUG \"$${CMAKE_LIB_FILE_LOCATION_DEBUG}\" \"$${CMAKE_IMPLIB_FILE_LOCATION_DEBUG}\" )
|
_populate_$${CMAKE_MODULE_NAME}_target_properties(DEBUG \"$${CMAKE_LIB_FILE_LOCATION_DEBUG}\" \"$${CMAKE_IMPLIB_FILE_LOCATION_DEBUG}\" $${CMAKE_DEBUG_AND_RELEASE})
|
||||||
!!ENDIF // CMAKE_STATIC_WINDOWS_BUILD
|
!!ENDIF // CMAKE_STATIC_WINDOWS_BUILD
|
||||||
endif()
|
endif()
|
||||||
!!ENDIF // CMAKE_DEBUG_TYPE
|
!!ENDIF // CMAKE_DEBUG_TYPE
|
||||||
@ -419,9 +444,9 @@ if (NOT TARGET Qt5::$${CMAKE_MODULE_NAME})
|
|||||||
|
|
||||||
!!IF !isEmpty(CMAKE_DEBUG_TYPE)
|
!!IF !isEmpty(CMAKE_DEBUG_TYPE)
|
||||||
!!IF !isEmpty(CMAKE_STATIC_WINDOWS_BUILD)
|
!!IF !isEmpty(CMAKE_STATIC_WINDOWS_BUILD)
|
||||||
_populate_$${CMAKE_MODULE_NAME}_target_properties(DEBUG \"$${CMAKE_IMPLIB_FILE_LOCATION_DEBUG}\" \"\" )
|
_populate_$${CMAKE_MODULE_NAME}_target_properties(DEBUG \"$${CMAKE_IMPLIB_FILE_LOCATION_DEBUG}\" \"\" $${CMAKE_DEBUG_AND_RELEASE})
|
||||||
!!ELSE
|
!!ELSE
|
||||||
_populate_$${CMAKE_MODULE_NAME}_target_properties(DEBUG \"$${CMAKE_LIB_FILE_LOCATION_DEBUG}\" \"$${CMAKE_IMPLIB_FILE_LOCATION_DEBUG}\" )
|
_populate_$${CMAKE_MODULE_NAME}_target_properties(DEBUG \"$${CMAKE_LIB_FILE_LOCATION_DEBUG}\" \"$${CMAKE_IMPLIB_FILE_LOCATION_DEBUG}\" $${CMAKE_DEBUG_AND_RELEASE})
|
||||||
!!ENDIF // CMAKE_STATIC_WINDOWS_BUILD
|
!!ENDIF // CMAKE_STATIC_WINDOWS_BUILD
|
||||||
|
|
||||||
!!IF !isEmpty(CMAKE_FIND_OTHER_LIBRARY_BUILD)
|
!!IF !isEmpty(CMAKE_FIND_OTHER_LIBRARY_BUILD)
|
||||||
@ -432,7 +457,7 @@ if (NOT TARGET Qt5::$${CMAKE_MODULE_NAME})
|
|||||||
!!ELSE // CMAKE_LIB_DIR_IS_ABSOLUTE
|
!!ELSE // CMAKE_LIB_DIR_IS_ABSOLUTE
|
||||||
if (EXISTS \"$${CMAKE_IMPLIB_FILE_LOCATION_RELEASE}\" )
|
if (EXISTS \"$${CMAKE_IMPLIB_FILE_LOCATION_RELEASE}\" )
|
||||||
!!ENDIF // CMAKE_LIB_DIR_IS_ABSOLUTE
|
!!ENDIF // CMAKE_LIB_DIR_IS_ABSOLUTE
|
||||||
_populate_$${CMAKE_MODULE_NAME}_target_properties(RELEASE \"$${CMAKE_IMPLIB_FILE_LOCATION_RELEASE}\" \"\" )
|
_populate_$${CMAKE_MODULE_NAME}_target_properties(RELEASE \"$${CMAKE_IMPLIB_FILE_LOCATION_RELEASE}\" \"\" $${CMAKE_DEBUG_AND_RELEASE})
|
||||||
!!ELSE // CMAKE_STATIC_WINDOWS_BUILD
|
!!ELSE // CMAKE_STATIC_WINDOWS_BUILD
|
||||||
if (EXISTS
|
if (EXISTS
|
||||||
!!IF isEmpty(CMAKE_DLL_DIR_IS_ABSOLUTE)
|
!!IF isEmpty(CMAKE_DLL_DIR_IS_ABSOLUTE)
|
||||||
@ -446,7 +471,7 @@ if (NOT TARGET Qt5::$${CMAKE_MODULE_NAME})
|
|||||||
!!ELSE
|
!!ELSE
|
||||||
\"$${CMAKE_IMPLIB_FILE_LOCATION_RELEASE}\" )
|
\"$${CMAKE_IMPLIB_FILE_LOCATION_RELEASE}\" )
|
||||||
!!ENDIF
|
!!ENDIF
|
||||||
_populate_$${CMAKE_MODULE_NAME}_target_properties(RELEASE \"$${CMAKE_LIB_FILE_LOCATION_RELEASE}\" \"$${CMAKE_IMPLIB_FILE_LOCATION_RELEASE}\" )
|
_populate_$${CMAKE_MODULE_NAME}_target_properties(RELEASE \"$${CMAKE_LIB_FILE_LOCATION_RELEASE}\" \"$${CMAKE_IMPLIB_FILE_LOCATION_RELEASE}\" $${CMAKE_DEBUG_AND_RELEASE})
|
||||||
!!ENDIF // CMAKE_STATIC_WINDOWS_BUILD
|
!!ENDIF // CMAKE_STATIC_WINDOWS_BUILD
|
||||||
endif()
|
endif()
|
||||||
!!ENDIF // CMAKE_RELEASE_TYPE
|
!!ENDIF // CMAKE_RELEASE_TYPE
|
||||||
@ -459,6 +484,8 @@ if (NOT TARGET Qt5::$${CMAKE_MODULE_NAME})
|
|||||||
)
|
)
|
||||||
!!ENDIF // TEMPLATE != aux
|
!!ENDIF // TEMPLATE != aux
|
||||||
|
|
||||||
|
!!IF isEmpty(CMAKE_INTERNAL_MODULE)
|
||||||
|
|
||||||
file(GLOB pluginTargets \"${CMAKE_CURRENT_LIST_DIR}/Qt5$${CMAKE_MODULE_NAME}_*Plugin.cmake\")
|
file(GLOB pluginTargets \"${CMAKE_CURRENT_LIST_DIR}/Qt5$${CMAKE_MODULE_NAME}_*Plugin.cmake\")
|
||||||
|
|
||||||
macro(_populate_$${CMAKE_MODULE_NAME}_plugin_properties Plugin Configuration PLUGIN_LOCATION)
|
macro(_populate_$${CMAKE_MODULE_NAME}_plugin_properties Plugin Configuration PLUGIN_LOCATION)
|
||||||
@ -481,6 +508,8 @@ if (NOT TARGET Qt5::$${CMAKE_MODULE_NAME})
|
|||||||
endforeach()
|
endforeach()
|
||||||
endif()
|
endif()
|
||||||
|
|
||||||
|
!!ENDIF // isEmpty(CMAKE_INTERNAL_MODULE)
|
||||||
|
|
||||||
|
|
||||||
!!IF !isEmpty(CMAKE_MODULE_EXTRAS)
|
!!IF !isEmpty(CMAKE_MODULE_EXTRAS)
|
||||||
include(\"${CMAKE_CURRENT_LIST_DIR}/Qt5$${CMAKE_MODULE_NAME}ConfigExtras.cmake\")
|
include(\"${CMAKE_CURRENT_LIST_DIR}/Qt5$${CMAKE_MODULE_NAME}ConfigExtras.cmake\")
|
||||||
|
@ -37,6 +37,9 @@ defineTest(addExclusiveBuilds) {
|
|||||||
addExclusiveBuildsProper($$join(ARGS, _and_), $$ARGS)
|
addExclusiveBuildsProper($$join(ARGS, _and_), $$ARGS)
|
||||||
}
|
}
|
||||||
|
|
||||||
# Default directories to process
|
QMAKE_DEFAULT_DIRS_TO_PROCESS = QGLTF_DIR TRACEGEN_DIR QMLCACHE_DIR LRELEASE_DIR LEX_DIR YACC_DIR
|
||||||
QMAKE_DIR_REPLACE_SANE += QGLTF_DIR TRACEGEN_DIR QMLCACHE_DIR LRELEASE_DIR LEX_DIR YACC_DIR
|
QMAKE_DIR_REPLACE_SANE += $$QMAKE_DEFAULT_DIRS_TO_PROCESS
|
||||||
QMAKE_DIR_REPLACE = OBJECTS_DIR MOC_DIR RCC_DIR PRECOMPILED_DIR DESTDIR $$QMAKE_DIR_REPLACE_SANE
|
QMAKE_DIR_REPLACE = \
|
||||||
|
OBJECTS_DIR MOC_DIR RCC_DIR PRECOMPILED_DIR DESTDIR \
|
||||||
|
$$QMAKE_DEFAULT_DIRS_TO_PROCESS
|
||||||
|
unset(QMAKE_DEFAULT_DIRS_TO_PROCESS)
|
||||||
|
@ -27,6 +27,24 @@ QT_TOOL_ENV = qtver qtmver qtvertag qtdocs builddir
|
|||||||
qtPrepareTool(QDOC, qdoc)
|
qtPrepareTool(QDOC, qdoc)
|
||||||
QT_TOOL_ENV =
|
QT_TOOL_ENV =
|
||||||
|
|
||||||
|
# On Windows, put the includes into a .inc file which QDoc will read, if the project
|
||||||
|
# has too many includes. We do this to overcome a command-line limit on Windows.
|
||||||
|
WIN_INCLUDETEMP=
|
||||||
|
INCLUDE_PATHS=$$INCPATH
|
||||||
|
win32:count(INCLUDE_PATHS, 30, >) {
|
||||||
|
WIN_INCLUDETEMP = $$OUT_PWD/qdocincludepaths.inc
|
||||||
|
WIN_INCLUDETEMP_CONTENT =
|
||||||
|
for (inc, INCLUDE_PATHS): \
|
||||||
|
WIN_INCLUDETEMP_CONTENT += -I$$inc
|
||||||
|
write_file($$absolute_path($$WIN_INCLUDETEMP, $$OUT_PWD), WIN_INCLUDETEMP_CONTENT)|error()
|
||||||
|
}
|
||||||
|
|
||||||
|
isEmpty(WIN_INCLUDETEMP) {
|
||||||
|
QDOC_INCLUDE_PATHS=$(INCPATH)
|
||||||
|
} else {
|
||||||
|
QDOC_INCLUDE_PATHS=@$$shell_quote($$WIN_INCLUDETEMP)
|
||||||
|
}
|
||||||
|
|
||||||
!build_online_docs: qtPrepareTool(QHELPGENERATOR, qhelpgenerator)
|
!build_online_docs: qtPrepareTool(QHELPGENERATOR, qhelpgenerator)
|
||||||
|
|
||||||
qtPrepareTool(QTATTRIBUTIONSSCANNER, qtattributionsscanner)
|
qtPrepareTool(QTATTRIBUTIONSSCANNER, qtattributionsscanner)
|
||||||
@ -75,12 +93,13 @@ qtattributionsscanner.CONFIG += phony
|
|||||||
QMAKE_EXTRA_TARGETS += qtattributionsscanner
|
QMAKE_EXTRA_TARGETS += qtattributionsscanner
|
||||||
|
|
||||||
doc_command = $$QDOC $$QMAKE_DOCS
|
doc_command = $$QDOC $$QMAKE_DOCS
|
||||||
|
|
||||||
prepare_docs {
|
prepare_docs {
|
||||||
prepare_docs.commands += $$doc_command -prepare $$PREP_DOC_INDEXES -no-link-errors $(INCPATH)
|
prepare_docs.commands += $$doc_command -prepare $$PREP_DOC_INDEXES -no-link-errors $$QDOC_INCLUDE_PATHS
|
||||||
generate_docs.commands += $$doc_command -generate $$DOC_INDEXES $(INCPATH)
|
generate_docs.commands += $$doc_command -generate $$DOC_INDEXES $$QDOC_INCLUDE_PATHS
|
||||||
prepare_docs.depends += qtattributionsscanner
|
prepare_docs.depends += qtattributionsscanner
|
||||||
} else {
|
} else {
|
||||||
html_docs.commands += $$doc_command $$DOC_INDEXES $(INCPATH)
|
html_docs.commands += $$doc_command $$DOC_INDEXES $(QDOC_INCLUDE_PATHS)
|
||||||
html_docs.depends += qtattributionsscanner
|
html_docs.depends += qtattributionsscanner
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -117,7 +117,7 @@ unset(QT_FOR_PRIVATE)
|
|||||||
QMAKE_USE_PRIVATE += $$QMAKE_USE_FOR_PRIVATE
|
QMAKE_USE_PRIVATE += $$QMAKE_USE_FOR_PRIVATE
|
||||||
unset(QMAKE_USE_FOR_PRIVATE)
|
unset(QMAKE_USE_FOR_PRIVATE)
|
||||||
|
|
||||||
!internal_module:CONFIG += create_cmake
|
CONFIG += create_cmake
|
||||||
|
|
||||||
contains(TARGET, QtAddOn.*): \
|
contains(TARGET, QtAddOn.*): \
|
||||||
DEFINES += QT_BUILD_ADDON_$${ucmodule}_LIB
|
DEFINES += QT_BUILD_ADDON_$${ucmodule}_LIB
|
||||||
|
@ -304,7 +304,6 @@ headersclean:!internal_module {
|
|||||||
header_check.variable_out = PRE_TARGETDEPS
|
header_check.variable_out = PRE_TARGETDEPS
|
||||||
header_check.name = headercheck ${QMAKE_FILE_IN}
|
header_check.name = headercheck ${QMAKE_FILE_IN}
|
||||||
header_check.commands = $$hcleanCOMMAND
|
header_check.commands = $$hcleanCOMMAND
|
||||||
silent:header_check.commands = @echo compiling[header] ${QMAKE_FILE_IN} && $$hcleanCOMMAND
|
|
||||||
QMAKE_EXTRA_COMPILERS += header_check
|
QMAKE_EXTRA_COMPILERS += header_check
|
||||||
}
|
}
|
||||||
unset(hcleanCOMMAND)
|
unset(hcleanCOMMAND)
|
||||||
|
@ -46,11 +46,17 @@ import json
|
|||||||
import subprocess
|
import subprocess
|
||||||
from distutils.version import StrictVersion
|
from distutils.version import StrictVersion
|
||||||
|
|
||||||
|
def is_available(object):
|
||||||
|
if "isAvailable" in object:
|
||||||
|
return object["isAvailable"] # introduced in Xcode 11
|
||||||
|
else:
|
||||||
|
return "unavailable" not in object["availability"]
|
||||||
|
|
||||||
def is_suitable_runtime(runtimes, runtime_name, platform, min_version):
|
def is_suitable_runtime(runtimes, runtime_name, platform, min_version):
|
||||||
for runtime in runtimes:
|
for runtime in runtimes:
|
||||||
identifier = runtime["identifier"]
|
identifier = runtime["identifier"]
|
||||||
if (runtime["name"] == runtime_name or identifier == runtime_name) \
|
if (runtime["name"] == runtime_name or identifier == runtime_name) \
|
||||||
and "unavailable" not in runtime["availability"] \
|
and is_available(runtime) \
|
||||||
and identifier.startswith("com.apple.CoreSimulator.SimRuntime.{}".format(platform)) \
|
and identifier.startswith("com.apple.CoreSimulator.SimRuntime.{}".format(platform)) \
|
||||||
and StrictVersion(runtime["version"]) >= min_version:
|
and StrictVersion(runtime["version"]) >= min_version:
|
||||||
return True
|
return True
|
||||||
@ -77,6 +83,6 @@ if __name__ == "__main__":
|
|||||||
for runtime_name in device_dict:
|
for runtime_name in device_dict:
|
||||||
if is_suitable_runtime(runtimes, runtime_name, args.platform, args.minimum_deployment_target):
|
if is_suitable_runtime(runtimes, runtime_name, args.platform, args.minimum_deployment_target):
|
||||||
for device in device_dict[runtime_name]:
|
for device in device_dict[runtime_name]:
|
||||||
if "unavailable" not in device["availability"] \
|
if is_available(device) \
|
||||||
and (args.state is None or device["state"].lower() in args.state):
|
and (args.state is None or device["state"].lower() in args.state):
|
||||||
print(device["udid"])
|
print(device["udid"])
|
||||||
|
@ -58,9 +58,9 @@ debug_and_release:!build_pass: return()
|
|||||||
|
|
||||||
DOCKER_ENABLED = 1
|
DOCKER_ENABLED = 1
|
||||||
|
|
||||||
equals(QMAKE_HOST.os, Darwin) | equals(QMAKE_HOST.os, Windows) {
|
equals(QMAKE_HOST.os, Darwin) {
|
||||||
DOCKER_ENABLED = 0
|
DOCKER_ENABLED = 0
|
||||||
message("Not using docker network test server on macOS and Windows, see QTQAINFRA-2717 and QTQAINFRA-2750")
|
message("Not using docker network test server on macOS, see QTQAINFRA-2717 and QTQAINFRA-2750")
|
||||||
}
|
}
|
||||||
|
|
||||||
TESTSERVER_VERSION = ""
|
TESTSERVER_VERSION = ""
|
||||||
|
@ -105,24 +105,24 @@ DEPEND_SRC = \
|
|||||||
$(SOURCE_PATH)/src/corelib/serialization/qtextstream.cpp \
|
$(SOURCE_PATH)/src/corelib/serialization/qtextstream.cpp \
|
||||||
$(SOURCE_PATH)/src/corelib/serialization/qxmlstream.cpp \
|
$(SOURCE_PATH)/src/corelib/serialization/qxmlstream.cpp \
|
||||||
$(SOURCE_PATH)/src/corelib/serialization/qxmlutils.cpp \
|
$(SOURCE_PATH)/src/corelib/serialization/qxmlutils.cpp \
|
||||||
|
$(SOURCE_PATH)/src/corelib/text/qbytearray.cpp\
|
||||||
|
$(SOURCE_PATH)/src/corelib/text/qbytearraymatcher.cpp \
|
||||||
|
$(SOURCE_PATH)/src/corelib/text/qlocale.cpp \
|
||||||
|
$(SOURCE_PATH)/src/corelib/text/qlocale_tools.cpp \
|
||||||
|
$(SOURCE_PATH)/src/corelib/text/qregexp.cpp \
|
||||||
|
$(SOURCE_PATH)/src/corelib/text/qstringbuilder.cpp \
|
||||||
|
$(SOURCE_PATH)/src/corelib/text/qstring.cpp \
|
||||||
|
$(SOURCE_PATH)/src/corelib/text/qstringlist.cpp \
|
||||||
|
$(SOURCE_PATH)/src/corelib/text/qvsnprintf.cpp \
|
||||||
$(SOURCE_PATH)/src/corelib/time/qdatetime.cpp \
|
$(SOURCE_PATH)/src/corelib/time/qdatetime.cpp \
|
||||||
$(SOURCE_PATH)/src/corelib/tools/qarraydata.cpp \
|
$(SOURCE_PATH)/src/corelib/tools/qarraydata.cpp \
|
||||||
$(SOURCE_PATH)/src/corelib/tools/qbitarray.cpp \
|
$(SOURCE_PATH)/src/corelib/tools/qbitarray.cpp \
|
||||||
$(SOURCE_PATH)/src/corelib/tools/qbytearray.cpp\
|
|
||||||
$(SOURCE_PATH)/src/corelib/tools/qbytearraymatcher.cpp \
|
|
||||||
$(SOURCE_PATH)/src/corelib/tools/qcryptographichash.cpp \
|
$(SOURCE_PATH)/src/corelib/tools/qcryptographichash.cpp \
|
||||||
$(SOURCE_PATH)/src/corelib/tools/qhash.cpp \
|
$(SOURCE_PATH)/src/corelib/tools/qhash.cpp \
|
||||||
$(SOURCE_PATH)/src/corelib/tools/qlist.cpp \
|
$(SOURCE_PATH)/src/corelib/tools/qlist.cpp \
|
||||||
$(SOURCE_PATH)/src/corelib/tools/qlocale.cpp \
|
|
||||||
$(SOURCE_PATH)/src/corelib/tools/qlocale_tools.cpp \
|
|
||||||
$(SOURCE_PATH)/src/corelib/tools/qmap.cpp \
|
$(SOURCE_PATH)/src/corelib/tools/qmap.cpp \
|
||||||
$(SOURCE_PATH)/src/corelib/tools/qregexp.cpp \
|
|
||||||
$(SOURCE_PATH)/src/corelib/tools/qringbuffer.cpp \
|
$(SOURCE_PATH)/src/corelib/tools/qringbuffer.cpp \
|
||||||
$(SOURCE_PATH)/src/corelib/tools/qstringbuilder.cpp \
|
|
||||||
$(SOURCE_PATH)/src/corelib/tools/qstring.cpp \
|
|
||||||
$(SOURCE_PATH)/src/corelib/tools/qstringlist.cpp \
|
|
||||||
$(SOURCE_PATH)/src/corelib/tools/qversionnumber.cpp \
|
$(SOURCE_PATH)/src/corelib/tools/qversionnumber.cpp \
|
||||||
$(SOURCE_PATH)/src/corelib/tools/qvsnprintf.cpp \
|
|
||||||
$(QTSRCS) $(QTSRCS2)
|
$(QTSRCS) $(QTSRCS2)
|
||||||
# QTSRCS and QTSRCS2 come from Makefile.unix.* (concatenated with this
|
# QTSRCS and QTSRCS2 come from Makefile.unix.* (concatenated with this
|
||||||
# by configure); QTSRCS2 may include *.mm entries on macOS.
|
# by configure); QTSRCS2 may include *.mm entries on macOS.
|
||||||
@ -302,13 +302,13 @@ qglobal.o: $(SOURCE_PATH)/src/corelib/global/qglobal.cpp
|
|||||||
qarraydata.o: $(SOURCE_PATH)/src/corelib/tools/qarraydata.cpp
|
qarraydata.o: $(SOURCE_PATH)/src/corelib/tools/qarraydata.cpp
|
||||||
$(CXX) -c -o $@ $(CXXFLAGS) $<
|
$(CXX) -c -o $@ $(CXXFLAGS) $<
|
||||||
|
|
||||||
qbytearray.o: $(SOURCE_PATH)/src/corelib/tools/qbytearray.cpp
|
qbytearray.o: $(SOURCE_PATH)/src/corelib/text/qbytearray.cpp
|
||||||
$(CXX) -c -o $@ $(CXXFLAGS) $<
|
$(CXX) -c -o $@ $(CXXFLAGS) $<
|
||||||
|
|
||||||
qvsnprintf.o: $(SOURCE_PATH)/src/corelib/tools/qvsnprintf.cpp
|
qvsnprintf.o: $(SOURCE_PATH)/src/corelib/text/qvsnprintf.cpp
|
||||||
$(CXX) -c -o $@ $(CXXFLAGS) $<
|
$(CXX) -c -o $@ $(CXXFLAGS) $<
|
||||||
|
|
||||||
qbytearraymatcher.o: $(SOURCE_PATH)/src/corelib/tools/qbytearraymatcher.cpp
|
qbytearraymatcher.o: $(SOURCE_PATH)/src/corelib/text/qbytearraymatcher.cpp
|
||||||
$(CXX) -c -o $@ $(CXXFLAGS) $<
|
$(CXX) -c -o $@ $(CXXFLAGS) $<
|
||||||
|
|
||||||
qmetatype.o: $(SOURCE_PATH)/src/corelib/kernel/qmetatype.cpp
|
qmetatype.o: $(SOURCE_PATH)/src/corelib/kernel/qmetatype.cpp
|
||||||
@ -338,22 +338,22 @@ qcore_foundation.o: $(SOURCE_PATH)/src/corelib/kernel/qcore_foundation.mm
|
|||||||
qutfcodec.o: $(SOURCE_PATH)/src/corelib/codecs/qutfcodec.cpp
|
qutfcodec.o: $(SOURCE_PATH)/src/corelib/codecs/qutfcodec.cpp
|
||||||
$(CXX) -c -o $@ $(CXXFLAGS) $<
|
$(CXX) -c -o $@ $(CXXFLAGS) $<
|
||||||
|
|
||||||
qstring.o: $(SOURCE_PATH)/src/corelib/tools/qstring.cpp
|
qstring.o: $(SOURCE_PATH)/src/corelib/text/qstring.cpp
|
||||||
$(CXX) -c -o $@ $(CXXFLAGS) $<
|
$(CXX) -c -o $@ $(CXXFLAGS) $<
|
||||||
|
|
||||||
qstringbuilder.o: $(SOURCE_PATH)/src/corelib/tools/qstringbuilder.cpp
|
qstringbuilder.o: $(SOURCE_PATH)/src/corelib/text/qstringbuilder.cpp
|
||||||
$(CXX) -c -o $@ $(CXXFLAGS) $<
|
$(CXX) -c -o $@ $(CXXFLAGS) $<
|
||||||
|
|
||||||
qlocale.o: $(SOURCE_PATH)/src/corelib/tools/qlocale.cpp
|
qlocale.o: $(SOURCE_PATH)/src/corelib/text/qlocale.cpp
|
||||||
$(CXX) -c -o $@ $(CXXFLAGS) $<
|
$(CXX) -c -o $@ $(CXXFLAGS) $<
|
||||||
|
|
||||||
qlocale_tools.o: $(SOURCE_PATH)/src/corelib/tools/qlocale_tools.cpp
|
qlocale_tools.o: $(SOURCE_PATH)/src/corelib/text/qlocale_tools.cpp
|
||||||
$(CXX) -c -o $@ $(CXXFLAGS) $<
|
$(CXX) -c -o $@ $(CXXFLAGS) $<
|
||||||
|
|
||||||
qlocale_unix.o: $(SOURCE_PATH)/src/corelib/tools/qlocale_unix.cpp
|
qlocale_unix.o: $(SOURCE_PATH)/src/corelib/text/qlocale_unix.cpp
|
||||||
$(CXX) -c -o $@ $(CXXFLAGS) $<
|
$(CXX) -c -o $@ $(CXXFLAGS) $<
|
||||||
|
|
||||||
qlocale_win.o: $(SOURCE_PATH)/src/corelib/tools/qlocale_win.cpp
|
qlocale_win.o: $(SOURCE_PATH)/src/corelib/text/qlocale_win.cpp
|
||||||
$(CXX) -c -o $@ $(CXXFLAGS) $<
|
$(CXX) -c -o $@ $(CXXFLAGS) $<
|
||||||
|
|
||||||
qversionnumber.o: $(SOURCE_PATH)/src/corelib/tools/qversionnumber.cpp
|
qversionnumber.o: $(SOURCE_PATH)/src/corelib/tools/qversionnumber.cpp
|
||||||
@ -407,7 +407,7 @@ qabstractfileengine.o: $(SOURCE_PATH)/src/corelib/io/qabstractfileengine.cpp
|
|||||||
qtemporaryfile.o: $(SOURCE_PATH)/src/corelib/io/qtemporaryfile.cpp
|
qtemporaryfile.o: $(SOURCE_PATH)/src/corelib/io/qtemporaryfile.cpp
|
||||||
$(CXX) -c -o $@ $(CXXFLAGS) $<
|
$(CXX) -c -o $@ $(CXXFLAGS) $<
|
||||||
|
|
||||||
qregexp.o: $(SOURCE_PATH)/src/corelib/tools/qregexp.cpp
|
qregexp.o: $(SOURCE_PATH)/src/corelib/text/qregexp.cpp
|
||||||
$(CXX) -c -o $@ $(CXXFLAGS) $<
|
$(CXX) -c -o $@ $(CXXFLAGS) $<
|
||||||
|
|
||||||
qbitarray.o: $(SOURCE_PATH)/src/corelib/tools/qbitarray.cpp
|
qbitarray.o: $(SOURCE_PATH)/src/corelib/tools/qbitarray.cpp
|
||||||
@ -428,7 +428,7 @@ qfileinfo.o: $(SOURCE_PATH)/src/corelib/io/qfileinfo.cpp
|
|||||||
qdatetime.o: $(SOURCE_PATH)/src/corelib/time/qdatetime.cpp
|
qdatetime.o: $(SOURCE_PATH)/src/corelib/time/qdatetime.cpp
|
||||||
$(CXX) -c -o $@ $(CXXFLAGS) $<
|
$(CXX) -c -o $@ $(CXXFLAGS) $<
|
||||||
|
|
||||||
qstringlist.o: $(SOURCE_PATH)/src/corelib/tools/qstringlist.cpp
|
qstringlist.o: $(SOURCE_PATH)/src/corelib/text/qstringlist.cpp
|
||||||
$(CXX) -c -o $@ $(CXXFLAGS) $<
|
$(CXX) -c -o $@ $(CXXFLAGS) $<
|
||||||
|
|
||||||
qmap.o: $(SOURCE_PATH)/src/corelib/tools/qmap.cpp
|
qmap.o: $(SOURCE_PATH)/src/corelib/tools/qmap.cpp
|
||||||
|
@ -196,6 +196,9 @@ qmake_pch.obj:
|
|||||||
{$(SOURCE_PATH)\src\corelib\serialization}.cpp{}.obj::
|
{$(SOURCE_PATH)\src\corelib\serialization}.cpp{}.obj::
|
||||||
$(CXX) $(CXXFLAGS) $<
|
$(CXX) $(CXXFLAGS) $<
|
||||||
|
|
||||||
|
{$(SOURCE_PATH)\src\corelib\text}.cpp{}.obj::
|
||||||
|
$(CXX) $(CXXFLAGS) $<
|
||||||
|
|
||||||
{$(SOURCE_PATH)\src\corelib\time}.cpp{}.obj::
|
{$(SOURCE_PATH)\src\corelib\time}.cpp{}.obj::
|
||||||
$(CXX) $(CXXFLAGS) $<
|
$(CXX) $(CXXFLAGS) $<
|
||||||
|
|
||||||
|
@ -167,14 +167,8 @@ MakefileGenerator::initOutPaths()
|
|||||||
ProString &pathRef = v[dkey].first();
|
ProString &pathRef = v[dkey].first();
|
||||||
pathRef = fileFixify(pathRef.toQString(), FileFixifyFromOutdir);
|
pathRef = fileFixify(pathRef.toQString(), FileFixifyFromOutdir);
|
||||||
|
|
||||||
#ifdef Q_OS_WIN
|
if (!pathRef.endsWith(Option::dir_sep))
|
||||||
// We don't want to add a separator for DLLDESTDIR on Windows (###why?)
|
|
||||||
if (dkey != "DLLDESTDIR")
|
|
||||||
#endif
|
|
||||||
{
|
|
||||||
if(!pathRef.endsWith(Option::dir_sep))
|
|
||||||
pathRef += Option::dir_sep;
|
pathRef += Option::dir_sep;
|
||||||
}
|
|
||||||
|
|
||||||
if (noIO() || (project->first("TEMPLATE") == "subdirs"))
|
if (noIO() || (project->first("TEMPLATE") == "subdirs"))
|
||||||
continue;
|
continue;
|
||||||
@ -2233,21 +2227,6 @@ MakefileGenerator::writeDummyMakefile(QTextStream &t)
|
|||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
bool
|
|
||||||
MakefileGenerator::writeStubMakefile(QTextStream &t)
|
|
||||||
{
|
|
||||||
t << "QMAKE = " << var("QMAKE_QMAKE") << Qt::endl;
|
|
||||||
const ProStringList &qut = project->values("QMAKE_EXTRA_TARGETS");
|
|
||||||
for (ProStringList::ConstIterator it = qut.begin(); it != qut.end(); ++it)
|
|
||||||
t << *it << " ";
|
|
||||||
//const QString ofile = Option::fixPathToTargetOS(fileFixify(Option::output.fileName()));
|
|
||||||
t << "first all clean install distclean uninstall: qmake\n"
|
|
||||||
<< "qmake_all:\n";
|
|
||||||
writeMakeQmake(t);
|
|
||||||
t << "FORCE:\n\n";
|
|
||||||
return true;
|
|
||||||
}
|
|
||||||
|
|
||||||
bool
|
bool
|
||||||
MakefileGenerator::writeMakefile(QTextStream &t)
|
MakefileGenerator::writeMakefile(QTextStream &t)
|
||||||
{
|
{
|
||||||
@ -2299,9 +2278,9 @@ QString MakefileGenerator::buildArgs(bool withExtra)
|
|||||||
|
|
||||||
//could get stored argv, but then it would have more options than are
|
//could get stored argv, but then it would have more options than are
|
||||||
//probably necesary this will try to guess the bare minimum..
|
//probably necesary this will try to guess the bare minimum..
|
||||||
QString MakefileGenerator::build_args()
|
QString MakefileGenerator::fullBuildArgs()
|
||||||
{
|
{
|
||||||
QString ret = "$(QMAKE)";
|
QString ret;
|
||||||
|
|
||||||
//output
|
//output
|
||||||
QString ofile = fileFixify(Option::output.fileName());
|
QString ofile = fileFixify(Option::output.fileName());
|
||||||
@ -2326,7 +2305,7 @@ MakefileGenerator::writeHeader(QTextStream &t)
|
|||||||
t << "# Project: " << fileFixify(project->projectFile()) << Qt::endl;
|
t << "# Project: " << fileFixify(project->projectFile()) << Qt::endl;
|
||||||
t << "# Template: " << var("TEMPLATE") << Qt::endl;
|
t << "# Template: " << var("TEMPLATE") << Qt::endl;
|
||||||
if(!project->isActiveConfig("build_pass"))
|
if(!project->isActiveConfig("build_pass"))
|
||||||
t << "# Command: " << build_args().replace(QLatin1String("$(QMAKE)"), var("QMAKE_QMAKE")) << Qt::endl;
|
t << "# Command: " << var("QMAKE_QMAKE") << fullBuildArgs() << Qt::endl;
|
||||||
t << "#############################################################################\n";
|
t << "#############################################################################\n";
|
||||||
t << Qt::endl;
|
t << Qt::endl;
|
||||||
QString ofile = Option::fixPathToTargetOS(Option::output.fileName());
|
QString ofile = Option::fixPathToTargetOS(Option::output.fileName());
|
||||||
@ -2792,7 +2771,7 @@ MakefileGenerator::writeMakeQmake(QTextStream &t, bool noDummyQmakeAll)
|
|||||||
<< "@$(QMAKE) -prl " << files.join(' ') << ' ' << buildArgs(true) << Qt::endl;
|
<< "@$(QMAKE) -prl " << files.join(' ') << ' ' << buildArgs(true) << Qt::endl;
|
||||||
}
|
}
|
||||||
|
|
||||||
QString qmake = build_args();
|
QString qmake = "$(QMAKE)" + fullBuildArgs();
|
||||||
if(!ofile.isEmpty() && !project->isActiveConfig("no_autoqmake")) {
|
if(!ofile.isEmpty() && !project->isActiveConfig("no_autoqmake")) {
|
||||||
t << escapeDependencyPath(ofile) << ": "
|
t << escapeDependencyPath(ofile) << ": "
|
||||||
<< escapeDependencyPath(fileFixify(project->projectFile())) << " ";
|
<< escapeDependencyPath(fileFixify(project->projectFile())) << " ";
|
||||||
@ -3429,9 +3408,9 @@ MakefileGenerator::writePkgConfigFile()
|
|||||||
t << Qt::endl;
|
t << Qt::endl;
|
||||||
|
|
||||||
// requires
|
// requires
|
||||||
const QString requires = project->values("QMAKE_PKGCONFIG_REQUIRES").join(' ');
|
const QString requiresString = project->values("QMAKE_PKGCONFIG_REQUIRES").join(' ');
|
||||||
if (!requires.isEmpty()) {
|
if (!requiresString.isEmpty()) {
|
||||||
t << "Requires: " << requires << Qt::endl;
|
t << "Requires: " << requiresString << Qt::endl;
|
||||||
}
|
}
|
||||||
|
|
||||||
t << Qt::endl;
|
t << Qt::endl;
|
||||||
|
@ -58,7 +58,7 @@ class MakefileGenerator : protected QMakeSourceFileInfo
|
|||||||
bool resolveDependenciesInFrameworks = false;
|
bool resolveDependenciesInFrameworks = false;
|
||||||
QHash<QString, bool> init_compiler_already;
|
QHash<QString, bool> init_compiler_already;
|
||||||
QString makedir, chkexists;
|
QString makedir, chkexists;
|
||||||
QString build_args();
|
QString fullBuildArgs();
|
||||||
|
|
||||||
//internal caches
|
//internal caches
|
||||||
mutable QHash<QString, QMakeLocalFileName> depHeuristicsCache;
|
mutable QHash<QString, QMakeLocalFileName> depHeuristicsCache;
|
||||||
@ -90,7 +90,6 @@ protected:
|
|||||||
void writeExtraCompilerTargets(QTextStream &t);
|
void writeExtraCompilerTargets(QTextStream &t);
|
||||||
void writeExtraCompilerVariables(QTextStream &t);
|
void writeExtraCompilerVariables(QTextStream &t);
|
||||||
bool writeDummyMakefile(QTextStream &t);
|
bool writeDummyMakefile(QTextStream &t);
|
||||||
virtual bool writeStubMakefile(QTextStream &t);
|
|
||||||
virtual bool writeMakefile(QTextStream &t);
|
virtual bool writeMakefile(QTextStream &t);
|
||||||
virtual void writeDefaultVariables(QTextStream &t);
|
virtual void writeDefaultVariables(QTextStream &t);
|
||||||
|
|
||||||
|
@ -57,6 +57,7 @@ private:
|
|||||||
QList<Build *> makefiles;
|
QList<Build *> makefiles;
|
||||||
void clearBuilds();
|
void clearBuilds();
|
||||||
MakefileGenerator *processBuild(const ProString &);
|
MakefileGenerator *processBuild(const ProString &);
|
||||||
|
void accumulateVariableFromBuilds(const ProKey &name, Build *build) const;
|
||||||
|
|
||||||
public:
|
public:
|
||||||
|
|
||||||
@ -95,9 +96,6 @@ BuildsMetaMakefileGenerator::init()
|
|||||||
if(builds.count() > 1 && Option::output.fileName() == "-") {
|
if(builds.count() > 1 && Option::output.fileName() == "-") {
|
||||||
use_single_build = true;
|
use_single_build = true;
|
||||||
warn_msg(WarnLogic, "Cannot direct to stdout when using multiple BUILDS.");
|
warn_msg(WarnLogic, "Cannot direct to stdout when using multiple BUILDS.");
|
||||||
} else if(0 && !use_single_build && project->first("TEMPLATE") == "subdirs") {
|
|
||||||
use_single_build = true;
|
|
||||||
warn_msg(WarnLogic, "Cannot specify multiple builds with TEMPLATE subdirs.");
|
|
||||||
}
|
}
|
||||||
if(!use_single_build) {
|
if(!use_single_build) {
|
||||||
for(int i = 0; i < builds.count(); i++) {
|
for(int i = 0; i < builds.count(); i++) {
|
||||||
@ -188,6 +186,7 @@ BuildsMetaMakefileGenerator::write()
|
|||||||
if(!build->makefile) {
|
if(!build->makefile) {
|
||||||
ret = false;
|
ret = false;
|
||||||
} else if(build == glue) {
|
} else if(build == glue) {
|
||||||
|
accumulateVariableFromBuilds("QMAKE_INTERNAL_INCLUDED_FILES", build);
|
||||||
ret = build->makefile->writeProjectMakefile();
|
ret = build->makefile->writeProjectMakefile();
|
||||||
} else {
|
} else {
|
||||||
ret = build->makefile->write();
|
ret = build->makefile->write();
|
||||||
@ -230,6 +229,16 @@ MakefileGenerator
|
|||||||
return nullptr;
|
return nullptr;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void BuildsMetaMakefileGenerator::accumulateVariableFromBuilds(const ProKey &name, Build *dst) const
|
||||||
|
{
|
||||||
|
ProStringList &values = dst->makefile->projectFile()->values(name);
|
||||||
|
for (auto build : makefiles) {
|
||||||
|
if (build != dst)
|
||||||
|
values += build->makefile->projectFile()->values(name);
|
||||||
|
}
|
||||||
|
values.removeDuplicates();
|
||||||
|
}
|
||||||
|
|
||||||
class SubdirsMetaMakefileGenerator : public MetaMakefileGenerator
|
class SubdirsMetaMakefileGenerator : public MetaMakefileGenerator
|
||||||
{
|
{
|
||||||
protected:
|
protected:
|
||||||
@ -327,9 +336,6 @@ SubdirsMetaMakefileGenerator::init()
|
|||||||
hasError |= tmpError;
|
hasError |= tmpError;
|
||||||
}
|
}
|
||||||
sub->makefile = MetaMakefileGenerator::createMetaGenerator(sub_proj, sub_name);
|
sub->makefile = MetaMakefileGenerator::createMetaGenerator(sub_proj, sub_name);
|
||||||
if(0 && sub->makefile->type() == SUBDIRSMETATYPE) {
|
|
||||||
subs.append(sub);
|
|
||||||
} else {
|
|
||||||
const QString output_name = Option::output.fileName();
|
const QString output_name = Option::output.fileName();
|
||||||
Option::output.setFileName(sub->output_file);
|
Option::output.setFileName(sub->output_file);
|
||||||
hasError |= !sub->makefile->write();
|
hasError |= !sub->makefile->write();
|
||||||
@ -337,7 +343,6 @@ SubdirsMetaMakefileGenerator::init()
|
|||||||
qmakeClearCaches();
|
qmakeClearCaches();
|
||||||
sub = nullptr;
|
sub = nullptr;
|
||||||
Option::output.setFileName(output_name);
|
Option::output.setFileName(output_name);
|
||||||
}
|
|
||||||
Option::output_dir = old_output_dir;
|
Option::output_dir = old_output_dir;
|
||||||
qmake_setpwd(oldpwd);
|
qmake_setpwd(oldpwd);
|
||||||
|
|
||||||
|
@ -497,21 +497,20 @@ UnixMakefileGenerator::findLibraries(bool linkPrl, bool mergeLflags)
|
|||||||
// Make sure we keep the dependency order of libraries
|
// Make sure we keep the dependency order of libraries
|
||||||
lflags[arch].removeAll(opt);
|
lflags[arch].removeAll(opt);
|
||||||
lflags[arch].append(opt);
|
lflags[arch].append(opt);
|
||||||
} else if (target_mode == TARG_MAC_MODE && opt.startsWith("-framework")) {
|
} else if (target_mode == TARG_MAC_MODE
|
||||||
if (opt.length() > 10) {
|
&& (opt == "-framework" || opt == "-force_load")) {
|
||||||
opt = opt.mid(10).trimmed();
|
// Handle space separated options
|
||||||
} else {
|
ProString dashOpt = opt;
|
||||||
opt = l.at(++lit);
|
opt = l.at(++lit);
|
||||||
if (opt.startsWith("-Xarch"))
|
if (opt.startsWith("-Xarch"))
|
||||||
opt = l.at(++lit); // The user has done the right thing and prefixed each part
|
opt = l.at(++lit); // The user has done the right thing and prefixed each part
|
||||||
}
|
|
||||||
for(int x = 0; x < lflags[arch].size(); ++x) {
|
for(int x = 0; x < lflags[arch].size(); ++x) {
|
||||||
if (lflags[arch].at(x) == "-framework" && lflags[arch].at(++x) == opt) {
|
if (lflags[arch].at(x) == dashOpt && lflags[arch].at(++x) == opt) {
|
||||||
lflags[arch].remove(x - 1, 2);
|
lflags[arch].remove(x - 1, 2);
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
lflags[arch].append("-framework");
|
lflags[arch].append(dashOpt);
|
||||||
lflags[arch].append(opt);
|
lflags[arch].append(opt);
|
||||||
} else {
|
} else {
|
||||||
lflags[arch].append(opt);
|
lflags[arch].append(opt);
|
||||||
|
@ -42,7 +42,6 @@ class UnixMakefileGenerator : public MakefileGenerator
|
|||||||
|
|
||||||
protected:
|
protected:
|
||||||
virtual bool doPrecompiledHeaders() const { return project->isActiveConfig("precompile_header"); }
|
virtual bool doPrecompiledHeaders() const { return project->isActiveConfig("precompile_header"); }
|
||||||
bool doDepends() const override { return !Option::mkfile::do_stub_makefile && MakefileGenerator::doDepends(); }
|
|
||||||
#ifdef Q_OS_WIN // MinGW x-compiling for QNX
|
#ifdef Q_OS_WIN // MinGW x-compiling for QNX
|
||||||
QString installRoot() const override;
|
QString installRoot() const override;
|
||||||
#endif
|
#endif
|
||||||
|
@ -66,8 +66,6 @@ UnixMakefileGenerator::writeMakefile(QTextStream &t)
|
|||||||
if (project->first("TEMPLATE") == "app" ||
|
if (project->first("TEMPLATE") == "app" ||
|
||||||
project->first("TEMPLATE") == "lib" ||
|
project->first("TEMPLATE") == "lib" ||
|
||||||
project->first("TEMPLATE") == "aux") {
|
project->first("TEMPLATE") == "aux") {
|
||||||
if(Option::mkfile::do_stub_makefile && MakefileGenerator::writeStubMakefile(t))
|
|
||||||
return true;
|
|
||||||
writeMakeParts(t);
|
writeMakeParts(t);
|
||||||
return MakefileGenerator::writeMakefile(t);
|
return MakefileGenerator::writeMakefile(t);
|
||||||
} else if (project->first("TEMPLATE") == "subdirs") {
|
} else if (project->first("TEMPLATE") == "subdirs") {
|
||||||
|
@ -93,18 +93,6 @@ bool MingwMakefileGenerator::writeMakefile(QTextStream &t)
|
|||||||
project->first("TEMPLATE") == "aux") {
|
project->first("TEMPLATE") == "aux") {
|
||||||
if(project->isActiveConfig("create_pc") && project->first("TEMPLATE") == "lib")
|
if(project->isActiveConfig("create_pc") && project->first("TEMPLATE") == "lib")
|
||||||
writePkgConfigFile();
|
writePkgConfigFile();
|
||||||
|
|
||||||
if(Option::mkfile::do_stub_makefile) {
|
|
||||||
t << "QMAKE = " << var("QMAKE_QMAKE") << Qt::endl;
|
|
||||||
const ProStringList &qut = project->values("QMAKE_EXTRA_TARGETS");
|
|
||||||
for (ProStringList::ConstIterator it = qut.begin(); it != qut.end(); ++it)
|
|
||||||
t << escapeDependencyPath(*it) << ' ';
|
|
||||||
t << "first all clean install distclean uninstall: qmake\n"
|
|
||||||
<< "qmake_all:\n";
|
|
||||||
writeMakeQmake(t);
|
|
||||||
t << "FORCE:\n\n";
|
|
||||||
return true;
|
|
||||||
}
|
|
||||||
writeMingwParts(t);
|
writeMingwParts(t);
|
||||||
return MakefileGenerator::writeMakefile(t);
|
return MakefileGenerator::writeMakefile(t);
|
||||||
}
|
}
|
||||||
@ -127,7 +115,7 @@ QString MingwMakefileGenerator::installRoot() const
|
|||||||
return QStringLiteral("$(INSTALL_ROOT:@msyshack@%=%)");
|
return QStringLiteral("$(INSTALL_ROOT:@msyshack@%=%)");
|
||||||
}
|
}
|
||||||
|
|
||||||
void createLdResponseFile(const QString &fileName, const ProStringList &objList)
|
static void createResponseFile(const QString &fileName, const ProStringList &objList)
|
||||||
{
|
{
|
||||||
QString filePath = Option::output_dir + QDir::separator() + fileName;
|
QString filePath = Option::output_dir + QDir::separator() + fileName;
|
||||||
QFile file(filePath);
|
QFile file(filePath);
|
||||||
@ -151,23 +139,6 @@ void createLdResponseFile(const QString &fileName, const ProStringList &objList)
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
void createArObjectScriptFile(const QString &fileName, const QString &target, const ProStringList &objList)
|
|
||||||
{
|
|
||||||
QString filePath = Option::output_dir + QDir::separator() + fileName;
|
|
||||||
QFile file(filePath);
|
|
||||||
if (file.open(QIODevice::WriteOnly | QIODevice::Text)) {
|
|
||||||
QTextStream t(&file);
|
|
||||||
// ### quoting?
|
|
||||||
t << "CREATE " << target << Qt::endl;
|
|
||||||
for (ProStringList::ConstIterator it = objList.constBegin(); it != objList.constEnd(); ++it) {
|
|
||||||
t << "ADDMOD " << *it << Qt::endl;
|
|
||||||
}
|
|
||||||
t << "SAVE\n";
|
|
||||||
t.flush();
|
|
||||||
file.close();
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
void MingwMakefileGenerator::writeMingwParts(QTextStream &t)
|
void MingwMakefileGenerator::writeMingwParts(QTextStream &t)
|
||||||
{
|
{
|
||||||
writeStandardParts(t);
|
writeStandardParts(t);
|
||||||
@ -294,26 +265,25 @@ void MingwMakefileGenerator::writeObjectsPart(QTextStream &t)
|
|||||||
if (objmax.isEmpty() || project->values("OBJECTS").count() < objmax.toInt()) {
|
if (objmax.isEmpty() || project->values("OBJECTS").count() < objmax.toInt()) {
|
||||||
objectsLinkLine = "$(OBJECTS)";
|
objectsLinkLine = "$(OBJECTS)";
|
||||||
} else if (project->isActiveConfig("staticlib") && project->first("TEMPLATE") == "lib") {
|
} else if (project->isActiveConfig("staticlib") && project->first("TEMPLATE") == "lib") {
|
||||||
QString ar_script_file = var("QMAKE_LINK_OBJECT_SCRIPT") + "." + var("TARGET");
|
QString ar_response_file = var("QMAKE_LINK_OBJECT_SCRIPT") + "." + var("TARGET");
|
||||||
if (!var("BUILD_NAME").isEmpty()) {
|
if (!var("BUILD_NAME").isEmpty()) {
|
||||||
ar_script_file += "." + var("BUILD_NAME");
|
ar_response_file += "." + var("BUILD_NAME");
|
||||||
}
|
}
|
||||||
if (!var("MAKEFILE").isEmpty())
|
if (!var("MAKEFILE").isEmpty())
|
||||||
ar_script_file += "." + var("MAKEFILE");
|
ar_response_file += "." + var("MAKEFILE");
|
||||||
// QMAKE_LIB is used for win32, including mingw, whereas QMAKE_AR is used on Unix.
|
// QMAKE_LIB is used for win32, including mingw, whereas QMAKE_AR is used on Unix.
|
||||||
// Strip off any options since the ar commands will be read from file.
|
QString ar_cmd = var("QMAKE_LIB");
|
||||||
QString ar_cmd = var("QMAKE_LIB").section(" ", 0, 0);
|
|
||||||
if (ar_cmd.isEmpty())
|
if (ar_cmd.isEmpty())
|
||||||
ar_cmd = "ar";
|
ar_cmd = "ar -rc";
|
||||||
createArObjectScriptFile(ar_script_file, var("DEST_TARGET"), project->values("OBJECTS"));
|
createResponseFile(ar_response_file, project->values("OBJECTS"));
|
||||||
objectsLinkLine = ar_cmd + " -M < " + escapeFilePath(ar_script_file);
|
objectsLinkLine = ar_cmd + ' ' + var("DEST_TARGET") + " @" + escapeFilePath(ar_response_file);
|
||||||
} else {
|
} else {
|
||||||
QString ld_response_file = var("QMAKE_LINK_OBJECT_SCRIPT") + "." + var("TARGET");
|
QString ld_response_file = var("QMAKE_LINK_OBJECT_SCRIPT") + "." + var("TARGET");
|
||||||
if (!var("BUILD_NAME").isEmpty())
|
if (!var("BUILD_NAME").isEmpty())
|
||||||
ld_response_file += "." + var("BUILD_NAME");
|
ld_response_file += "." + var("BUILD_NAME");
|
||||||
if (!var("MAKEFILE").isEmpty())
|
if (!var("MAKEFILE").isEmpty())
|
||||||
ld_response_file += "." + var("MAKEFILE");
|
ld_response_file += "." + var("MAKEFILE");
|
||||||
createLdResponseFile(ld_response_file, project->values("OBJECTS"));
|
createResponseFile(ld_response_file, project->values("OBJECTS"));
|
||||||
objectsLinkLine = "@" + escapeFilePath(ld_response_file);
|
objectsLinkLine = "@" + escapeFilePath(ld_response_file);
|
||||||
}
|
}
|
||||||
Win32MakefileGenerator::writeObjectsPart(t);
|
Win32MakefileGenerator::writeObjectsPart(t);
|
||||||
|
@ -48,10 +48,6 @@ NmakeMakefileGenerator::writeMakefile(QTextStream &t)
|
|||||||
if(project->first("TEMPLATE") == "app" ||
|
if(project->first("TEMPLATE") == "app" ||
|
||||||
project->first("TEMPLATE") == "lib" ||
|
project->first("TEMPLATE") == "lib" ||
|
||||||
project->first("TEMPLATE") == "aux") {
|
project->first("TEMPLATE") == "aux") {
|
||||||
#if 0
|
|
||||||
if(Option::mkfile::do_stub_makefile)
|
|
||||||
return MakefileGenerator::writeStubMakefile(t);
|
|
||||||
#endif
|
|
||||||
writeNmakeParts(t);
|
writeNmakeParts(t);
|
||||||
return MakefileGenerator::writeMakefile(t);
|
return MakefileGenerator::writeMakefile(t);
|
||||||
}
|
}
|
||||||
|
@ -238,7 +238,7 @@ ProString &ProString::append(const ProString &other, bool *pending)
|
|||||||
QChar *ptr;
|
QChar *ptr;
|
||||||
if (pending && !*pending) {
|
if (pending && !*pending) {
|
||||||
ptr = prepareExtend(1 + other.m_length, 0, m_length);
|
ptr = prepareExtend(1 + other.m_length, 0, m_length);
|
||||||
*ptr++ = 32;
|
*ptr++ = QLatin1Char(' ');
|
||||||
} else {
|
} else {
|
||||||
ptr = prepareExtend(other.m_length, 0, m_length);
|
ptr = prepareExtend(other.m_length, 0, m_length);
|
||||||
}
|
}
|
||||||
@ -276,7 +276,7 @@ ProString &ProString::append(const ProStringList &other, bool *pending, bool ski
|
|||||||
QChar *ptr = prepareExtend(totalLength, 0, m_length);
|
QChar *ptr = prepareExtend(totalLength, 0, m_length);
|
||||||
for (int i = startIdx; i < sz; ++i) {
|
for (int i = startIdx; i < sz; ++i) {
|
||||||
if (putSpace)
|
if (putSpace)
|
||||||
*ptr++ = 32;
|
*ptr++ = QLatin1Char(' ');
|
||||||
else
|
else
|
||||||
putSpace = true;
|
putSpace = true;
|
||||||
const ProString &str = other.at(i);
|
const ProString &str = other.at(i);
|
||||||
|
@ -68,6 +68,7 @@ class ProString {
|
|||||||
public:
|
public:
|
||||||
ProString();
|
ProString();
|
||||||
ProString(const ProString &other);
|
ProString(const ProString &other);
|
||||||
|
ProString &operator=(const ProString &) = default;
|
||||||
PROITEM_EXPLICIT ProString(const QString &str);
|
PROITEM_EXPLICIT ProString(const QString &str);
|
||||||
PROITEM_EXPLICIT ProString(const QStringRef &str);
|
PROITEM_EXPLICIT ProString(const QStringRef &str);
|
||||||
PROITEM_EXPLICIT ProString(const char *str);
|
PROITEM_EXPLICIT ProString(const char *str);
|
||||||
@ -432,10 +433,11 @@ public:
|
|||||||
ProFunctionDef(const ProFunctionDef &o) : m_pro(o.m_pro), m_offset(o.m_offset) { m_pro->ref(); }
|
ProFunctionDef(const ProFunctionDef &o) : m_pro(o.m_pro), m_offset(o.m_offset) { m_pro->ref(); }
|
||||||
ProFunctionDef(ProFunctionDef &&other) noexcept
|
ProFunctionDef(ProFunctionDef &&other) noexcept
|
||||||
: m_pro(other.m_pro), m_offset(other.m_offset) { other.m_pro = nullptr; }
|
: m_pro(other.m_pro), m_offset(other.m_offset) { other.m_pro = nullptr; }
|
||||||
~ProFunctionDef() { m_pro->deref(); }
|
~ProFunctionDef() { if (m_pro) m_pro->deref(); }
|
||||||
ProFunctionDef &operator=(const ProFunctionDef &o)
|
ProFunctionDef &operator=(const ProFunctionDef &o)
|
||||||
{
|
{
|
||||||
if (this != &o) {
|
if (this != &o) {
|
||||||
|
if (m_pro)
|
||||||
m_pro->deref();
|
m_pro->deref();
|
||||||
m_pro = o.m_pro;
|
m_pro = o.m_pro;
|
||||||
m_pro->ref();
|
m_pro->ref();
|
||||||
|
@ -1130,47 +1130,34 @@ bool QMakeEvaluator::prepareProject(const QString &inDir)
|
|||||||
}
|
}
|
||||||
superdir = qdfi.path();
|
superdir = qdfi.path();
|
||||||
}
|
}
|
||||||
|
QString sdir = inDir;
|
||||||
QString dir = m_outputDir;
|
QString dir = m_outputDir;
|
||||||
forever {
|
forever {
|
||||||
|
conffile = sdir + QLatin1String("/.qmake.conf");
|
||||||
|
if (!m_vfs->exists(conffile, flags))
|
||||||
|
conffile.clear();
|
||||||
cachefile = dir + QLatin1String("/.qmake.cache");
|
cachefile = dir + QLatin1String("/.qmake.cache");
|
||||||
if (!m_vfs->exists(cachefile, flags))
|
if (!m_vfs->exists(cachefile, flags))
|
||||||
cachefile.clear();
|
cachefile.clear();
|
||||||
if (!cachefile.isEmpty()) {
|
if (!conffile.isEmpty() || !cachefile.isEmpty()) {
|
||||||
|
if (dir != sdir)
|
||||||
|
m_sourceRoot = sdir;
|
||||||
m_buildRoot = dir;
|
m_buildRoot = dir;
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
if (dir == superdir)
|
if (dir == superdir)
|
||||||
goto no_cache;
|
goto no_cache;
|
||||||
QFileInfo qdfi(dir);
|
|
||||||
if (qdfi.isRoot()) {
|
|
||||||
cachefile.clear();
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
dir = qdfi.path();
|
|
||||||
}
|
|
||||||
QString sdir = inDir;
|
|
||||||
forever {
|
|
||||||
conffile = sdir + QLatin1String("/.qmake.conf");
|
|
||||||
if (!m_vfs->exists(conffile, flags))
|
|
||||||
conffile.clear();
|
|
||||||
if (!conffile.isEmpty()) {
|
|
||||||
if (sdir != m_buildRoot)
|
|
||||||
m_sourceRoot = sdir;
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
QFileInfo qsdfi(sdir);
|
QFileInfo qsdfi(sdir);
|
||||||
if (qsdfi.isRoot()) {
|
QFileInfo qdfi(dir);
|
||||||
conffile.clear();
|
if (qsdfi.isRoot() || qdfi.isRoot())
|
||||||
break;
|
goto no_cache;
|
||||||
}
|
|
||||||
sdir = qsdfi.path();
|
sdir = qsdfi.path();
|
||||||
|
dir = qdfi.path();
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
m_buildRoot = QFileInfo(cachefile).path();
|
m_buildRoot = QFileInfo(cachefile).path();
|
||||||
}
|
}
|
||||||
if (!conffile.isEmpty())
|
|
||||||
m_conffile = QDir::cleanPath(conffile);
|
m_conffile = QDir::cleanPath(conffile);
|
||||||
if (!cachefile.isEmpty())
|
|
||||||
m_cachefile = QDir::cleanPath(cachefile);
|
m_cachefile = QDir::cleanPath(cachefile);
|
||||||
}
|
}
|
||||||
no_cache:
|
no_cache:
|
||||||
@ -1583,8 +1570,8 @@ void QMakeEvaluator::updateFeaturePaths()
|
|||||||
}
|
}
|
||||||
|
|
||||||
for (int i = 0; i < feature_roots.count(); ++i)
|
for (int i = 0; i < feature_roots.count(); ++i)
|
||||||
if (!feature_roots.at(i).endsWith((ushort)'/'))
|
if (!feature_roots.at(i).endsWith(QLatin1Char('/')))
|
||||||
feature_roots[i].append((ushort)'/');
|
feature_roots[i].append(QLatin1Char('/'));
|
||||||
|
|
||||||
feature_roots.removeDuplicates();
|
feature_roots.removeDuplicates();
|
||||||
|
|
||||||
|
@ -621,7 +621,7 @@ void QMakeParser::read(ProFile *pro, const QStringRef &in, int line, SubGrammar
|
|||||||
if (c != term) {
|
if (c != term) {
|
||||||
parseError(fL1S("Missing %1 terminator [found %2]")
|
parseError(fL1S("Missing %1 terminator [found %2]")
|
||||||
.arg(QChar(term))
|
.arg(QChar(term))
|
||||||
.arg(c ? QString(c) : QString::fromLatin1("end-of-line")));
|
.arg(c ? QString(QChar(c)) : QString::fromLatin1("end-of-line")));
|
||||||
m_inError = true;
|
m_inError = true;
|
||||||
// Just parse on, as if there was a terminator ...
|
// Just parse on, as if there was a terminator ...
|
||||||
} else {
|
} else {
|
||||||
|
@ -111,7 +111,6 @@ private:
|
|||||||
|
|
||||||
struct BlockScope {
|
struct BlockScope {
|
||||||
BlockScope() : start(nullptr), braceLevel(0), special(false), inBranch(false), nest(NestNone) {}
|
BlockScope() : start(nullptr), braceLevel(0), special(false), inBranch(false), nest(NestNone) {}
|
||||||
BlockScope(const BlockScope &other) { *this = other; }
|
|
||||||
ushort *start; // Where this block started; store length here
|
ushort *start; // Where this block started; store length here
|
||||||
int braceLevel; // Nesting of braces in scope
|
int braceLevel; // Nesting of braces in scope
|
||||||
bool special; // Single-line conditionals inside loops, etc. cannot have else branches
|
bool special; // Single-line conditionals inside loops, etc. cannot have else branches
|
||||||
|
@ -93,7 +93,6 @@ bool Option::mkfile::do_deps = true;
|
|||||||
bool Option::mkfile::do_mocs = true;
|
bool Option::mkfile::do_mocs = true;
|
||||||
bool Option::mkfile::do_dep_heuristics = true;
|
bool Option::mkfile::do_dep_heuristics = true;
|
||||||
bool Option::mkfile::do_preprocess = false;
|
bool Option::mkfile::do_preprocess = false;
|
||||||
bool Option::mkfile::do_stub_makefile = false;
|
|
||||||
QStringList Option::mkfile::project_files;
|
QStringList Option::mkfile::project_files;
|
||||||
|
|
||||||
static Option::QMAKE_MODE default_mode(QString progname)
|
static Option::QMAKE_MODE default_mode(QString progname)
|
||||||
@ -254,8 +253,6 @@ Option::parseCommandLine(QStringList &args, QMakeCmdLineParserState &state)
|
|||||||
Option::mkfile::do_deps = false;
|
Option::mkfile::do_deps = false;
|
||||||
} else if (arg == "-nomoc") {
|
} else if (arg == "-nomoc") {
|
||||||
Option::mkfile::do_mocs = false;
|
Option::mkfile::do_mocs = false;
|
||||||
} else if (arg == "-createstub") {
|
|
||||||
Option::mkfile::do_stub_makefile = true;
|
|
||||||
} else if (arg == "-nodependheuristics") {
|
} else if (arg == "-nodependheuristics") {
|
||||||
Option::mkfile::do_dep_heuristics = false;
|
Option::mkfile::do_dep_heuristics = false;
|
||||||
} else if (arg == "-E") {
|
} else if (arg == "-E") {
|
||||||
|
@ -189,7 +189,6 @@ struct Option
|
|||||||
static bool do_mocs;
|
static bool do_mocs;
|
||||||
static bool do_dep_heuristics;
|
static bool do_dep_heuristics;
|
||||||
static bool do_preprocess;
|
static bool do_preprocess;
|
||||||
static bool do_stub_makefile;
|
|
||||||
static int cachefile_depth;
|
static int cachefile_depth;
|
||||||
static QStringList project_files;
|
static QStringList project_files;
|
||||||
};
|
};
|
||||||
|
@ -178,6 +178,9 @@ public class QtNative
|
|||||||
return fdDesc.detachFd();
|
return fdDesc.detachFd();
|
||||||
} catch (FileNotFoundException e) {
|
} catch (FileNotFoundException e) {
|
||||||
return -1;
|
return -1;
|
||||||
|
} catch (SecurityException e) {
|
||||||
|
Log.e(QtTAG, "Exception when opening file", e);
|
||||||
|
return -1;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -62,7 +62,7 @@ QByteArray QLatin1Codec::convertFromUnicode(const QChar *ch, int len, ConverterS
|
|||||||
char *d = r.data();
|
char *d = r.data();
|
||||||
int invalid = 0;
|
int invalid = 0;
|
||||||
for (int i = 0; i < len; ++i) {
|
for (int i = 0; i < len; ++i) {
|
||||||
if (ch[i] > 0xff) {
|
if (ch[i] > QChar(0xff)) {
|
||||||
d[i] = replacement;
|
d[i] = replacement;
|
||||||
++invalid;
|
++invalid;
|
||||||
} else {
|
} else {
|
||||||
@ -112,28 +112,28 @@ QString QLatin15Codec::convertToUnicode(const char* chars, int len, ConverterSta
|
|||||||
while(len--) {
|
while(len--) {
|
||||||
switch(uc->unicode()) {
|
switch(uc->unicode()) {
|
||||||
case 0xa4:
|
case 0xa4:
|
||||||
*uc = 0x20ac;
|
*uc = QChar(0x20ac);
|
||||||
break;
|
break;
|
||||||
case 0xa6:
|
case 0xa6:
|
||||||
*uc = 0x0160;
|
*uc = QChar(0x0160);
|
||||||
break;
|
break;
|
||||||
case 0xa8:
|
case 0xa8:
|
||||||
*uc = 0x0161;
|
*uc = QChar(0x0161);
|
||||||
break;
|
break;
|
||||||
case 0xb4:
|
case 0xb4:
|
||||||
*uc = 0x017d;
|
*uc = QChar(0x017d);
|
||||||
break;
|
break;
|
||||||
case 0xb8:
|
case 0xb8:
|
||||||
*uc = 0x017e;
|
*uc = QChar(0x017e);
|
||||||
break;
|
break;
|
||||||
case 0xbc:
|
case 0xbc:
|
||||||
*uc = 0x0152;
|
*uc = QChar(0x0152);
|
||||||
break;
|
break;
|
||||||
case 0xbd:
|
case 0xbd:
|
||||||
*uc = 0x0153;
|
*uc = QChar(0x0153);
|
||||||
break;
|
break;
|
||||||
case 0xbe:
|
case 0xbe:
|
||||||
*uc = 0x0178;
|
*uc = QChar(0x0178);
|
||||||
break;
|
break;
|
||||||
default:
|
default:
|
||||||
break;
|
break;
|
||||||
|
@ -544,11 +544,9 @@ QTextCodec *QTextCodec::codecForName(const QByteArray &name)
|
|||||||
#if !QT_CONFIG(icu)
|
#if !QT_CONFIG(icu)
|
||||||
QTextCodecCache *cache = &globalData->codecCache;
|
QTextCodecCache *cache = &globalData->codecCache;
|
||||||
QTextCodec *codec;
|
QTextCodec *codec;
|
||||||
if (cache) {
|
|
||||||
codec = cache->value(name);
|
codec = cache->value(name);
|
||||||
if (codec)
|
if (codec)
|
||||||
return codec;
|
return codec;
|
||||||
}
|
|
||||||
|
|
||||||
for (TextCodecListConstIt it = globalData->allCodecs.constBegin(), cend = globalData->allCodecs.constEnd(); it != cend; ++it) {
|
for (TextCodecListConstIt it = globalData->allCodecs.constBegin(), cend = globalData->allCodecs.constEnd(); it != cend; ++it) {
|
||||||
QTextCodec *cursor = *it;
|
QTextCodec *cursor = *it;
|
||||||
@ -560,7 +558,6 @@ QTextCodec *QTextCodec::codecForName(const QByteArray &name)
|
|||||||
QList<QByteArray> aliases = cursor->aliases();
|
QList<QByteArray> aliases = cursor->aliases();
|
||||||
for (ByteArrayListConstIt ait = aliases.constBegin(), acend = aliases.constEnd(); ait != acend; ++ait) {
|
for (ByteArrayListConstIt ait = aliases.constBegin(), acend = aliases.constEnd(); ait != acend; ++ait) {
|
||||||
if (qTextCodecNameMatch(*ait, name)) {
|
if (qTextCodecNameMatch(*ait, name)) {
|
||||||
if (cache)
|
|
||||||
cache->insert(name, cursor);
|
cache->insert(name, cursor);
|
||||||
return cursor;
|
return cursor;
|
||||||
}
|
}
|
||||||
|
@ -951,10 +951,10 @@ QString QUtf32::convertToUnicode(const char *chars, int len, QTextCodec::Convert
|
|||||||
}
|
}
|
||||||
uint code = (endian == BigEndianness) ? qFromBigEndian<quint32>(tuple) : qFromLittleEndian<quint32>(tuple);
|
uint code = (endian == BigEndianness) ? qFromBigEndian<quint32>(tuple) : qFromLittleEndian<quint32>(tuple);
|
||||||
if (QChar::requiresSurrogates(code)) {
|
if (QChar::requiresSurrogates(code)) {
|
||||||
*qch++ = QChar::highSurrogate(code);
|
*qch++ = QChar(QChar::highSurrogate(code));
|
||||||
*qch++ = QChar::lowSurrogate(code);
|
*qch++ = QChar(QChar::lowSurrogate(code));
|
||||||
} else {
|
} else {
|
||||||
*qch++ = code;
|
*qch++ = QChar(code);
|
||||||
}
|
}
|
||||||
num = 0;
|
num = 0;
|
||||||
}
|
}
|
||||||
|
@ -596,7 +596,7 @@
|
|||||||
"qDoubleSnprintf(argv[0], 1, invalidLocale, \"invalid format\", a);",
|
"qDoubleSnprintf(argv[0], 1, invalidLocale, \"invalid format\", a);",
|
||||||
"qDoubleSscanf(argv[0], invalidLocale, \"invalid format\", &a, &argc);"
|
"qDoubleSscanf(argv[0], invalidLocale, \"invalid format\", &a, &argc);"
|
||||||
],
|
],
|
||||||
"qmake": "DEFINES += QDSP_P_H=$$shell_quote(\\\"@PWD@/tools/qdoublescanprint_p.h\\\")"
|
"qmake": "DEFINES += QDSP_P_H=$$shell_quote(\\\"@PWD@/text/qdoublescanprint_p.h\\\")"
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
|
@ -36,6 +36,7 @@ qtConfig(animation): include(animation/animation.pri)
|
|||||||
include(global/global.pri)
|
include(global/global.pri)
|
||||||
include(thread/thread.pri)
|
include(thread/thread.pri)
|
||||||
include(tools/tools.pri)
|
include(tools/tools.pri)
|
||||||
|
include(text/text.pri)
|
||||||
include(time/time.pri)
|
include(time/time.pri)
|
||||||
include(io/io.pri)
|
include(io/io.pri)
|
||||||
include(itemmodels/itemmodels.pri)
|
include(itemmodels/itemmodels.pri)
|
||||||
|
@ -1,7 +1,7 @@
|
|||||||
/****************************************************************************
|
/****************************************************************************
|
||||||
**
|
**
|
||||||
** Copyright (C) 2016 The Qt Company Ltd.
|
** Copyright (C) 2019 The Qt Company Ltd.
|
||||||
** Copyright (C) 2016 Intel Corporation.
|
** Copyright (C) 2019 Intel Corporation.
|
||||||
** Contact: https://www.qt.io/licensing/
|
** Contact: https://www.qt.io/licensing/
|
||||||
**
|
**
|
||||||
** This file is part of the QtCore module of the Qt Toolkit.
|
** This file is part of the QtCore module of the Qt Toolkit.
|
||||||
@ -613,7 +613,8 @@ using qsizetype = QIntegerForSizeof<std::size_t>::Signed;
|
|||||||
# define Q_ALWAYS_INLINE inline
|
# define Q_ALWAYS_INLINE inline
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#if defined(Q_CC_GNU) && defined(Q_OS_WIN)
|
#if defined(Q_CC_GNU) && defined(Q_OS_WIN) && !defined(QT_NO_DATA_RELOCATION)
|
||||||
|
// ### Qt6: you can remove me
|
||||||
# define QT_INIT_METAOBJECT __attribute__((init_priority(101)))
|
# define QT_INIT_METAOBJECT __attribute__((init_priority(101)))
|
||||||
#else
|
#else
|
||||||
# define QT_INIT_METAOBJECT
|
# define QT_INIT_METAOBJECT
|
||||||
@ -1002,6 +1003,29 @@ QT_WARNING_DISABLE_MSVC(4530) /* C++ exception handler used, but unwind semantic
|
|||||||
# endif
|
# endif
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
// Work around MSVC warning about use of 3-arg algorithms
|
||||||
|
// until we can depend on the C++14 4-arg ones.
|
||||||
|
//
|
||||||
|
// These algortithms do NOT check for equal length.
|
||||||
|
// They need to be treated as if they called the 3-arg version (which they do)!
|
||||||
|
#ifdef Q_CC_MSVC
|
||||||
|
# define QT_3ARG_ALG(alg, f1, l1, f2, l2) \
|
||||||
|
std::alg(f1, l1, f2, l2)
|
||||||
|
#else
|
||||||
|
# define QT_3ARG_ALG(alg, f1, l1, f2, l2) \
|
||||||
|
[&f1, &l1, &f2, &l2]() { \
|
||||||
|
Q_UNUSED(l2); \
|
||||||
|
return std::alg(f1, l1, f2); \
|
||||||
|
}()
|
||||||
|
#endif
|
||||||
|
template <typename ForwardIterator1, typename ForwardIterator2>
|
||||||
|
inline bool qt_is_permutation(ForwardIterator1 first1, ForwardIterator1 last1,
|
||||||
|
ForwardIterator2 first2, ForwardIterator2 last2)
|
||||||
|
{
|
||||||
|
return QT_3ARG_ALG(is_permutation, first1, last1, first2, last2);
|
||||||
|
}
|
||||||
|
#undef QT_3ARG_ALG
|
||||||
|
|
||||||
// this adds const to non-const objects (like std::as_const)
|
// this adds const to non-const objects (like std::as_const)
|
||||||
template <typename T>
|
template <typename T>
|
||||||
Q_DECL_CONSTEXPR typename std::add_const<T>::type &qAsConst(T &t) noexcept { return t; }
|
Q_DECL_CONSTEXPR typename std::add_const<T>::type &qAsConst(T &t) noexcept { return t; }
|
||||||
|
@ -1,6 +1,7 @@
|
|||||||
/****************************************************************************
|
/****************************************************************************
|
||||||
**
|
**
|
||||||
** Copyright (C) 2016 The Qt Company Ltd.
|
** Copyright (C) 2019 The Qt Company Ltd.
|
||||||
|
** Copyright (C) 2019 Intel Corporation.
|
||||||
** Contact: https://www.qt.io/licensing/
|
** Contact: https://www.qt.io/licensing/
|
||||||
**
|
**
|
||||||
** This file is part of the QtCore module of the Qt Toolkit.
|
** This file is part of the QtCore module of the Qt Toolkit.
|
||||||
@ -180,6 +181,12 @@
|
|||||||
#if defined(Q_OS_WIN32) || defined(Q_OS_WIN64) || defined(Q_OS_WINRT)
|
#if defined(Q_OS_WIN32) || defined(Q_OS_WIN64) || defined(Q_OS_WINRT)
|
||||||
# define Q_OS_WINDOWS
|
# define Q_OS_WINDOWS
|
||||||
# define Q_OS_WIN
|
# define Q_OS_WIN
|
||||||
|
# if QT_VERSION >= QT_VERSION_CHECK(6, 0, 0)
|
||||||
|
// On Windows, pointers to dllimport'ed variables are not constant expressions,
|
||||||
|
// so to keep to certain initializations (like QMetaObject) constexpr, we need
|
||||||
|
// to use functions instead.
|
||||||
|
# define QT_NO_DATA_RELOCATION
|
||||||
|
# endif
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#if defined(Q_OS_WIN)
|
#if defined(Q_OS_WIN)
|
||||||
|
@ -55,6 +55,10 @@
|
|||||||
#include <stdlib.h>
|
#include <stdlib.h>
|
||||||
#include <qglobal.h>
|
#include <qglobal.h>
|
||||||
#ifdef Q_OS_WIN
|
#ifdef Q_OS_WIN
|
||||||
|
# ifdef Q_CC_MINGW
|
||||||
|
// <unistd.h> must be included before any other header pulls in <time.h>.
|
||||||
|
# include <unistd.h> // Define _POSIX_THREAD_SAFE_FUNCTIONS to obtain localtime_r()
|
||||||
|
# endif
|
||||||
# define _POSIX_
|
# define _POSIX_
|
||||||
# include <limits.h>
|
# include <limits.h>
|
||||||
# undef _POSIX_
|
# undef _POSIX_
|
||||||
|
@ -153,7 +153,7 @@ QDirPrivate::QDirPrivate(const QDirPrivate ©)
|
|||||||
|
|
||||||
bool QDirPrivate::exists() const
|
bool QDirPrivate::exists() const
|
||||||
{
|
{
|
||||||
if (fileEngine.isNull()) {
|
if (!fileEngine) {
|
||||||
QFileSystemEngine::fillMetaData(dirEntry, metaData,
|
QFileSystemEngine::fillMetaData(dirEntry, metaData,
|
||||||
QFileSystemMetaData::ExistsAttribute | QFileSystemMetaData::DirectoryType); // always stat
|
QFileSystemMetaData::ExistsAttribute | QFileSystemMetaData::DirectoryType); // always stat
|
||||||
return metaData.exists() && metaData.isDirectory();
|
return metaData.exists() && metaData.isDirectory();
|
||||||
@ -226,7 +226,7 @@ inline void QDirPrivate::resolveAbsoluteEntry() const
|
|||||||
return;
|
return;
|
||||||
|
|
||||||
QString absoluteName;
|
QString absoluteName;
|
||||||
if (fileEngine.isNull()) {
|
if (!fileEngine) {
|
||||||
if (!dirEntry.isRelative() && dirEntry.isClean()) {
|
if (!dirEntry.isRelative() && dirEntry.isClean()) {
|
||||||
absoluteDirEntry = dirEntry;
|
absoluteDirEntry = dirEntry;
|
||||||
return;
|
return;
|
||||||
@ -693,7 +693,7 @@ QString QDir::absolutePath() const
|
|||||||
QString QDir::canonicalPath() const
|
QString QDir::canonicalPath() const
|
||||||
{
|
{
|
||||||
const QDirPrivate* d = d_ptr.constData();
|
const QDirPrivate* d = d_ptr.constData();
|
||||||
if (d->fileEngine.isNull()) {
|
if (!d->fileEngine) {
|
||||||
QFileSystemEntry answer = QFileSystemEngine::canonicalName(d->dirEntry, d->metaData);
|
QFileSystemEntry answer = QFileSystemEngine::canonicalName(d->dirEntry, d->metaData);
|
||||||
return answer.filePath();
|
return answer.filePath();
|
||||||
}
|
}
|
||||||
@ -947,6 +947,12 @@ QString QDir::fromNativeSeparators(const QString &pathName)
|
|||||||
int i = pathName.indexOf(QLatin1Char('\\'));
|
int i = pathName.indexOf(QLatin1Char('\\'));
|
||||||
if (i != -1) {
|
if (i != -1) {
|
||||||
QString n(pathName);
|
QString n(pathName);
|
||||||
|
if (n.startsWith(QLatin1String("\\\\?\\"))) {
|
||||||
|
n.remove(0, 4);
|
||||||
|
i = n.indexOf(QLatin1Char('\\'));
|
||||||
|
if (i == -1)
|
||||||
|
return n;
|
||||||
|
}
|
||||||
|
|
||||||
QChar * const data = n.data();
|
QChar * const data = n.data();
|
||||||
data[i++] = QLatin1Char('/');
|
data[i++] = QLatin1Char('/');
|
||||||
@ -1496,7 +1502,7 @@ bool QDir::mkdir(const QString &dirName) const
|
|||||||
}
|
}
|
||||||
|
|
||||||
QString fn = filePath(dirName);
|
QString fn = filePath(dirName);
|
||||||
if (d->fileEngine.isNull())
|
if (!d->fileEngine)
|
||||||
return QFileSystemEngine::createDirectory(QFileSystemEntry(fn), false);
|
return QFileSystemEngine::createDirectory(QFileSystemEntry(fn), false);
|
||||||
return d->fileEngine->mkdir(fn, false);
|
return d->fileEngine->mkdir(fn, false);
|
||||||
}
|
}
|
||||||
@ -1520,7 +1526,7 @@ bool QDir::rmdir(const QString &dirName) const
|
|||||||
}
|
}
|
||||||
|
|
||||||
QString fn = filePath(dirName);
|
QString fn = filePath(dirName);
|
||||||
if (d->fileEngine.isNull())
|
if (!d->fileEngine)
|
||||||
return QFileSystemEngine::removeDirectory(QFileSystemEntry(fn), false);
|
return QFileSystemEngine::removeDirectory(QFileSystemEntry(fn), false);
|
||||||
|
|
||||||
return d->fileEngine->rmdir(fn, false);
|
return d->fileEngine->rmdir(fn, false);
|
||||||
@ -1548,7 +1554,7 @@ bool QDir::mkpath(const QString &dirPath) const
|
|||||||
}
|
}
|
||||||
|
|
||||||
QString fn = filePath(dirPath);
|
QString fn = filePath(dirPath);
|
||||||
if (d->fileEngine.isNull())
|
if (!d->fileEngine)
|
||||||
return QFileSystemEngine::createDirectory(QFileSystemEntry(fn), true);
|
return QFileSystemEngine::createDirectory(QFileSystemEntry(fn), true);
|
||||||
return d->fileEngine->mkdir(fn, true);
|
return d->fileEngine->mkdir(fn, true);
|
||||||
}
|
}
|
||||||
@ -1574,7 +1580,7 @@ bool QDir::rmpath(const QString &dirPath) const
|
|||||||
}
|
}
|
||||||
|
|
||||||
QString fn = filePath(dirPath);
|
QString fn = filePath(dirPath);
|
||||||
if (d->fileEngine.isNull())
|
if (!d->fileEngine)
|
||||||
return QFileSystemEngine::removeDirectory(QFileSystemEntry(fn), true);
|
return QFileSystemEngine::removeDirectory(QFileSystemEntry(fn), true);
|
||||||
return d->fileEngine->rmdir(fn, true);
|
return d->fileEngine->rmdir(fn, true);
|
||||||
}
|
}
|
||||||
@ -1647,7 +1653,7 @@ bool QDir::isReadable() const
|
|||||||
{
|
{
|
||||||
const QDirPrivate* d = d_ptr.constData();
|
const QDirPrivate* d = d_ptr.constData();
|
||||||
|
|
||||||
if (d->fileEngine.isNull()) {
|
if (!d->fileEngine) {
|
||||||
if (!d->metaData.hasFlags(QFileSystemMetaData::UserReadPermission))
|
if (!d->metaData.hasFlags(QFileSystemMetaData::UserReadPermission))
|
||||||
QFileSystemEngine::fillMetaData(d->dirEntry, d->metaData, QFileSystemMetaData::UserReadPermission);
|
QFileSystemEngine::fillMetaData(d->dirEntry, d->metaData, QFileSystemMetaData::UserReadPermission);
|
||||||
|
|
||||||
@ -1692,7 +1698,7 @@ bool QDir::exists() const
|
|||||||
*/
|
*/
|
||||||
bool QDir::isRoot() const
|
bool QDir::isRoot() const
|
||||||
{
|
{
|
||||||
if (d_ptr->fileEngine.isNull())
|
if (!d_ptr->fileEngine)
|
||||||
return d_ptr->dirEntry.isRoot();
|
return d_ptr->dirEntry.isRoot();
|
||||||
return d_ptr->fileEngine->fileFlags(QAbstractFileEngine::FlagsMask) & QAbstractFileEngine::RootFlag;
|
return d_ptr->fileEngine->fileFlags(QAbstractFileEngine::FlagsMask) & QAbstractFileEngine::RootFlag;
|
||||||
}
|
}
|
||||||
@ -1724,7 +1730,7 @@ bool QDir::isRoot() const
|
|||||||
*/
|
*/
|
||||||
bool QDir::isRelative() const
|
bool QDir::isRelative() const
|
||||||
{
|
{
|
||||||
if (d_ptr->fileEngine.isNull())
|
if (!d_ptr->fileEngine)
|
||||||
return d_ptr->dirEntry.isRelative();
|
return d_ptr->dirEntry.isRelative();
|
||||||
return d_ptr->fileEngine->isRelativePath();
|
return d_ptr->fileEngine->isRelativePath();
|
||||||
}
|
}
|
||||||
@ -1741,7 +1747,7 @@ bool QDir::makeAbsolute()
|
|||||||
{
|
{
|
||||||
const QDirPrivate *d = d_ptr.constData();
|
const QDirPrivate *d = d_ptr.constData();
|
||||||
QScopedPointer<QDirPrivate> dir;
|
QScopedPointer<QDirPrivate> dir;
|
||||||
if (!d->fileEngine.isNull()) {
|
if (!!d->fileEngine) {
|
||||||
QString absolutePath = d->fileEngine->fileName(QAbstractFileEngine::AbsoluteName);
|
QString absolutePath = d->fileEngine->fileName(QAbstractFileEngine::AbsoluteName);
|
||||||
if (QDir::isRelativePath(absolutePath))
|
if (QDir::isRelativePath(absolutePath))
|
||||||
return false;
|
return false;
|
||||||
@ -1774,8 +1780,8 @@ bool QDir::operator==(const QDir &dir) const
|
|||||||
if (d == other)
|
if (d == other)
|
||||||
return true;
|
return true;
|
||||||
Qt::CaseSensitivity sensitive;
|
Qt::CaseSensitivity sensitive;
|
||||||
if (d->fileEngine.isNull() || other->fileEngine.isNull()) {
|
if (!d->fileEngine || !other->fileEngine) {
|
||||||
if (d->fileEngine.data() != other->fileEngine.data()) // one is native, the other is a custom file-engine
|
if (d->fileEngine.get() != other->fileEngine.get()) // one is native, the other is a custom file-engine
|
||||||
return false;
|
return false;
|
||||||
|
|
||||||
sensitive = QFileSystemEngine::isCaseSensitive() ? Qt::CaseSensitive : Qt::CaseInsensitive;
|
sensitive = QFileSystemEngine::isCaseSensitive() ? Qt::CaseSensitive : Qt::CaseInsensitive;
|
||||||
@ -2339,6 +2345,11 @@ static QString qt_cleanPath(const QString &path, bool *ok)
|
|||||||
if (path.isEmpty())
|
if (path.isEmpty())
|
||||||
return path;
|
return path;
|
||||||
QString name = path;
|
QString name = path;
|
||||||
|
#if defined (Q_OS_WIN)
|
||||||
|
if (name.startsWith(QLatin1String("\\\\?\\")))
|
||||||
|
name.remove(0, 4);
|
||||||
|
#endif
|
||||||
|
|
||||||
QChar dir_separator = QDir::separator();
|
QChar dir_separator = QDir::separator();
|
||||||
if (dir_separator != QLatin1Char('/'))
|
if (dir_separator != QLatin1Char('/'))
|
||||||
name.replace(dir_separator, QLatin1Char('/'));
|
name.replace(dir_separator, QLatin1Char('/'));
|
||||||
|
@ -54,6 +54,8 @@
|
|||||||
#include "qfilesystementry_p.h"
|
#include "qfilesystementry_p.h"
|
||||||
#include "qfilesystemmetadata_p.h"
|
#include "qfilesystemmetadata_p.h"
|
||||||
|
|
||||||
|
#include <memory>
|
||||||
|
|
||||||
QT_BEGIN_NAMESPACE
|
QT_BEGIN_NAMESPACE
|
||||||
|
|
||||||
class QDirPrivate : public QSharedData
|
class QDirPrivate : public QSharedData
|
||||||
@ -82,7 +84,7 @@ public:
|
|||||||
|
|
||||||
static inline QChar getFilterSepChar(const QString &nameFilter);
|
static inline QChar getFilterSepChar(const QString &nameFilter);
|
||||||
|
|
||||||
static inline QStringList splitFilters(const QString &nameFilter, QChar sep = 0);
|
static inline QStringList splitFilters(const QString &nameFilter, QChar sep = {});
|
||||||
|
|
||||||
void setPath(const QString &path);
|
void setPath(const QString &path);
|
||||||
|
|
||||||
@ -98,7 +100,7 @@ public:
|
|||||||
QDir::SortFlags sort;
|
QDir::SortFlags sort;
|
||||||
QDir::Filters filters;
|
QDir::Filters filters;
|
||||||
|
|
||||||
QScopedPointer<QAbstractFileEngine> fileEngine;
|
std::unique_ptr<QAbstractFileEngine> fileEngine;
|
||||||
|
|
||||||
QFileSystemEntry dirEntry;
|
QFileSystemEntry dirEntry;
|
||||||
mutable QFileSystemEntry absoluteDirEntry;
|
mutable QFileSystemEntry absoluteDirEntry;
|
||||||
|
@ -107,6 +107,8 @@
|
|||||||
#include <QtCore/private/qfilesystemengine_p.h>
|
#include <QtCore/private/qfilesystemengine_p.h>
|
||||||
#include <QtCore/private/qfileinfo_p.h>
|
#include <QtCore/private/qfileinfo_p.h>
|
||||||
|
|
||||||
|
#include <memory>
|
||||||
|
|
||||||
QT_BEGIN_NAMESPACE
|
QT_BEGIN_NAMESPACE
|
||||||
|
|
||||||
template <class Iterator>
|
template <class Iterator>
|
||||||
@ -132,7 +134,7 @@ public:
|
|||||||
void checkAndPushDirectory(const QFileInfo &);
|
void checkAndPushDirectory(const QFileInfo &);
|
||||||
bool matchesFilters(const QString &fileName, const QFileInfo &fi) const;
|
bool matchesFilters(const QString &fileName, const QFileInfo &fi) const;
|
||||||
|
|
||||||
QScopedPointer<QAbstractFileEngine> engine;
|
std::unique_ptr<QAbstractFileEngine> engine;
|
||||||
|
|
||||||
QFileSystemEntry dirEntry;
|
QFileSystemEntry dirEntry;
|
||||||
const QStringList nameFilters;
|
const QStringList nameFilters;
|
||||||
@ -435,7 +437,7 @@ bool QDirIteratorPrivate::matchesFilters(const QString &fileName, const QFileInf
|
|||||||
QDirIterator::QDirIterator(const QDir &dir, IteratorFlags flags)
|
QDirIterator::QDirIterator(const QDir &dir, IteratorFlags flags)
|
||||||
{
|
{
|
||||||
const QDirPrivate *other = dir.d_ptr.constData();
|
const QDirPrivate *other = dir.d_ptr.constData();
|
||||||
d.reset(new QDirIteratorPrivate(other->dirEntry, other->nameFilters, other->filters, flags, !other->fileEngine.isNull()));
|
d.reset(new QDirIteratorPrivate(other->dirEntry, other->nameFilters, other->filters, flags, bool(other->fileEngine)));
|
||||||
}
|
}
|
||||||
|
|
||||||
/*!
|
/*!
|
||||||
|
@ -55,6 +55,8 @@
|
|||||||
# include "qcoreapplication.h"
|
# include "qcoreapplication.h"
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
#include <private/qmemory_p.h>
|
||||||
|
|
||||||
#ifdef QT_NO_QOBJECT
|
#ifdef QT_NO_QOBJECT
|
||||||
#define tr(X) QString::fromLatin1(X)
|
#define tr(X) QString::fromLatin1(X)
|
||||||
#endif
|
#endif
|
||||||
@ -85,10 +87,9 @@ QFilePrivate::openExternalFile(int flags, int fd, QFile::FileHandleFlags handleF
|
|||||||
Q_UNUSED(fd);
|
Q_UNUSED(fd);
|
||||||
return false;
|
return false;
|
||||||
#else
|
#else
|
||||||
delete fileEngine;
|
auto fs = qt_make_unique<QFSFileEngine>();
|
||||||
fileEngine = nullptr;
|
auto fe = fs.get();
|
||||||
QFSFileEngine *fe = new QFSFileEngine;
|
fileEngine = std::move(fs);
|
||||||
fileEngine = fe;
|
|
||||||
return fe->open(QIODevice::OpenMode(flags), fd, handleFlags);
|
return fe->open(QIODevice::OpenMode(flags), fd, handleFlags);
|
||||||
#endif
|
#endif
|
||||||
}
|
}
|
||||||
@ -101,10 +102,9 @@ QFilePrivate::openExternalFile(int flags, FILE *fh, QFile::FileHandleFlags handl
|
|||||||
Q_UNUSED(fh);
|
Q_UNUSED(fh);
|
||||||
return false;
|
return false;
|
||||||
#else
|
#else
|
||||||
delete fileEngine;
|
auto fs = qt_make_unique<QFSFileEngine>();
|
||||||
fileEngine = nullptr;
|
auto fe = fs.get();
|
||||||
QFSFileEngine *fe = new QFSFileEngine;
|
fileEngine = std::move(fs);
|
||||||
fileEngine = fe;
|
|
||||||
return fe->open(QIODevice::OpenMode(flags), fh, handleFlags);
|
return fe->open(QIODevice::OpenMode(flags), fh, handleFlags);
|
||||||
#endif
|
#endif
|
||||||
}
|
}
|
||||||
@ -112,8 +112,8 @@ QFilePrivate::openExternalFile(int flags, FILE *fh, QFile::FileHandleFlags handl
|
|||||||
QAbstractFileEngine *QFilePrivate::engine() const
|
QAbstractFileEngine *QFilePrivate::engine() const
|
||||||
{
|
{
|
||||||
if (!fileEngine)
|
if (!fileEngine)
|
||||||
fileEngine = QAbstractFileEngine::create(fileName);
|
fileEngine.reset(QAbstractFileEngine::create(fileName));
|
||||||
return fileEngine;
|
return fileEngine.get();
|
||||||
}
|
}
|
||||||
|
|
||||||
//************* QFile
|
//************* QFile
|
||||||
@ -334,10 +334,7 @@ QFile::setFileName(const QString &name)
|
|||||||
file_already_open(*this, "setFileName");
|
file_already_open(*this, "setFileName");
|
||||||
close();
|
close();
|
||||||
}
|
}
|
||||||
if(d->fileEngine) { //get a new file engine later
|
d->fileEngine.reset(); //get a new file engine later
|
||||||
delete d->fileEngine;
|
|
||||||
d->fileEngine = nullptr;
|
|
||||||
}
|
|
||||||
d->fileName = name;
|
d->fileName = name;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -42,6 +42,8 @@
|
|||||||
#include "qfiledevice_p.h"
|
#include "qfiledevice_p.h"
|
||||||
#include "qfsfileengine_p.h"
|
#include "qfsfileengine_p.h"
|
||||||
|
|
||||||
|
#include <private/qmemory_p.h>
|
||||||
|
|
||||||
#ifdef QT_NO_QOBJECT
|
#ifdef QT_NO_QOBJECT
|
||||||
#define tr(X) QString::fromLatin1(X)
|
#define tr(X) QString::fromLatin1(X)
|
||||||
#endif
|
#endif
|
||||||
@ -53,24 +55,20 @@ QT_BEGIN_NAMESPACE
|
|||||||
#endif
|
#endif
|
||||||
|
|
||||||
QFileDevicePrivate::QFileDevicePrivate()
|
QFileDevicePrivate::QFileDevicePrivate()
|
||||||
: fileEngine(nullptr),
|
: cachedSize(0),
|
||||||
cachedSize(0),
|
|
||||||
error(QFile::NoError), lastWasWrite(false)
|
error(QFile::NoError), lastWasWrite(false)
|
||||||
{
|
{
|
||||||
writeBufferChunkSize = QFILE_WRITEBUFFER_SIZE;
|
writeBufferChunkSize = QFILE_WRITEBUFFER_SIZE;
|
||||||
}
|
}
|
||||||
|
|
||||||
QFileDevicePrivate::~QFileDevicePrivate()
|
QFileDevicePrivate::~QFileDevicePrivate()
|
||||||
{
|
= default;
|
||||||
delete fileEngine;
|
|
||||||
fileEngine = nullptr;
|
|
||||||
}
|
|
||||||
|
|
||||||
QAbstractFileEngine * QFileDevicePrivate::engine() const
|
QAbstractFileEngine * QFileDevicePrivate::engine() const
|
||||||
{
|
{
|
||||||
if (!fileEngine)
|
if (!fileEngine)
|
||||||
fileEngine = new QFSFileEngine;
|
fileEngine = qt_make_unique<QFSFileEngine>();
|
||||||
return fileEngine;
|
return fileEngine.get();
|
||||||
}
|
}
|
||||||
|
|
||||||
void QFileDevicePrivate::setError(QFileDevice::FileError err)
|
void QFileDevicePrivate::setError(QFileDevice::FileError err)
|
||||||
|
@ -53,6 +53,8 @@
|
|||||||
|
|
||||||
#include "private/qiodevice_p.h"
|
#include "private/qiodevice_p.h"
|
||||||
|
|
||||||
|
#include <memory>
|
||||||
|
|
||||||
QT_BEGIN_NAMESPACE
|
QT_BEGIN_NAMESPACE
|
||||||
|
|
||||||
class QAbstractFileEngine;
|
class QAbstractFileEngine;
|
||||||
@ -75,7 +77,7 @@ protected:
|
|||||||
void setError(QFileDevice::FileError err, const QString &errorString);
|
void setError(QFileDevice::FileError err, const QString &errorString);
|
||||||
void setError(QFileDevice::FileError err, int errNum);
|
void setError(QFileDevice::FileError err, int errNum);
|
||||||
|
|
||||||
mutable QAbstractFileEngine *fileEngine;
|
mutable std::unique_ptr<QAbstractFileEngine> fileEngine;
|
||||||
mutable qint64 cachedSize;
|
mutable qint64 cachedSize;
|
||||||
|
|
||||||
QFileDevice::FileHandleFlags handleFlags;
|
QFileDevice::FileHandleFlags handleFlags;
|
||||||
|
@ -707,11 +707,11 @@ bool QFileInfo::exists(const QString &file)
|
|||||||
return false;
|
return false;
|
||||||
QFileSystemEntry entry(file);
|
QFileSystemEntry entry(file);
|
||||||
QFileSystemMetaData data;
|
QFileSystemMetaData data;
|
||||||
QAbstractFileEngine *engine =
|
std::unique_ptr<QAbstractFileEngine> engine
|
||||||
QFileSystemEngine::resolveEntryAndCreateLegacyEngine(entry, data);
|
{QFileSystemEngine::resolveEntryAndCreateLegacyEngine(entry, data)};
|
||||||
// Expensive fallback to non-QFileSystemEngine implementation
|
// Expensive fallback to non-QFileSystemEngine implementation
|
||||||
if (engine)
|
if (engine)
|
||||||
return QFileInfo(new QFileInfoPrivate(entry, data, engine)).exists();
|
return QFileInfo(new QFileInfoPrivate(entry, data, std::move(engine))).exists();
|
||||||
|
|
||||||
QFileSystemEngine::fillMetaData(entry, data, QFileSystemMetaData::ExistsAttribute);
|
QFileSystemEngine::fillMetaData(entry, data, QFileSystemMetaData::ExistsAttribute);
|
||||||
return data.exists();
|
return data.exists();
|
||||||
|
@ -61,6 +61,8 @@
|
|||||||
#include <QtCore/private/qfilesystementry_p.h>
|
#include <QtCore/private/qfilesystementry_p.h>
|
||||||
#include <QtCore/private/qfilesystemmetadata_p.h>
|
#include <QtCore/private/qfilesystemmetadata_p.h>
|
||||||
|
|
||||||
|
#include <memory>
|
||||||
|
|
||||||
QT_BEGIN_NAMESPACE
|
QT_BEGIN_NAMESPACE
|
||||||
|
|
||||||
class QFileInfoPrivate : public QSharedData
|
class QFileInfoPrivate : public QSharedData
|
||||||
@ -126,10 +128,10 @@ public:
|
|||||||
metaData = QFileSystemMetaData();
|
metaData = QFileSystemMetaData();
|
||||||
}
|
}
|
||||||
|
|
||||||
inline QFileInfoPrivate(const QFileSystemEntry &file, const QFileSystemMetaData &data, QAbstractFileEngine *engine)
|
inline QFileInfoPrivate(const QFileSystemEntry &file, const QFileSystemMetaData &data, std::unique_ptr<QAbstractFileEngine> engine)
|
||||||
: fileEntry(file),
|
: fileEntry(file),
|
||||||
metaData(data),
|
metaData(data),
|
||||||
fileEngine(engine),
|
fileEngine{std::move(engine)},
|
||||||
cachedFlags(0),
|
cachedFlags(0),
|
||||||
#ifndef QT_NO_FSFILEENGINE
|
#ifndef QT_NO_FSFILEENGINE
|
||||||
isDefaultConstructed(false),
|
isDefaultConstructed(false),
|
||||||
@ -163,7 +165,7 @@ public:
|
|||||||
QFileSystemEntry fileEntry;
|
QFileSystemEntry fileEntry;
|
||||||
mutable QFileSystemMetaData metaData;
|
mutable QFileSystemMetaData metaData;
|
||||||
|
|
||||||
QScopedPointer<QAbstractFileEngine> const fileEngine;
|
std::unique_ptr<QAbstractFileEngine> const fileEngine;
|
||||||
|
|
||||||
mutable QString fileNames[QAbstractFileEngine::NFileNames];
|
mutable QString fileNames[QAbstractFileEngine::NFileNames];
|
||||||
mutable QString fileOwners[2]; // QAbstractFileEngine::FileOwner: OwnerUser and OwnerGroup
|
mutable QString fileOwners[2]; // QAbstractFileEngine::FileOwner: OwnerUser and OwnerGroup
|
||||||
|
@ -822,6 +822,8 @@ QString QFileSystemEngine::resolveUserName(uint userId)
|
|||||||
#endif
|
#endif
|
||||||
if (pw)
|
if (pw)
|
||||||
return QFile::decodeName(QByteArray(pw->pw_name));
|
return QFile::decodeName(QByteArray(pw->pw_name));
|
||||||
|
#else // Integrity || WASM
|
||||||
|
Q_UNUSED(userId);
|
||||||
#endif
|
#endif
|
||||||
return QString();
|
return QString();
|
||||||
}
|
}
|
||||||
@ -859,6 +861,8 @@ QString QFileSystemEngine::resolveGroupName(uint groupId)
|
|||||||
#endif
|
#endif
|
||||||
if (gr)
|
if (gr)
|
||||||
return QFile::decodeName(QByteArray(gr->gr_name));
|
return QFile::decodeName(QByteArray(gr->gr_name));
|
||||||
|
#else // Integrity || WASM
|
||||||
|
Q_UNUSED(groupId);
|
||||||
#endif
|
#endif
|
||||||
return QString();
|
return QString();
|
||||||
}
|
}
|
||||||
|
@ -40,13 +40,54 @@
|
|||||||
#include "qplatformdefs.h"
|
#include "qplatformdefs.h"
|
||||||
#include "qfilesystemiterator_p.h"
|
#include "qfilesystemiterator_p.h"
|
||||||
|
|
||||||
|
#if QT_CONFIG(textcodec)
|
||||||
|
# include <qtextcodec.h>
|
||||||
|
# include <private/qutfcodec_p.h>
|
||||||
|
#endif
|
||||||
|
|
||||||
#ifndef QT_NO_FILESYSTEMITERATOR
|
#ifndef QT_NO_FILESYSTEMITERATOR
|
||||||
|
|
||||||
|
#include <memory>
|
||||||
|
|
||||||
#include <stdlib.h>
|
#include <stdlib.h>
|
||||||
#include <errno.h>
|
#include <errno.h>
|
||||||
|
|
||||||
QT_BEGIN_NAMESPACE
|
QT_BEGIN_NAMESPACE
|
||||||
|
|
||||||
|
static bool checkNameDecodable(const char *d_name, qsizetype len)
|
||||||
|
{
|
||||||
|
// This function is called in a loop from advance() below, but the loop is
|
||||||
|
// usually run only once.
|
||||||
|
|
||||||
|
#if QT_CONFIG(textcodec)
|
||||||
|
// We identify the codecs by their RFC 2978 MIBenum values. In this
|
||||||
|
// function:
|
||||||
|
// 3 US-ASCII (ANSI X3.4-1986)
|
||||||
|
// 4 Latin1 (ISO-8859-1)
|
||||||
|
// 106 UTF-8
|
||||||
|
QTextCodec *codec = QTextCodec::codecForLocale();
|
||||||
|
# ifdef QT_LOCALE_IS_UTF8
|
||||||
|
int mibEnum = 106;
|
||||||
|
# else
|
||||||
|
int mibEnum = codec->mibEnum();
|
||||||
|
# endif
|
||||||
|
if (Q_LIKELY(mibEnum == 106)) // UTF-8
|
||||||
|
return QUtf8::isValidUtf8(d_name, len).isValidUtf8;
|
||||||
|
if (mibEnum == 3) // US-ASCII
|
||||||
|
return QtPrivate::isAscii(QLatin1String(d_name, len));
|
||||||
|
if (mibEnum == 4) // Latin 1
|
||||||
|
return true;
|
||||||
|
|
||||||
|
// fall back to generic QTextCodec
|
||||||
|
QTextCodec::ConverterState cs(QTextCodec::IgnoreHeader);
|
||||||
|
codec->toUnicode(d_name, len, &cs);
|
||||||
|
return cs.invalidChars == 0 && cs.remainingChars == 0;
|
||||||
|
#else
|
||||||
|
// if we have no text codecs, then QString::fromLocal8Bit is fromLatin1
|
||||||
|
return true;
|
||||||
|
#endif
|
||||||
|
}
|
||||||
|
|
||||||
QFileSystemIterator::QFileSystemIterator(const QFileSystemEntry &entry, QDir::Filters filters,
|
QFileSystemIterator::QFileSystemIterator(const QFileSystemEntry &entry, QDir::Filters filters,
|
||||||
const QStringList &nameFilters, QDirIterator::IteratorFlags flags)
|
const QStringList &nameFilters, QDirIterator::IteratorFlags flags)
|
||||||
: nativePath(entry.nativeFilePath())
|
: nativePath(entry.nativeFilePath())
|
||||||
@ -81,9 +122,9 @@ bool QFileSystemIterator::advance(QFileSystemEntry &fileEntry, QFileSystemMetaDa
|
|||||||
dirEntry = QT_READDIR(dir);
|
dirEntry = QT_READDIR(dir);
|
||||||
|
|
||||||
if (dirEntry) {
|
if (dirEntry) {
|
||||||
// process entries with correct UTF-8 names only
|
qsizetype len = strlen(dirEntry->d_name);
|
||||||
if (QFile::encodeName(QFile::decodeName(dirEntry->d_name)) == dirEntry->d_name) {
|
if (checkNameDecodable(dirEntry->d_name, len)) {
|
||||||
fileEntry = QFileSystemEntry(nativePath + QByteArray(dirEntry->d_name), QFileSystemEntry::FromNativePath());
|
fileEntry = QFileSystemEntry(nativePath + QByteArray(dirEntry->d_name, len), QFileSystemEntry::FromNativePath());
|
||||||
metaData.fillFromDirEnt(*dirEntry);
|
metaData.fillFromDirEnt(*dirEntry);
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
@ -422,16 +422,27 @@ void QInotifyFileSystemWatcherEngine::readFromInotify()
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
template <typename Hash, typename Key>
|
||||||
|
typename Hash::const_iterator
|
||||||
|
find_last_in_equal_range(const Hash &c, const Key &key)
|
||||||
|
{
|
||||||
|
// find c.equal_range(key).second - 1 without backwards iteration:
|
||||||
|
auto i = c.find(key);
|
||||||
|
const auto end = c.cend();
|
||||||
|
if (i == end)
|
||||||
|
return end;
|
||||||
|
decltype(i) prev;
|
||||||
|
do {
|
||||||
|
prev = i;
|
||||||
|
++i;
|
||||||
|
} while (i != end && i.key() == key);
|
||||||
|
return prev;
|
||||||
|
}
|
||||||
|
|
||||||
QString QInotifyFileSystemWatcherEngine::getPathFromID(int id) const
|
QString QInotifyFileSystemWatcherEngine::getPathFromID(int id) const
|
||||||
{
|
{
|
||||||
QHash<int, QString>::const_iterator i = idToPath.find(id);
|
auto i = find_last_in_equal_range(idToPath, id);
|
||||||
while (i != idToPath.constEnd() && i.key() == id) {
|
return i == idToPath.cend() ? QString() : i.value() ;
|
||||||
if ((i + 1) == idToPath.constEnd() || (i + 1).key() != id) {
|
|
||||||
return i.value();
|
|
||||||
}
|
|
||||||
++i;
|
|
||||||
}
|
|
||||||
return QString();
|
|
||||||
}
|
}
|
||||||
|
|
||||||
QT_END_NAMESPACE
|
QT_END_NAMESPACE
|
||||||
|
@ -167,19 +167,21 @@ QFSFileEngine::QFSFileEngine(QFSFileEnginePrivate &dd)
|
|||||||
/*!
|
/*!
|
||||||
\internal
|
\internal
|
||||||
*/
|
*/
|
||||||
bool QFSFileEngine::processOpenModeFlags(QIODevice::OpenMode *mode)
|
ProcessOpenModeResult processOpenModeFlags(QIODevice::OpenMode openMode)
|
||||||
{
|
{
|
||||||
QIODevice::OpenMode &openMode = *mode;
|
ProcessOpenModeResult result;
|
||||||
|
result.ok = false;
|
||||||
if ((openMode & QFile::NewOnly) && (openMode & QFile::ExistingOnly)) {
|
if ((openMode & QFile::NewOnly) && (openMode & QFile::ExistingOnly)) {
|
||||||
qWarning("NewOnly and ExistingOnly are mutually exclusive");
|
qWarning("NewOnly and ExistingOnly are mutually exclusive");
|
||||||
setError(QFile::OpenError, QLatin1String("NewOnly and ExistingOnly are mutually exclusive"));
|
result.error = QLatin1String("NewOnly and ExistingOnly are mutually exclusive");
|
||||||
return false;
|
return result;
|
||||||
}
|
}
|
||||||
|
|
||||||
if ((openMode & QFile::ExistingOnly) && !(openMode & (QFile::ReadOnly | QFile::WriteOnly))) {
|
if ((openMode & QFile::ExistingOnly) && !(openMode & (QFile::ReadOnly | QFile::WriteOnly))) {
|
||||||
qWarning("ExistingOnly must be specified alongside ReadOnly, WriteOnly, or ReadWrite");
|
qWarning("ExistingOnly must be specified alongside ReadOnly, WriteOnly, or ReadWrite");
|
||||||
setError(QFile::OpenError, QLatin1String("ExistingOnly must be specified alongside ReadOnly, WriteOnly, or ReadWrite"));
|
result.error = QLatin1String(
|
||||||
return false;
|
"ExistingOnly must be specified alongside ReadOnly, WriteOnly, or ReadWrite");
|
||||||
|
return result;
|
||||||
}
|
}
|
||||||
|
|
||||||
// Either Append or NewOnly implies WriteOnly
|
// Either Append or NewOnly implies WriteOnly
|
||||||
@ -190,7 +192,9 @@ bool QFSFileEngine::processOpenModeFlags(QIODevice::OpenMode *mode)
|
|||||||
if ((openMode & QFile::WriteOnly) && !(openMode & (QFile::ReadOnly | QFile::Append | QFile::NewOnly)))
|
if ((openMode & QFile::WriteOnly) && !(openMode & (QFile::ReadOnly | QFile::Append | QFile::NewOnly)))
|
||||||
openMode |= QFile::Truncate;
|
openMode |= QFile::Truncate;
|
||||||
|
|
||||||
return true;
|
result.ok = true;
|
||||||
|
result.openMode = openMode;
|
||||||
|
return result;
|
||||||
}
|
}
|
||||||
|
|
||||||
/*!
|
/*!
|
||||||
@ -234,16 +238,19 @@ bool QFSFileEngine::open(QIODevice::OpenMode openMode)
|
|||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (!processOpenModeFlags(&openMode))
|
const ProcessOpenModeResult res = processOpenModeFlags(openMode);
|
||||||
|
if (!res.ok) {
|
||||||
|
setError(QFileDevice::OpenError, res.error);
|
||||||
return false;
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
d->openMode = openMode;
|
d->openMode = res.openMode;
|
||||||
d->lastFlushFailed = false;
|
d->lastFlushFailed = false;
|
||||||
d->tried_stat = 0;
|
d->tried_stat = 0;
|
||||||
d->fh = nullptr;
|
d->fh = nullptr;
|
||||||
d->fd = -1;
|
d->fd = -1;
|
||||||
|
|
||||||
return d->nativeOpen(openMode);
|
return d->nativeOpen(d->openMode);
|
||||||
}
|
}
|
||||||
|
|
||||||
/*!
|
/*!
|
||||||
@ -262,17 +269,20 @@ bool QFSFileEngine::open(QIODevice::OpenMode openMode, FILE *fh, QFile::FileHand
|
|||||||
|
|
||||||
Q_D(QFSFileEngine);
|
Q_D(QFSFileEngine);
|
||||||
|
|
||||||
if (!processOpenModeFlags(&openMode))
|
const ProcessOpenModeResult res = processOpenModeFlags(openMode);
|
||||||
|
if (!res.ok) {
|
||||||
|
setError(QFileDevice::OpenError, res.error);
|
||||||
return false;
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
d->openMode = openMode;
|
d->openMode = res.openMode;
|
||||||
d->lastFlushFailed = false;
|
d->lastFlushFailed = false;
|
||||||
d->closeFileHandle = (handleFlags & QFile::AutoCloseHandle);
|
d->closeFileHandle = (handleFlags & QFile::AutoCloseHandle);
|
||||||
d->fileEntry.clear();
|
d->fileEntry.clear();
|
||||||
d->tried_stat = 0;
|
d->tried_stat = 0;
|
||||||
d->fd = -1;
|
d->fd = -1;
|
||||||
|
|
||||||
return d->openFh(openMode, fh);
|
return d->openFh(d->openMode, fh);
|
||||||
}
|
}
|
||||||
|
|
||||||
/*!
|
/*!
|
||||||
@ -321,10 +331,13 @@ bool QFSFileEngine::open(QIODevice::OpenMode openMode, int fd, QFile::FileHandle
|
|||||||
{
|
{
|
||||||
Q_D(QFSFileEngine);
|
Q_D(QFSFileEngine);
|
||||||
|
|
||||||
if (!processOpenModeFlags(&openMode))
|
const ProcessOpenModeResult res = processOpenModeFlags(openMode);
|
||||||
|
if (!res.ok) {
|
||||||
|
setError(QFileDevice::OpenError, res.error);
|
||||||
return false;
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
d->openMode = openMode;
|
d->openMode = res.openMode;
|
||||||
d->lastFlushFailed = false;
|
d->lastFlushFailed = false;
|
||||||
d->closeFileHandle = (handleFlags & QFile::AutoCloseHandle);
|
d->closeFileHandle = (handleFlags & QFile::AutoCloseHandle);
|
||||||
d->fileEntry.clear();
|
d->fileEntry.clear();
|
||||||
@ -332,7 +345,7 @@ bool QFSFileEngine::open(QIODevice::OpenMode openMode, int fd, QFile::FileHandle
|
|||||||
d->fd = -1;
|
d->fd = -1;
|
||||||
d->tried_stat = 0;
|
d->tried_stat = 0;
|
||||||
|
|
||||||
return d->openFd(openMode, fd);
|
return d->openFd(d->openMode, fd);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
@ -61,6 +61,13 @@
|
|||||||
|
|
||||||
QT_BEGIN_NAMESPACE
|
QT_BEGIN_NAMESPACE
|
||||||
|
|
||||||
|
struct ProcessOpenModeResult {
|
||||||
|
bool ok;
|
||||||
|
QIODevice::OpenMode openMode;
|
||||||
|
QString error;
|
||||||
|
};
|
||||||
|
Q_CORE_EXPORT ProcessOpenModeResult processOpenModeFlags(QIODevice::OpenMode mode);
|
||||||
|
|
||||||
class QFSFileEnginePrivate;
|
class QFSFileEnginePrivate;
|
||||||
|
|
||||||
class Q_CORE_EXPORT QFSFileEngine : public QAbstractFileEngine
|
class Q_CORE_EXPORT QFSFileEngine : public QAbstractFileEngine
|
||||||
@ -131,9 +138,6 @@ public:
|
|||||||
|
|
||||||
protected:
|
protected:
|
||||||
QFSFileEngine(QFSFileEnginePrivate &dd);
|
QFSFileEngine(QFSFileEnginePrivate &dd);
|
||||||
|
|
||||||
private:
|
|
||||||
inline bool processOpenModeFlags(QIODevice::OpenMode *mode);
|
|
||||||
};
|
};
|
||||||
|
|
||||||
class Q_AUTOTEST_EXPORT QFSFileEnginePrivate : public QAbstractFileEnginePrivate
|
class Q_AUTOTEST_EXPORT QFSFileEnginePrivate : public QAbstractFileEnginePrivate
|
||||||
|
@ -312,7 +312,7 @@ void toString(QString &appendTo, const IPv6Address address)
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
const QChar colon = ushort(':');
|
const QChar colon = u':';
|
||||||
if (zeroRunLength < 4)
|
if (zeroRunLength < 4)
|
||||||
zeroRunOffset = -1;
|
zeroRunOffset = -1;
|
||||||
else if (zeroRunOffset == 0)
|
else if (zeroRunOffset == 0)
|
||||||
|
@ -202,6 +202,7 @@ void QProcessEnvironmentPrivate::insert(const QProcessEnvironmentPrivate &other)
|
|||||||
vars.insert(it.key(), it.value());
|
vars.insert(it.key(), it.value());
|
||||||
|
|
||||||
#ifdef Q_OS_UNIX
|
#ifdef Q_OS_UNIX
|
||||||
|
const OrderedNameMapMutexLocker locker(this, &other);
|
||||||
auto nit = other.nameMap.constBegin();
|
auto nit = other.nameMap.constBegin();
|
||||||
const auto nend = other.nameMap.constEnd();
|
const auto nend = other.nameMap.constEnd();
|
||||||
for ( ; nit != nend; ++nit)
|
for ( ; nit != nend; ++nit)
|
||||||
@ -275,7 +276,6 @@ bool QProcessEnvironment::operator==(const QProcessEnvironment &other) const
|
|||||||
return true;
|
return true;
|
||||||
if (d) {
|
if (d) {
|
||||||
if (other.d) {
|
if (other.d) {
|
||||||
QProcessEnvironmentPrivate::OrderedMutexLocker locker(d, other.d);
|
|
||||||
return d->vars == other.d->vars;
|
return d->vars == other.d->vars;
|
||||||
} else {
|
} else {
|
||||||
return isEmpty();
|
return isEmpty();
|
||||||
@ -322,7 +322,6 @@ bool QProcessEnvironment::contains(const QString &name) const
|
|||||||
{
|
{
|
||||||
if (!d)
|
if (!d)
|
||||||
return false;
|
return false;
|
||||||
QProcessEnvironmentPrivate::MutexLocker locker(d);
|
|
||||||
return d->vars.contains(d->prepareName(name));
|
return d->vars.contains(d->prepareName(name));
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -373,7 +372,6 @@ QString QProcessEnvironment::value(const QString &name, const QString &defaultVa
|
|||||||
if (!d)
|
if (!d)
|
||||||
return defaultValue;
|
return defaultValue;
|
||||||
|
|
||||||
QProcessEnvironmentPrivate::MutexLocker locker(d);
|
|
||||||
const auto it = d->vars.constFind(d->prepareName(name));
|
const auto it = d->vars.constFind(d->prepareName(name));
|
||||||
if (it == d->vars.constEnd())
|
if (it == d->vars.constEnd())
|
||||||
return defaultValue;
|
return defaultValue;
|
||||||
@ -398,7 +396,6 @@ QStringList QProcessEnvironment::toStringList() const
|
|||||||
{
|
{
|
||||||
if (!d)
|
if (!d)
|
||||||
return QStringList();
|
return QStringList();
|
||||||
QProcessEnvironmentPrivate::MutexLocker locker(d);
|
|
||||||
return d->toList();
|
return d->toList();
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -412,7 +409,6 @@ QStringList QProcessEnvironment::keys() const
|
|||||||
{
|
{
|
||||||
if (!d)
|
if (!d)
|
||||||
return QStringList();
|
return QStringList();
|
||||||
QProcessEnvironmentPrivate::MutexLocker locker(d);
|
|
||||||
return d->keys();
|
return d->keys();
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -429,7 +425,6 @@ void QProcessEnvironment::insert(const QProcessEnvironment &e)
|
|||||||
return;
|
return;
|
||||||
|
|
||||||
// our re-impl of detach() detaches from null
|
// our re-impl of detach() detaches from null
|
||||||
QProcessEnvironmentPrivate::MutexLocker locker(e.d);
|
|
||||||
d->insert(*e.d);
|
d->insert(*e.d);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -146,16 +146,22 @@ public:
|
|||||||
inline QString nameToString(const Key &name) const { return name; }
|
inline QString nameToString(const Key &name) const { return name; }
|
||||||
inline Value prepareValue(const QString &value) const { return value; }
|
inline Value prepareValue(const QString &value) const { return value; }
|
||||||
inline QString valueToString(const Value &value) const { return value; }
|
inline QString valueToString(const Value &value) const { return value; }
|
||||||
struct MutexLocker {
|
|
||||||
MutexLocker(const QProcessEnvironmentPrivate *) {}
|
|
||||||
};
|
|
||||||
struct OrderedMutexLocker {
|
|
||||||
OrderedMutexLocker(const QProcessEnvironmentPrivate *,
|
|
||||||
const QProcessEnvironmentPrivate *) {}
|
|
||||||
};
|
|
||||||
#else
|
#else
|
||||||
|
struct NameMapMutexLocker : public QMutexLocker
|
||||||
|
{
|
||||||
|
NameMapMutexLocker(const QProcessEnvironmentPrivate *d) : QMutexLocker(&d->nameMapMutex) {}
|
||||||
|
};
|
||||||
|
struct OrderedNameMapMutexLocker : public QOrderedMutexLocker
|
||||||
|
{
|
||||||
|
OrderedNameMapMutexLocker(const QProcessEnvironmentPrivate *d1,
|
||||||
|
const QProcessEnvironmentPrivate *d2)
|
||||||
|
: QOrderedMutexLocker(&d1->nameMapMutex, &d2->nameMapMutex)
|
||||||
|
{}
|
||||||
|
};
|
||||||
|
|
||||||
inline Key prepareName(const QString &name) const
|
inline Key prepareName(const QString &name) const
|
||||||
{
|
{
|
||||||
|
const NameMapMutexLocker locker(this);
|
||||||
Key &ent = nameMap[name];
|
Key &ent = nameMap[name];
|
||||||
if (ent.isEmpty())
|
if (ent.isEmpty())
|
||||||
ent = name.toLocal8Bit();
|
ent = name.toLocal8Bit();
|
||||||
@ -164,40 +170,27 @@ public:
|
|||||||
inline QString nameToString(const Key &name) const
|
inline QString nameToString(const Key &name) const
|
||||||
{
|
{
|
||||||
const QString sname = QString::fromLocal8Bit(name);
|
const QString sname = QString::fromLocal8Bit(name);
|
||||||
|
{
|
||||||
|
const NameMapMutexLocker locker(this);
|
||||||
nameMap[sname] = name;
|
nameMap[sname] = name;
|
||||||
|
}
|
||||||
return sname;
|
return sname;
|
||||||
}
|
}
|
||||||
inline Value prepareValue(const QString &value) const { return Value(value); }
|
inline Value prepareValue(const QString &value) const { return Value(value); }
|
||||||
inline QString valueToString(const Value &value) const { return value.string(); }
|
inline QString valueToString(const Value &value) const { return value.string(); }
|
||||||
|
|
||||||
struct MutexLocker : public QMutexLocker
|
|
||||||
{
|
|
||||||
MutexLocker(const QProcessEnvironmentPrivate *d) : QMutexLocker(&d->mutex) {}
|
|
||||||
};
|
|
||||||
struct OrderedMutexLocker : public QOrderedMutexLocker
|
|
||||||
{
|
|
||||||
OrderedMutexLocker(const QProcessEnvironmentPrivate *d1,
|
|
||||||
const QProcessEnvironmentPrivate *d2) :
|
|
||||||
QOrderedMutexLocker(&d1->mutex, &d2->mutex)
|
|
||||||
{}
|
|
||||||
};
|
|
||||||
|
|
||||||
QProcessEnvironmentPrivate() : QSharedData() {}
|
QProcessEnvironmentPrivate() : QSharedData() {}
|
||||||
QProcessEnvironmentPrivate(const QProcessEnvironmentPrivate &other) :
|
QProcessEnvironmentPrivate(const QProcessEnvironmentPrivate &other) :
|
||||||
QSharedData()
|
QSharedData(), vars(other.vars)
|
||||||
{
|
{
|
||||||
// This being locked ensures that the functions that only assign
|
|
||||||
// d pointers don't need explicit locking.
|
|
||||||
// We don't need to lock our own mutex, as this object is new and
|
// We don't need to lock our own mutex, as this object is new and
|
||||||
// consequently not shared. For the same reason, non-const methods
|
// consequently not shared. For the same reason, non-const methods
|
||||||
// do not need a lock, as they detach objects (however, we need to
|
// do not need a lock, as they detach objects (however, we need to
|
||||||
// ensure that they really detach before using prepareName()).
|
// ensure that they really detach before using prepareName()).
|
||||||
MutexLocker locker(&other);
|
NameMapMutexLocker locker(&other);
|
||||||
vars = other.vars;
|
|
||||||
nameMap = other.nameMap;
|
nameMap = other.nameMap;
|
||||||
// We need to detach our members, so that our mutex can protect them.
|
// We need to detach our nameMap, so that our mutex can protect it.
|
||||||
// As we are being detached, they likely would be detached a moment later anyway.
|
// As we are being detached, it likely would be detached a moment later anyway.
|
||||||
vars.detach();
|
|
||||||
nameMap.detach();
|
nameMap.detach();
|
||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
@ -208,8 +201,7 @@ public:
|
|||||||
#ifdef Q_OS_UNIX
|
#ifdef Q_OS_UNIX
|
||||||
typedef QHash<QString, Key> NameHash;
|
typedef QHash<QString, Key> NameHash;
|
||||||
mutable NameHash nameMap;
|
mutable NameHash nameMap;
|
||||||
|
mutable QMutex nameMapMutex;
|
||||||
mutable QMutex mutex;
|
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
static QProcessEnvironment fromList(const QStringList &list);
|
static QProcessEnvironment fromList(const QStringList &list);
|
||||||
|
@ -438,7 +438,6 @@ void QProcessPrivate::startProcess()
|
|||||||
int envc = 0;
|
int envc = 0;
|
||||||
char **envp = 0;
|
char **envp = 0;
|
||||||
if (environment.d.constData()) {
|
if (environment.d.constData()) {
|
||||||
QProcessEnvironmentPrivate::MutexLocker locker(environment.d);
|
|
||||||
envp = _q_dupEnvironment(environment.d.constData()->vars, &envc);
|
envp = _q_dupEnvironment(environment.d.constData()->vars, &envc);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -970,7 +969,6 @@ bool QProcessPrivate::startDetached(qint64 *pid)
|
|||||||
int envc = 0;
|
int envc = 0;
|
||||||
char **envp = nullptr;
|
char **envp = nullptr;
|
||||||
if (environment.d.constData()) {
|
if (environment.d.constData()) {
|
||||||
QProcessEnvironmentPrivate::MutexLocker locker(environment.d);
|
|
||||||
envp = _q_dupEnvironment(environment.d.constData()->vars, &envc);
|
envp = _q_dupEnvironment(environment.d.constData()->vars, &envc);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -1,7 +1,7 @@
|
|||||||
/****************************************************************************
|
/****************************************************************************
|
||||||
**
|
**
|
||||||
** Copyright (C) 2018 The Qt Company Ltd.
|
** Copyright (C) 2018 The Qt Company Ltd.
|
||||||
** Copyright (C) 2018 Intel Corporation.
|
** Copyright (C) 2019 Intel Corporation.
|
||||||
** Contact: https://www.qt.io/licensing/
|
** Contact: https://www.qt.io/licensing/
|
||||||
**
|
**
|
||||||
** This file is part of the QtCore module of the Qt Toolkit.
|
** This file is part of the QtCore module of the Qt Toolkit.
|
||||||
@ -279,14 +279,14 @@ static inline QStringList *resourceSearchPaths()
|
|||||||
This enum is used by compressionAlgorithm() to indicate which algorithm the
|
This enum is used by compressionAlgorithm() to indicate which algorithm the
|
||||||
RCC tool used to compress the payload.
|
RCC tool used to compress the payload.
|
||||||
|
|
||||||
\value NoCompression Contents are not compressed (isCompressed() is false).
|
\value NoCompression Contents are not compressed
|
||||||
\value ZlibCompression Contents are compressed using \l{zlib}{https://zlib.net} and can
|
\value ZlibCompression Contents are compressed using \l{zlib}{https://zlib.net} and can
|
||||||
be decompressed using the qUncompress() function.
|
be decompressed using the qUncompress() function.
|
||||||
\value ZstdCompression Contents are compressed using \l{zstd}{https://zstd.net}. To
|
\value ZstdCompression Contents are compressed using \l{zstd}{https://zstd.net}. To
|
||||||
decompress, use the \c{ZSTD_decompress} function from the zstd
|
decompress, use the \c{ZSTD_decompress} function from the zstd
|
||||||
library.
|
library.
|
||||||
|
|
||||||
\sa compressionAlgorithm(), isCompressed()
|
\sa compressionAlgorithm()
|
||||||
*/
|
*/
|
||||||
|
|
||||||
class QResourcePrivate {
|
class QResourcePrivate {
|
||||||
@ -551,13 +551,20 @@ bool QResource::isValid() const
|
|||||||
\sa isDir()
|
\sa isDir()
|
||||||
*/
|
*/
|
||||||
|
|
||||||
|
#if QT_DEPRECATED_SINCE(5, 13)
|
||||||
/*!
|
/*!
|
||||||
|
\obsolete
|
||||||
|
|
||||||
Returns \c true if the resource represents a file and the data backing it
|
Returns \c true if the resource represents a file and the data backing it
|
||||||
is in a compressed format, false otherwise. If the data is compressed,
|
is in a compressed format, false otherwise. If the data is compressed,
|
||||||
check compressionAlgorithm() to verify what algorithm to use to decompress
|
check compressionAlgorithm() to verify what algorithm to use to decompress
|
||||||
the data.
|
the data.
|
||||||
|
|
||||||
|
\note This function is deprecated and can be replaced with
|
||||||
|
\code
|
||||||
|
compressionAlgorithm() != NoCompression
|
||||||
|
\endcode
|
||||||
|
|
||||||
\sa data(), compressionAlgorithm(), isFile()
|
\sa data(), compressionAlgorithm(), isFile()
|
||||||
*/
|
*/
|
||||||
|
|
||||||
@ -565,6 +572,7 @@ bool QResource::isCompressed() const
|
|||||||
{
|
{
|
||||||
return compressionAlgorithm() != NoCompression;
|
return compressionAlgorithm() != NoCompression;
|
||||||
}
|
}
|
||||||
|
#endif
|
||||||
|
|
||||||
/*!
|
/*!
|
||||||
\since 5.13
|
\since 5.13
|
||||||
@ -582,7 +590,7 @@ bool QResource::isCompressed() const
|
|||||||
|
|
||||||
See \l{http://facebook.github.io/zstd/zstd_manual.html}{Zstandard manual}.
|
See \l{http://facebook.github.io/zstd/zstd_manual.html}{Zstandard manual}.
|
||||||
|
|
||||||
\sa isCompressed(), data(), isFile()
|
\sa data(), isFile()
|
||||||
*/
|
*/
|
||||||
QResource::Compression QResource::compressionAlgorithm() const
|
QResource::Compression QResource::compressionAlgorithm() const
|
||||||
{
|
{
|
||||||
@ -606,11 +614,11 @@ qint64 QResource::size() const
|
|||||||
|
|
||||||
/*!
|
/*!
|
||||||
Returns direct access to a read only segment of data that this resource
|
Returns direct access to a read only segment of data that this resource
|
||||||
represents. If the resource is compressed the data returns is
|
represents. If the resource is compressed the data returned is compressed
|
||||||
compressed and qUncompress() must be used to access the data. If the
|
and the appropriate library functions must be used to access the data. If
|
||||||
resource is a directory \nullptr is returned.
|
the resource is a directory \nullptr is returned.
|
||||||
|
|
||||||
\sa size(), isCompressed(), isFile()
|
\sa size(), compressionAlgorithm(), isFile()
|
||||||
*/
|
*/
|
||||||
|
|
||||||
const uchar *QResource::data() const
|
const uchar *QResource::data() const
|
||||||
@ -940,12 +948,15 @@ bool QResourceRoot::mappingRootSubdir(const QString &path, QString *match) const
|
|||||||
Q_CORE_EXPORT bool qRegisterResourceData(int version, const unsigned char *tree,
|
Q_CORE_EXPORT bool qRegisterResourceData(int version, const unsigned char *tree,
|
||||||
const unsigned char *name, const unsigned char *data)
|
const unsigned char *name, const unsigned char *data)
|
||||||
{
|
{
|
||||||
|
if (resourceGlobalData.isDestroyed())
|
||||||
|
return false;
|
||||||
QMutexLocker lock(resourceMutex());
|
QMutexLocker lock(resourceMutex());
|
||||||
if (version >= 0x01 && version <= 0x3 && resourceList()) {
|
ResourceList *list = resourceList();
|
||||||
|
if (version >= 0x01 && version <= 0x3) {
|
||||||
bool found = false;
|
bool found = false;
|
||||||
QResourceRoot res(version, tree, name, data);
|
QResourceRoot res(version, tree, name, data);
|
||||||
for(int i = 0; i < resourceList()->size(); ++i) {
|
for (int i = 0; i < list->size(); ++i) {
|
||||||
if(*resourceList()->at(i) == res) {
|
if (*list->at(i) == res) {
|
||||||
found = true;
|
found = true;
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
@ -953,7 +964,7 @@ Q_CORE_EXPORT bool qRegisterResourceData(int version, const unsigned char *tree,
|
|||||||
if(!found) {
|
if(!found) {
|
||||||
QResourceRoot *root = new QResourceRoot(version, tree, name, data);
|
QResourceRoot *root = new QResourceRoot(version, tree, name, data);
|
||||||
root->ref.ref();
|
root->ref.ref();
|
||||||
resourceList()->append(root);
|
list->append(root);
|
||||||
}
|
}
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
@ -967,11 +978,12 @@ Q_CORE_EXPORT bool qUnregisterResourceData(int version, const unsigned char *tre
|
|||||||
return false;
|
return false;
|
||||||
|
|
||||||
QMutexLocker lock(resourceMutex());
|
QMutexLocker lock(resourceMutex());
|
||||||
if (version >= 0x01 && version <= 0x3 && resourceList()) {
|
if (version >= 0x01 && version <= 0x3) {
|
||||||
QResourceRoot res(version, tree, name, data);
|
QResourceRoot res(version, tree, name, data);
|
||||||
for(int i = 0; i < resourceList()->size(); ) {
|
ResourceList *list = resourceList();
|
||||||
if(*resourceList()->at(i) == res) {
|
for (int i = 0; i < list->size(); ) {
|
||||||
QResourceRoot *root = resourceList()->takeAt(i);
|
if (*list->at(i) == res) {
|
||||||
|
QResourceRoot *root = list->takeAt(i);
|
||||||
if(!root->ref.deref())
|
if(!root->ref.deref())
|
||||||
delete root;
|
delete root;
|
||||||
} else {
|
} else {
|
||||||
@ -1217,7 +1229,7 @@ QResource::unregisterResource(const QString &rccFilename, const QString &resourc
|
|||||||
if(res->type() == QResourceRoot::Resource_File) {
|
if(res->type() == QResourceRoot::Resource_File) {
|
||||||
QDynamicFileResourceRoot *root = reinterpret_cast<QDynamicFileResourceRoot*>(res);
|
QDynamicFileResourceRoot *root = reinterpret_cast<QDynamicFileResourceRoot*>(res);
|
||||||
if (root->mappingFile() == rccFilename && root->mappingRoot() == r) {
|
if (root->mappingFile() == rccFilename && root->mappingRoot() == r) {
|
||||||
resourceList()->removeAt(i);
|
list->removeAt(i);
|
||||||
if(!root->ref.deref()) {
|
if(!root->ref.deref()) {
|
||||||
delete root;
|
delete root;
|
||||||
return true;
|
return true;
|
||||||
@ -1288,7 +1300,7 @@ QResource::unregisterResource(const uchar *rccData, const QString &resourceRoot)
|
|||||||
if(res->type() == QResourceRoot::Resource_Buffer) {
|
if(res->type() == QResourceRoot::Resource_Buffer) {
|
||||||
QDynamicBufferResourceRoot *root = reinterpret_cast<QDynamicBufferResourceRoot*>(res);
|
QDynamicBufferResourceRoot *root = reinterpret_cast<QDynamicBufferResourceRoot*>(res);
|
||||||
if (root->mappingBuffer() == rccData && root->mappingRoot() == r) {
|
if (root->mappingBuffer() == rccData && root->mappingRoot() == r) {
|
||||||
resourceList()->removeAt(i);
|
list->removeAt(i);
|
||||||
if(!root->ref.deref()) {
|
if(!root->ref.deref()) {
|
||||||
delete root;
|
delete root;
|
||||||
return true;
|
return true;
|
||||||
@ -1366,9 +1378,15 @@ bool QResourceFileEngine::open(QIODevice::OpenMode flags)
|
|||||||
qWarning("QResourceFileEngine::open: Missing file name");
|
qWarning("QResourceFileEngine::open: Missing file name");
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
if(flags & QIODevice::WriteOnly)
|
if (flags & QIODevice::WriteOnly)
|
||||||
return false;
|
return false;
|
||||||
|
if (d->resource.compressionAlgorithm() != QResource::NoCompression) {
|
||||||
d->uncompress();
|
d->uncompress();
|
||||||
|
if (d->uncompressed.isNull()) {
|
||||||
|
d->errorString = QSystemError::stdString(EIO);
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
}
|
||||||
if (!d->resource.isValid()) {
|
if (!d->resource.isValid()) {
|
||||||
d->errorString = QSystemError::stdString(ENOENT);
|
d->errorString = QSystemError::stdString(ENOENT);
|
||||||
return false;
|
return false;
|
||||||
@ -1395,7 +1413,7 @@ qint64 QResourceFileEngine::read(char *data, qint64 len)
|
|||||||
len = size()-d->offset;
|
len = size()-d->offset;
|
||||||
if(len <= 0)
|
if(len <= 0)
|
||||||
return 0;
|
return 0;
|
||||||
if(d->resource.isCompressed())
|
if (!d->uncompressed.isNull())
|
||||||
memcpy(data, d->uncompressed.constData()+d->offset, len);
|
memcpy(data, d->uncompressed.constData()+d->offset, len);
|
||||||
else
|
else
|
||||||
memcpy(data, d->resource.data()+d->offset, len);
|
memcpy(data, d->resource.data()+d->offset, len);
|
||||||
@ -1431,9 +1449,9 @@ bool QResourceFileEngine::link(const QString &)
|
|||||||
qint64 QResourceFileEngine::size() const
|
qint64 QResourceFileEngine::size() const
|
||||||
{
|
{
|
||||||
Q_D(const QResourceFileEngine);
|
Q_D(const QResourceFileEngine);
|
||||||
if(!d->resource.isValid())
|
if (!d->resource.isValid())
|
||||||
return 0;
|
return 0;
|
||||||
if (d->resource.isCompressed()) {
|
if (d->resource.compressionAlgorithm() != QResource::NoCompression) {
|
||||||
d->uncompress();
|
d->uncompress();
|
||||||
return d->uncompressed.size();
|
return d->uncompressed.size();
|
||||||
}
|
}
|
||||||
@ -1596,7 +1614,7 @@ uchar *QResourceFileEnginePrivate::map(qint64 offset, qint64 size, QFile::Memory
|
|||||||
Q_UNUSED(flags);
|
Q_UNUSED(flags);
|
||||||
|
|
||||||
qint64 max = resource.size();
|
qint64 max = resource.size();
|
||||||
if (resource.isCompressed()) {
|
if (resource.compressionAlgorithm() != QResource::NoCompression) {
|
||||||
uncompress();
|
uncompress();
|
||||||
max = uncompressed.size();
|
max = uncompressed.size();
|
||||||
}
|
}
|
||||||
@ -1609,7 +1627,7 @@ uchar *QResourceFileEnginePrivate::map(qint64 offset, qint64 size, QFile::Memory
|
|||||||
}
|
}
|
||||||
|
|
||||||
const uchar *address = resource.data();
|
const uchar *address = resource.data();
|
||||||
if (resource.isCompressed())
|
if (resource.compressionAlgorithm() != QResource::NoCompression)
|
||||||
address = reinterpret_cast<const uchar *>(uncompressed.constData());
|
address = reinterpret_cast<const uchar *>(uncompressed.constData());
|
||||||
|
|
||||||
return const_cast<uchar *>(address) + offset;
|
return const_cast<uchar *>(address) + offset;
|
||||||
|
@ -72,7 +72,6 @@ public:
|
|||||||
|
|
||||||
bool isValid() const;
|
bool isValid() const;
|
||||||
|
|
||||||
bool isCompressed() const;
|
|
||||||
Compression compressionAlgorithm() const;
|
Compression compressionAlgorithm() const;
|
||||||
qint64 size() const;
|
qint64 size() const;
|
||||||
const uchar *data() const;
|
const uchar *data() const;
|
||||||
@ -84,6 +83,10 @@ public:
|
|||||||
QT_DEPRECATED_X("Use QDir::searchPaths() instead")
|
QT_DEPRECATED_X("Use QDir::searchPaths() instead")
|
||||||
static QStringList searchPaths();
|
static QStringList searchPaths();
|
||||||
#endif
|
#endif
|
||||||
|
#if QT_DEPRECATED_SINCE(5, 15)
|
||||||
|
QT_DEPRECATED_VERSION_X_5_15("Use QResource::compressionAlgorithm() instead")
|
||||||
|
bool isCompressed() const;
|
||||||
|
#endif
|
||||||
|
|
||||||
static bool registerResource(const QString &rccFilename, const QString &resourceRoot=QString());
|
static bool registerResource(const QString &rccFilename, const QString &resourceRoot=QString());
|
||||||
static bool unregisterResource(const QString &rccFilename, const QString &resourceRoot=QString());
|
static bool unregisterResource(const QString &rccFilename, const QString &resourceRoot=QString());
|
||||||
|
@ -150,8 +150,7 @@ QSaveFile::~QSaveFile()
|
|||||||
QFileDevice::close();
|
QFileDevice::close();
|
||||||
if (d->fileEngine) {
|
if (d->fileEngine) {
|
||||||
d->fileEngine->remove();
|
d->fileEngine->remove();
|
||||||
delete d->fileEngine;
|
d->fileEngine.reset();
|
||||||
d->fileEngine = nullptr;
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -197,6 +196,7 @@ bool QSaveFile::open(OpenMode mode)
|
|||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
unsetError();
|
unsetError();
|
||||||
|
d->writeError = QFileDevice::NoError;
|
||||||
if ((mode & (ReadOnly | WriteOnly)) == 0) {
|
if ((mode & (ReadOnly | WriteOnly)) == 0) {
|
||||||
qWarning("QSaveFile::open: Open mode not specified");
|
qWarning("QSaveFile::open: Open mode not specified");
|
||||||
return false;
|
return false;
|
||||||
@ -234,7 +234,7 @@ bool QSaveFile::open(OpenMode mode)
|
|||||||
}
|
}
|
||||||
|
|
||||||
auto openDirectly = [&]() {
|
auto openDirectly = [&]() {
|
||||||
d->fileEngine = QAbstractFileEngine::create(d->finalFileName);
|
d->fileEngine.reset(QAbstractFileEngine::create(d->finalFileName));
|
||||||
if (d->fileEngine->open(mode | QIODevice::Unbuffered)) {
|
if (d->fileEngine->open(mode | QIODevice::Unbuffered)) {
|
||||||
d->useTemporaryFile = false;
|
d->useTemporaryFile = false;
|
||||||
QFileDevice::open(mode);
|
QFileDevice::open(mode);
|
||||||
@ -251,8 +251,7 @@ bool QSaveFile::open(OpenMode mode)
|
|||||||
if (openDirectly())
|
if (openDirectly())
|
||||||
return true;
|
return true;
|
||||||
d->setError(d->fileEngine->error(), d->fileEngine->errorString());
|
d->setError(d->fileEngine->error(), d->fileEngine->errorString());
|
||||||
delete d->fileEngine;
|
d->fileEngine.reset();
|
||||||
d->fileEngine = nullptr;
|
|
||||||
} else {
|
} else {
|
||||||
QString msg =
|
QString msg =
|
||||||
QSaveFile::tr("QSaveFile cannot open '%1' without direct write fallback "
|
QSaveFile::tr("QSaveFile cannot open '%1' without direct write fallback "
|
||||||
@ -264,18 +263,17 @@ bool QSaveFile::open(OpenMode mode)
|
|||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
d->fileEngine = new QTemporaryFileEngine(&d->finalFileName, QTemporaryFileEngine::Win32NonShared);
|
d->fileEngine.reset(new QTemporaryFileEngine(&d->finalFileName, QTemporaryFileEngine::Win32NonShared));
|
||||||
// if the target file exists, we'll copy its permissions below,
|
// if the target file exists, we'll copy its permissions below,
|
||||||
// but until then, let's ensure the temporary file is not accessible
|
// but until then, let's ensure the temporary file is not accessible
|
||||||
// to a third party
|
// to a third party
|
||||||
int perm = (existingFile.exists() ? 0600 : 0666);
|
int perm = (existingFile.exists() ? 0600 : 0666);
|
||||||
static_cast<QTemporaryFileEngine *>(d->fileEngine)->initialize(d->finalFileName, perm);
|
static_cast<QTemporaryFileEngine *>(d->fileEngine.get())->initialize(d->finalFileName, perm);
|
||||||
// Same as in QFile: QIODevice provides the buffering, so there's no need to request it from the file engine.
|
// Same as in QFile: QIODevice provides the buffering, so there's no need to request it from the file engine.
|
||||||
if (!d->fileEngine->open(mode | QIODevice::Unbuffered)) {
|
if (!d->fileEngine->open(mode | QIODevice::Unbuffered)) {
|
||||||
QFileDevice::FileError err = d->fileEngine->error();
|
QFileDevice::FileError err = d->fileEngine->error();
|
||||||
#ifdef Q_OS_UNIX
|
#ifdef Q_OS_UNIX
|
||||||
if (d->directWriteFallback && err == QFileDevice::OpenError && errno == EACCES) {
|
if (d->directWriteFallback && err == QFileDevice::OpenError && errno == EACCES) {
|
||||||
delete d->fileEngine;
|
|
||||||
if (openDirectly())
|
if (openDirectly())
|
||||||
return true;
|
return true;
|
||||||
err = d->fileEngine->error();
|
err = d->fileEngine->error();
|
||||||
@ -284,8 +282,7 @@ bool QSaveFile::open(OpenMode mode)
|
|||||||
if (err == QFileDevice::UnspecifiedError)
|
if (err == QFileDevice::UnspecifiedError)
|
||||||
err = QFileDevice::OpenError;
|
err = QFileDevice::OpenError;
|
||||||
d->setError(err, d->fileEngine->errorString());
|
d->setError(err, d->fileEngine->errorString());
|
||||||
delete d->fileEngine;
|
d->fileEngine.reset();
|
||||||
d->fileEngine = nullptr;
|
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -331,30 +328,26 @@ bool QSaveFile::commit()
|
|||||||
}
|
}
|
||||||
QFileDevice::close(); // calls flush()
|
QFileDevice::close(); // calls flush()
|
||||||
|
|
||||||
|
const auto fe = std::move(d->fileEngine);
|
||||||
|
|
||||||
// Sync to disk if possible. Ignore errors (e.g. not supported).
|
// Sync to disk if possible. Ignore errors (e.g. not supported).
|
||||||
d->fileEngine->syncToDisk();
|
fe->syncToDisk();
|
||||||
|
|
||||||
if (d->useTemporaryFile) {
|
if (d->useTemporaryFile) {
|
||||||
if (d->writeError != QFileDevice::NoError) {
|
if (d->writeError != QFileDevice::NoError) {
|
||||||
d->fileEngine->remove();
|
fe->remove();
|
||||||
d->writeError = QFileDevice::NoError;
|
d->writeError = QFileDevice::NoError;
|
||||||
delete d->fileEngine;
|
|
||||||
d->fileEngine = nullptr;
|
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
// atomically replace old file with new file
|
// atomically replace old file with new file
|
||||||
// Can't use QFile::rename for that, must use the file engine directly
|
// Can't use QFile::rename for that, must use the file engine directly
|
||||||
Q_ASSERT(d->fileEngine);
|
Q_ASSERT(fe);
|
||||||
if (!d->fileEngine->renameOverwrite(d->finalFileName)) {
|
if (!fe->renameOverwrite(d->finalFileName)) {
|
||||||
d->setError(d->fileEngine->error(), d->fileEngine->errorString());
|
d->setError(fe->error(), fe->errorString());
|
||||||
d->fileEngine->remove();
|
fe->remove();
|
||||||
delete d->fileEngine;
|
|
||||||
d->fileEngine = nullptr;
|
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
delete d->fileEngine;
|
|
||||||
d->fileEngine = nullptr;
|
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -297,7 +297,7 @@ QT_BEGIN_NAMESPACE
|
|||||||
\li "<APPROOT>/tmp"
|
\li "<APPROOT>/tmp"
|
||||||
\row \li HomeLocation
|
\row \li HomeLocation
|
||||||
\li "<APPROOT>/files"
|
\li "<APPROOT>/files"
|
||||||
\li "<APPROOT>" (not writable)
|
\li system defined
|
||||||
\row \li DataLocation
|
\row \li DataLocation
|
||||||
\li "<APPROOT>/files", "<USER>/<APPNAME>/files"
|
\li "<APPROOT>/files", "<USER>/<APPNAME>/files"
|
||||||
\li "<APPROOT>/Library/Application Support"
|
\li "<APPROOT>/Library/Application Support"
|
||||||
|
@ -71,6 +71,28 @@ static void appendOrganizationAndApp(QString &path)
|
|||||||
#endif
|
#endif
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#if QT_CONFIG(regularexpression)
|
||||||
|
static QLatin1String xdg_key_name(QStandardPaths::StandardLocation type)
|
||||||
|
{
|
||||||
|
switch (type) {
|
||||||
|
case QStandardPaths::DesktopLocation:
|
||||||
|
return QLatin1String("DESKTOP");
|
||||||
|
case QStandardPaths::DocumentsLocation:
|
||||||
|
return QLatin1String("DOCUMENTS");
|
||||||
|
case QStandardPaths::PicturesLocation:
|
||||||
|
return QLatin1String("PICTURES");
|
||||||
|
case QStandardPaths::MusicLocation:
|
||||||
|
return QLatin1String("MUSIC");
|
||||||
|
case QStandardPaths::MoviesLocation:
|
||||||
|
return QLatin1String("VIDEOS");
|
||||||
|
case QStandardPaths::DownloadLocation:
|
||||||
|
return QLatin1String("DOWNLOAD");
|
||||||
|
default:
|
||||||
|
return QLatin1String();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
|
||||||
QString QStandardPaths::writableLocation(StandardLocation type)
|
QString QStandardPaths::writableLocation(StandardLocation type)
|
||||||
{
|
{
|
||||||
switch (type) {
|
switch (type) {
|
||||||
@ -182,61 +204,32 @@ QString QStandardPaths::writableLocation(StandardLocation type)
|
|||||||
if (xdgConfigHome.isEmpty())
|
if (xdgConfigHome.isEmpty())
|
||||||
xdgConfigHome = QDir::homePath() + QLatin1String("/.config");
|
xdgConfigHome = QDir::homePath() + QLatin1String("/.config");
|
||||||
QFile file(xdgConfigHome + QLatin1String("/user-dirs.dirs"));
|
QFile file(xdgConfigHome + QLatin1String("/user-dirs.dirs"));
|
||||||
if (!isTestModeEnabled() && file.open(QIODevice::ReadOnly)) {
|
const QLatin1String key = xdg_key_name(type);
|
||||||
QHash<QString, QString> lines;
|
if (!key.isEmpty() && !isTestModeEnabled() && file.open(QIODevice::ReadOnly)) {
|
||||||
QTextStream stream(&file);
|
QTextStream stream(&file);
|
||||||
// Only look for lines like: XDG_DESKTOP_DIR="$HOME/Desktop"
|
// Only look for lines like: XDG_DESKTOP_DIR="$HOME/Desktop"
|
||||||
QRegularExpression exp(QLatin1String("^XDG_(.*)_DIR=(.*)$"));
|
QRegularExpression exp(QLatin1String("^XDG_(.*)_DIR=(.*)$"));
|
||||||
|
QString result;
|
||||||
while (!stream.atEnd()) {
|
while (!stream.atEnd()) {
|
||||||
const QString &line = stream.readLine();
|
const QString &line = stream.readLine();
|
||||||
QRegularExpressionMatch match = exp.match(line);
|
QRegularExpressionMatch match = exp.match(line);
|
||||||
if (match.hasMatch()) {
|
if (match.hasMatch() && match.capturedView(1) == key) {
|
||||||
const QStringList lst = match.capturedTexts();
|
QStringView value = match.capturedView(2);
|
||||||
const QString key = lst.at(1);
|
|
||||||
QString value = lst.at(2);
|
|
||||||
if (value.length() > 2
|
if (value.length() > 2
|
||||||
&& value.startsWith(QLatin1Char('\"'))
|
&& value.startsWith(QLatin1Char('\"'))
|
||||||
&& value.endsWith(QLatin1Char('\"')))
|
&& value.endsWith(QLatin1Char('\"')))
|
||||||
value = value.mid(1, value.length() - 2);
|
value = value.mid(1, value.length() - 2);
|
||||||
// Store the key and value: "DESKTOP", "$HOME/Desktop"
|
|
||||||
lines[key] = value;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
QString key;
|
|
||||||
switch (type) {
|
|
||||||
case DesktopLocation:
|
|
||||||
key = QLatin1String("DESKTOP");
|
|
||||||
break;
|
|
||||||
case DocumentsLocation:
|
|
||||||
key = QLatin1String("DOCUMENTS");
|
|
||||||
break;
|
|
||||||
case PicturesLocation:
|
|
||||||
key = QLatin1String("PICTURES");
|
|
||||||
break;
|
|
||||||
case MusicLocation:
|
|
||||||
key = QLatin1String("MUSIC");
|
|
||||||
break;
|
|
||||||
case MoviesLocation:
|
|
||||||
key = QLatin1String("VIDEOS");
|
|
||||||
break;
|
|
||||||
case DownloadLocation:
|
|
||||||
key = QLatin1String("DOWNLOAD");
|
|
||||||
break;
|
|
||||||
default:
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
if (!key.isEmpty()) {
|
|
||||||
QString value = lines.value(key);
|
|
||||||
if (!value.isEmpty()) {
|
|
||||||
// value can start with $HOME
|
// value can start with $HOME
|
||||||
if (value.startsWith(QLatin1String("$HOME")))
|
if (value.startsWith(QLatin1String("$HOME")))
|
||||||
value = QDir::homePath() + value.midRef(5);
|
result = QDir::homePath() + value.mid(5);
|
||||||
if (value.length() > 1 && value.endsWith(QLatin1Char('/')))
|
else
|
||||||
value.chop(1);
|
result = value.toString();
|
||||||
return value;
|
if (result.length() > 1 && result.endsWith(QLatin1Char('/')))
|
||||||
|
result.chop(1);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
if (!result.isNull())
|
||||||
|
return result;
|
||||||
}
|
}
|
||||||
#endif // QT_CONFIG(regularexpression)
|
#endif // QT_CONFIG(regularexpression)
|
||||||
|
|
||||||
|
@ -468,7 +468,17 @@ inline bool QStorageIterator::next()
|
|||||||
size_t len = strlen(buffer.data());
|
size_t len = strlen(buffer.data());
|
||||||
if (len == 0)
|
if (len == 0)
|
||||||
return false;
|
return false;
|
||||||
if (ptr[len - 1] == '\n')
|
while (Q_UNLIKELY(ptr[len - 1] != '\n' && !feof(fp))) {
|
||||||
|
// buffer wasn't large enough. Enlarge and try again.
|
||||||
|
// (we're readidng from the kernel, so OOM is unlikely)
|
||||||
|
buffer.resize((buffer.size() + 4096) & ~4095);
|
||||||
|
ptr = buffer.data();
|
||||||
|
if (fgets(ptr + len, buffer.size() - len, fp) == nullptr)
|
||||||
|
return false;
|
||||||
|
|
||||||
|
len += strlen(ptr + len);
|
||||||
|
Q_ASSERT(len < size_t(buffer.size()));
|
||||||
|
}
|
||||||
ptr[len - 1] = '\0';
|
ptr[len - 1] = '\0';
|
||||||
|
|
||||||
// parse the line
|
// parse the line
|
||||||
|
@ -544,10 +544,10 @@ QTemporaryFilePrivate::~QTemporaryFilePrivate()
|
|||||||
QAbstractFileEngine *QTemporaryFilePrivate::engine() const
|
QAbstractFileEngine *QTemporaryFilePrivate::engine() const
|
||||||
{
|
{
|
||||||
if (!fileEngine) {
|
if (!fileEngine) {
|
||||||
fileEngine = new QTemporaryFileEngine(&templateName);
|
fileEngine.reset(new QTemporaryFileEngine(&templateName));
|
||||||
resetFileEngine();
|
resetFileEngine();
|
||||||
}
|
}
|
||||||
return fileEngine;
|
return fileEngine.get();
|
||||||
}
|
}
|
||||||
|
|
||||||
void QTemporaryFilePrivate::resetFileEngine() const
|
void QTemporaryFilePrivate::resetFileEngine() const
|
||||||
@ -555,7 +555,7 @@ void QTemporaryFilePrivate::resetFileEngine() const
|
|||||||
if (!fileEngine)
|
if (!fileEngine)
|
||||||
return;
|
return;
|
||||||
|
|
||||||
QTemporaryFileEngine *tef = static_cast<QTemporaryFileEngine *>(fileEngine);
|
QTemporaryFileEngine *tef = static_cast<QTemporaryFileEngine *>(fileEngine.get());
|
||||||
if (fileName.isEmpty())
|
if (fileName.isEmpty())
|
||||||
tef->initialize(templateName, 0600);
|
tef->initialize(templateName, 0600);
|
||||||
else
|
else
|
||||||
@ -568,7 +568,7 @@ void QTemporaryFilePrivate::materializeUnnamedFile()
|
|||||||
if (!fileName.isEmpty() || !fileEngine)
|
if (!fileName.isEmpty() || !fileEngine)
|
||||||
return;
|
return;
|
||||||
|
|
||||||
auto *tef = static_cast<QTemporaryFileEngine *>(fileEngine);
|
auto *tef = static_cast<QTemporaryFileEngine *>(fileEngine.get());
|
||||||
fileName = tef->fileName(QAbstractFileEngine::DefaultName);
|
fileName = tef->fileName(QAbstractFileEngine::DefaultName);
|
||||||
#endif
|
#endif
|
||||||
}
|
}
|
||||||
@ -792,7 +792,7 @@ void QTemporaryFile::setAutoRemove(bool b)
|
|||||||
QString QTemporaryFile::fileName() const
|
QString QTemporaryFile::fileName() const
|
||||||
{
|
{
|
||||||
Q_D(const QTemporaryFile);
|
Q_D(const QTemporaryFile);
|
||||||
auto tef = static_cast<QTemporaryFileEngine *>(d->fileEngine);
|
auto tef = static_cast<QTemporaryFileEngine *>(d->fileEngine.get());
|
||||||
if (tef && tef->isReallyOpen())
|
if (tef && tef->isReallyOpen())
|
||||||
const_cast<QTemporaryFilePrivate *>(d)->materializeUnnamedFile();
|
const_cast<QTemporaryFilePrivate *>(d)->materializeUnnamedFile();
|
||||||
|
|
||||||
@ -841,7 +841,7 @@ void QTemporaryFile::setFileTemplate(const QString &name)
|
|||||||
bool QTemporaryFile::rename(const QString &newName)
|
bool QTemporaryFile::rename(const QString &newName)
|
||||||
{
|
{
|
||||||
Q_D(QTemporaryFile);
|
Q_D(QTemporaryFile);
|
||||||
auto tef = static_cast<QTemporaryFileEngine *>(d->fileEngine);
|
auto tef = static_cast<QTemporaryFileEngine *>(d->fileEngine.get());
|
||||||
if (!tef || !tef->isReallyOpen() || !tef->filePathWasTemplate)
|
if (!tef || !tef->isReallyOpen() || !tef->filePathWasTemplate)
|
||||||
return QFile::rename(newName);
|
return QFile::rename(newName);
|
||||||
|
|
||||||
@ -947,7 +947,7 @@ QTemporaryFile *QTemporaryFile::createNativeFile(QFile &file)
|
|||||||
bool QTemporaryFile::open(OpenMode flags)
|
bool QTemporaryFile::open(OpenMode flags)
|
||||||
{
|
{
|
||||||
Q_D(QTemporaryFile);
|
Q_D(QTemporaryFile);
|
||||||
auto tef = static_cast<QTemporaryFileEngine *>(d->fileEngine);
|
auto tef = static_cast<QTemporaryFileEngine *>(d->fileEngine.get());
|
||||||
if (tef && tef->isReallyOpen()) {
|
if (tef && tef->isReallyOpen()) {
|
||||||
setOpenMode(flags);
|
setOpenMode(flags);
|
||||||
return true;
|
return true;
|
||||||
@ -961,7 +961,7 @@ bool QTemporaryFile::open(OpenMode flags)
|
|||||||
d->resetFileEngine();
|
d->resetFileEngine();
|
||||||
|
|
||||||
if (QFile::open(flags)) {
|
if (QFile::open(flags)) {
|
||||||
tef = static_cast<QTemporaryFileEngine *>(d->fileEngine);
|
tef = static_cast<QTemporaryFileEngine *>(d->fileEngine.get());
|
||||||
if (tef->isUnnamedFile())
|
if (tef->isUnnamedFile())
|
||||||
d->fileName.clear();
|
d->fileName.clear();
|
||||||
else
|
else
|
||||||
|
@ -59,9 +59,9 @@ enum TLDMatchType {
|
|||||||
static bool containsTLDEntry(QStringView entry, TLDMatchType match)
|
static bool containsTLDEntry(QStringView entry, TLDMatchType match)
|
||||||
{
|
{
|
||||||
const QStringView matchSymbols[] = {
|
const QStringView matchSymbols[] = {
|
||||||
QStringViewLiteral(""),
|
u"",
|
||||||
QStringViewLiteral("*"),
|
u"*",
|
||||||
QStringViewLiteral("!"),
|
u"!",
|
||||||
};
|
};
|
||||||
const auto symbol = matchSymbols[match];
|
const auto symbol = matchSymbols[match];
|
||||||
int index = qt_hash(entry, qt_hash(symbol)) % tldCount;
|
int index = qt_hash(entry, qt_hash(symbol)) % tldCount;
|
||||||
|
@ -1010,7 +1010,7 @@ inline bool QUrlPrivate::setScheme(const QString &value, int len, bool doSetErro
|
|||||||
for (int i = needsLowercasing; i >= 0; --i) {
|
for (int i = needsLowercasing; i >= 0; --i) {
|
||||||
ushort c = schemeData[i].unicode();
|
ushort c = schemeData[i].unicode();
|
||||||
if (c >= 'A' && c <= 'Z')
|
if (c >= 'A' && c <= 'Z')
|
||||||
schemeData[i] = c + 0x20;
|
schemeData[i] = QChar(c + 0x20);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -2220,9 +2220,8 @@ Q_AUTOTEST_EXPORT void qt_punycodeEncoder(const QChar *s, int ucLength, QString
|
|||||||
bool skipped = false;
|
bool skipped = false;
|
||||||
// copy all basic code points verbatim to output.
|
// copy all basic code points verbatim to output.
|
||||||
for (uint j = 0; j < (uint) ucLength; ++j) {
|
for (uint j = 0; j < (uint) ucLength; ++j) {
|
||||||
ushort js = s[j].unicode();
|
if (s[j].unicode() < 0x80)
|
||||||
if (js < 0x80)
|
*d++ = s[j];
|
||||||
*d++ = js;
|
|
||||||
else
|
else
|
||||||
skipped = true;
|
skipped = true;
|
||||||
}
|
}
|
||||||
|
@ -146,7 +146,7 @@ QT_BEGIN_NAMESPACE
|
|||||||
*/
|
*/
|
||||||
|
|
||||||
/*!
|
/*!
|
||||||
\fn QUrlQuery(std::initializer_list<QPair<QString, QString>> list)
|
\fn QUrlQuery::QUrlQuery(std::initializer_list<QPair<QString, QString>> list)
|
||||||
|
|
||||||
\since 5.13
|
\since 5.13
|
||||||
|
|
||||||
@ -293,9 +293,9 @@ void QUrlQueryPrivate::setQuery(const QString &query)
|
|||||||
const QChar *delimiter = nullptr;
|
const QChar *delimiter = nullptr;
|
||||||
while (pos != end) {
|
while (pos != end) {
|
||||||
// scan for the component parts of this pair
|
// scan for the component parts of this pair
|
||||||
if (!delimiter && pos->unicode() == valueDelimiter)
|
if (!delimiter && *pos == valueDelimiter)
|
||||||
delimiter = pos;
|
delimiter = pos;
|
||||||
if (pos->unicode() == pairDelimiter)
|
if (*pos == pairDelimiter)
|
||||||
break;
|
break;
|
||||||
++pos;
|
++pos;
|
||||||
}
|
}
|
||||||
@ -584,8 +584,8 @@ QString QUrlQuery::query(QUrl::ComponentFormattingOptions encoding) const
|
|||||||
*/
|
*/
|
||||||
void QUrlQuery::setQueryDelimiters(QChar valueDelimiter, QChar pairDelimiter)
|
void QUrlQuery::setQueryDelimiters(QChar valueDelimiter, QChar pairDelimiter)
|
||||||
{
|
{
|
||||||
d->valueDelimiter = valueDelimiter.unicode();
|
d->valueDelimiter = valueDelimiter;
|
||||||
d->pairDelimiter = pairDelimiter.unicode();
|
d->pairDelimiter = pairDelimiter;
|
||||||
}
|
}
|
||||||
|
|
||||||
/*!
|
/*!
|
||||||
|
@ -532,21 +532,16 @@ void QAbstractItemModelPrivate::invalidatePersistentIndex(const QModelIndex &ind
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
namespace {
|
using DefaultRoleNames = QHash<int, QByteArray>;
|
||||||
struct DefaultRoleNames : public QHash<int, QByteArray>
|
Q_GLOBAL_STATIC_WITH_ARGS(DefaultRoleNames, qDefaultRoleNames, (
|
||||||
{
|
{
|
||||||
DefaultRoleNames() {
|
{ Qt::DisplayRole, "display" },
|
||||||
(*this)[Qt::DisplayRole] = "display";
|
{ Qt::DecorationRole, "decoration" },
|
||||||
(*this)[Qt::DecorationRole] = "decoration";
|
{ Qt::EditRole, "edit" },
|
||||||
(*this)[Qt::EditRole] = "edit";
|
{ Qt::ToolTipRole, "toolTip" },
|
||||||
(*this)[Qt::ToolTipRole] = "toolTip";
|
{ Qt::StatusTipRole, "statusTip" },
|
||||||
(*this)[Qt::StatusTipRole] = "statusTip";
|
{ Qt::WhatsThisRole, "whatsThis" },
|
||||||
(*this)[Qt::WhatsThisRole] = "whatsThis";
|
}))
|
||||||
}
|
|
||||||
};
|
|
||||||
}
|
|
||||||
|
|
||||||
Q_GLOBAL_STATIC(DefaultRoleNames, qDefaultRoleNames)
|
|
||||||
|
|
||||||
const QHash<int,QByteArray> &QAbstractItemModelPrivate::defaultRoleNames()
|
const QHash<int,QByteArray> &QAbstractItemModelPrivate::defaultRoleNames()
|
||||||
{
|
{
|
||||||
|
@ -64,11 +64,7 @@ struct QSortFilterProxyModelDataChanged
|
|||||||
|
|
||||||
static inline QSet<int> qVectorToSet(const QVector<int> &vector)
|
static inline QSet<int> qVectorToSet(const QVector<int> &vector)
|
||||||
{
|
{
|
||||||
QSet<int> set;
|
return {vector.begin(), vector.end()};
|
||||||
set.reserve(vector.size());
|
|
||||||
for(int i=0; i < vector.size(); ++i)
|
|
||||||
set << vector.at(i);
|
|
||||||
return set;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
class QSortFilterProxyModelLessThan
|
class QSortFilterProxyModelLessThan
|
||||||
@ -130,7 +126,7 @@ struct QRowsRemoval
|
|||||||
{
|
{
|
||||||
}
|
}
|
||||||
|
|
||||||
bool contains(QModelIndex parent, int row)
|
bool contains(QModelIndex parent, int row) const
|
||||||
{
|
{
|
||||||
do {
|
do {
|
||||||
if (parent == parent_source)
|
if (parent == parent_source)
|
||||||
@ -470,8 +466,8 @@ bool QSortFilterProxyModelPrivate::filterRecursiveAcceptsRow(int source_row, con
|
|||||||
void QSortFilterProxyModelPrivate::remove_from_mapping(const QModelIndex &source_parent)
|
void QSortFilterProxyModelPrivate::remove_from_mapping(const QModelIndex &source_parent)
|
||||||
{
|
{
|
||||||
if (Mapping *m = source_index_mapping.take(source_parent)) {
|
if (Mapping *m = source_index_mapping.take(source_parent)) {
|
||||||
for (int i = 0; i < m->mapped_children.size(); ++i)
|
for (const QModelIndex &mappedIdx : qAsConst(m->mapped_children))
|
||||||
remove_from_mapping(m->mapped_children.at(i));
|
remove_from_mapping(mappedIdx);
|
||||||
delete m;
|
delete m;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -607,9 +603,9 @@ void QSortFilterProxyModelPrivate::sort()
|
|||||||
Q_Q(QSortFilterProxyModel);
|
Q_Q(QSortFilterProxyModel);
|
||||||
emit q->layoutAboutToBeChanged(QList<QPersistentModelIndex>(), QAbstractItemModel::VerticalSortHint);
|
emit q->layoutAboutToBeChanged(QList<QPersistentModelIndex>(), QAbstractItemModel::VerticalSortHint);
|
||||||
QModelIndexPairList source_indexes = store_persistent_indexes();
|
QModelIndexPairList source_indexes = store_persistent_indexes();
|
||||||
IndexMap::const_iterator it = source_index_mapping.constBegin();
|
const auto end = source_index_mapping.constEnd();
|
||||||
for (; it != source_index_mapping.constEnd(); ++it) {
|
for (auto it = source_index_mapping.constBegin(); it != end; ++it) {
|
||||||
QModelIndex source_parent = it.key();
|
const QModelIndex &source_parent = it.key();
|
||||||
Mapping *m = it.value();
|
Mapping *m = it.value();
|
||||||
sort_source_rows(m->source_rows, source_parent);
|
sort_source_rows(m->source_rows, source_parent);
|
||||||
build_source_to_proxy_mapping(m->source_rows, m->proxy_rows);
|
build_source_to_proxy_mapping(m->source_rows, m->proxy_rows);
|
||||||
@ -735,13 +731,14 @@ void QSortFilterProxyModelPrivate::remove_source_items(
|
|||||||
if (!proxy_parent.isValid() && source_parent.isValid())
|
if (!proxy_parent.isValid() && source_parent.isValid())
|
||||||
return; // nothing to do (already removed)
|
return; // nothing to do (already removed)
|
||||||
|
|
||||||
QVector<QPair<int, int> > proxy_intervals;
|
const auto proxy_intervals = proxy_intervals_for_source_items(
|
||||||
proxy_intervals = proxy_intervals_for_source_items(source_to_proxy, source_items);
|
source_to_proxy, source_items);
|
||||||
|
|
||||||
for (int i = proxy_intervals.size()-1; i >= 0; --i) {
|
const auto end = proxy_intervals.rend();
|
||||||
QPair<int, int> interval = proxy_intervals.at(i);
|
for (auto it = proxy_intervals.rbegin(); it != end; ++it) {
|
||||||
int proxy_start = interval.first;
|
const QPair<int, int> &interval = *it;
|
||||||
int proxy_end = interval.second;
|
const int proxy_start = interval.first;
|
||||||
|
const int proxy_end = interval.second;
|
||||||
remove_proxy_interval(source_to_proxy, proxy_to_source, proxy_start, proxy_end,
|
remove_proxy_interval(source_to_proxy, proxy_to_source, proxy_start, proxy_end,
|
||||||
proxy_parent, orient, emit_signal);
|
proxy_parent, orient, emit_signal);
|
||||||
}
|
}
|
||||||
@ -875,15 +872,15 @@ void QSortFilterProxyModelPrivate::insert_source_items(
|
|||||||
if (!proxy_parent.isValid() && source_parent.isValid())
|
if (!proxy_parent.isValid() && source_parent.isValid())
|
||||||
return; // nothing to do (source_parent is not mapped)
|
return; // nothing to do (source_parent is not mapped)
|
||||||
|
|
||||||
QVector<QPair<int, QVector<int> > > proxy_intervals;
|
const auto proxy_intervals = proxy_intervals_for_source_items_to_add(
|
||||||
proxy_intervals = proxy_intervals_for_source_items_to_add(
|
|
||||||
proxy_to_source, source_items, source_parent, orient);
|
proxy_to_source, source_items, source_parent, orient);
|
||||||
|
|
||||||
for (int i = proxy_intervals.size()-1; i >= 0; --i) {
|
const auto end = proxy_intervals.rend();
|
||||||
QPair<int, QVector<int> > interval = proxy_intervals.at(i);
|
for (auto it = proxy_intervals.rbegin(); it != end; ++it) {
|
||||||
int proxy_start = interval.first;
|
const QPair<int, QVector<int> > &interval = *it;
|
||||||
QVector<int> source_items = interval.second;
|
const int proxy_start = interval.first;
|
||||||
int proxy_end = proxy_start + source_items.size() - 1;
|
const QVector<int> &source_items = interval.second;
|
||||||
|
const int proxy_end = proxy_start + source_items.size() - 1;
|
||||||
|
|
||||||
if (emit_signal) {
|
if (emit_signal) {
|
||||||
if (orient == Qt::Vertical)
|
if (orient == Qt::Vertical)
|
||||||
@ -1195,8 +1192,8 @@ QModelIndexPairList QSortFilterProxyModelPrivate::store_persistent_indexes() con
|
|||||||
Q_Q(const QSortFilterProxyModel);
|
Q_Q(const QSortFilterProxyModel);
|
||||||
QModelIndexPairList source_indexes;
|
QModelIndexPairList source_indexes;
|
||||||
source_indexes.reserve(persistent.indexes.count());
|
source_indexes.reserve(persistent.indexes.count());
|
||||||
for (QPersistentModelIndexData *data : qAsConst(persistent.indexes)) {
|
for (const QPersistentModelIndexData *data : qAsConst(persistent.indexes)) {
|
||||||
QModelIndex proxy_index = data->index;
|
const QModelIndex &proxy_index = data->index;
|
||||||
QModelIndex source_index = q->mapToSource(proxy_index);
|
QModelIndex source_index = q->mapToSource(proxy_index);
|
||||||
source_indexes.append(qMakePair(proxy_index, QPersistentModelIndex(source_index)));
|
source_indexes.append(qMakePair(proxy_index, QPersistentModelIndex(source_index)));
|
||||||
}
|
}
|
||||||
@ -1217,9 +1214,9 @@ void QSortFilterProxyModelPrivate::update_persistent_indexes(
|
|||||||
const int numSourceIndexes = source_indexes.count();
|
const int numSourceIndexes = source_indexes.count();
|
||||||
from.reserve(numSourceIndexes);
|
from.reserve(numSourceIndexes);
|
||||||
to.reserve(numSourceIndexes);
|
to.reserve(numSourceIndexes);
|
||||||
for (int i = 0; i < numSourceIndexes; ++i) {
|
for (const auto &indexPair : source_indexes) {
|
||||||
QModelIndex source_index = source_indexes.at(i).second;
|
const QPersistentModelIndex &source_index = indexPair.second;
|
||||||
QModelIndex old_proxy_index = source_indexes.at(i).first;
|
const QModelIndex &old_proxy_index = indexPair.first;
|
||||||
create_mapping(source_index.parent());
|
create_mapping(source_index.parent());
|
||||||
QModelIndex proxy_index = q->mapFromSource(source_index);
|
QModelIndex proxy_index = q->mapFromSource(source_index);
|
||||||
from << old_proxy_index;
|
from << old_proxy_index;
|
||||||
@ -1264,7 +1261,7 @@ void QSortFilterProxyModelPrivate::filter_changed(const QModelIndex &source_pare
|
|||||||
const QVector<QModelIndex> mappedChildren = m->mapped_children;
|
const QVector<QModelIndex> mappedChildren = m->mapped_children;
|
||||||
QVector<int> indexesToRemove;
|
QVector<int> indexesToRemove;
|
||||||
for (int i = 0; i < mappedChildren.size(); ++i) {
|
for (int i = 0; i < mappedChildren.size(); ++i) {
|
||||||
const QModelIndex source_child_index = mappedChildren.at(i);
|
const QModelIndex &source_child_index = mappedChildren.at(i);
|
||||||
if (rows_removed.contains(source_child_index.row()) || columns_removed.contains(source_child_index.column())) {
|
if (rows_removed.contains(source_child_index.row()) || columns_removed.contains(source_child_index.column())) {
|
||||||
indexesToRemove.push_back(i);
|
indexesToRemove.push_back(i);
|
||||||
remove_from_mapping(source_child_index);
|
remove_from_mapping(source_child_index);
|
||||||
@ -2296,10 +2293,9 @@ QMimeData *QSortFilterProxyModel::mimeData(const QModelIndexList &indexes) const
|
|||||||
{
|
{
|
||||||
Q_D(const QSortFilterProxyModel);
|
Q_D(const QSortFilterProxyModel);
|
||||||
QModelIndexList source_indexes;
|
QModelIndexList source_indexes;
|
||||||
const int numIndexes = indexes.count();
|
source_indexes.reserve(indexes.count());
|
||||||
source_indexes.reserve(numIndexes);
|
for (const QModelIndex &idx : indexes)
|
||||||
for (int i = 0; i < numIndexes; ++i)
|
source_indexes << mapToSource(idx);
|
||||||
source_indexes << mapToSource(indexes.at(i));
|
|
||||||
return d->model->mimeData(source_indexes);
|
return d->model->mimeData(source_indexes);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -514,10 +514,9 @@ Q_CONSTRUCTOR_FUNCTION(qt_apple_check_os_version);
|
|||||||
|
|
||||||
// -------------------------------------------------------------------------
|
// -------------------------------------------------------------------------
|
||||||
|
|
||||||
void QMacKeyValueObserver::addObserver()
|
void QMacKeyValueObserver::addObserver(NSKeyValueObservingOptions options)
|
||||||
{
|
{
|
||||||
[object addObserver:observer forKeyPath:keyPath
|
[object addObserver:observer forKeyPath:keyPath options:options context:callback.get()];
|
||||||
options:NSKeyValueObservingOptionNew context:callback.get()];
|
|
||||||
}
|
}
|
||||||
|
|
||||||
void QMacKeyValueObserver::removeObserver() {
|
void QMacKeyValueObserver::removeObserver() {
|
||||||
|
@ -350,8 +350,12 @@ public:
|
|||||||
QMacKeyValueObserver() {}
|
QMacKeyValueObserver() {}
|
||||||
|
|
||||||
// Note: QMacKeyValueObserver must not outlive the object observed!
|
// Note: QMacKeyValueObserver must not outlive the object observed!
|
||||||
QMacKeyValueObserver(id object, NSString *keyPath, Callback callback)
|
QMacKeyValueObserver(id object, NSString *keyPath, Callback callback,
|
||||||
: object(object), keyPath(keyPath), callback(new Callback(callback)) { addObserver(); }
|
NSKeyValueObservingOptions options = NSKeyValueObservingOptionNew)
|
||||||
|
: object(object), keyPath(keyPath), callback(new Callback(callback))
|
||||||
|
{
|
||||||
|
addObserver(options);
|
||||||
|
}
|
||||||
|
|
||||||
QMacKeyValueObserver(const QMacKeyValueObserver &other)
|
QMacKeyValueObserver(const QMacKeyValueObserver &other)
|
||||||
: QMacKeyValueObserver(other.object, other.keyPath, *other.callback.get()) {}
|
: QMacKeyValueObserver(other.object, other.keyPath, *other.callback.get()) {}
|
||||||
@ -381,7 +385,7 @@ private:
|
|||||||
std::swap(first.callback, second.callback);
|
std::swap(first.callback, second.callback);
|
||||||
}
|
}
|
||||||
|
|
||||||
void addObserver();
|
void addObserver(NSKeyValueObservingOptions options);
|
||||||
|
|
||||||
id object = nil;
|
id object = nil;
|
||||||
NSString *keyPath = nullptr;
|
NSString *keyPath = nullptr;
|
||||||
|
@ -57,7 +57,7 @@
|
|||||||
|
|
||||||
#include <qt_windows.h>
|
#include <qt_windows.h>
|
||||||
|
|
||||||
namespace std { template <typename T> class function; }
|
#include <functional>
|
||||||
|
|
||||||
QT_BEGIN_NAMESPACE
|
QT_BEGIN_NAMESPACE
|
||||||
|
|
||||||
|
@ -953,7 +953,7 @@ static const QMetaObject *QMetaObject_findMetaObject(const QMetaObject *self, co
|
|||||||
return self;
|
return self;
|
||||||
if (self->d.relatedMetaObjects) {
|
if (self->d.relatedMetaObjects) {
|
||||||
Q_ASSERT(priv(self->d.data)->revision >= 2);
|
Q_ASSERT(priv(self->d.data)->revision >= 2);
|
||||||
const QMetaObject * const *e = self->d.relatedMetaObjects;
|
const auto *e = self->d.relatedMetaObjects;
|
||||||
if (e) {
|
if (e) {
|
||||||
while (*e) {
|
while (*e) {
|
||||||
if (const QMetaObject *m =QMetaObject_findMetaObject((*e), name))
|
if (const QMetaObject *m =QMetaObject_findMetaObject((*e), name))
|
||||||
|
@ -747,7 +747,7 @@ void QMetaObjectBuilder::addMetaObject
|
|||||||
|
|
||||||
if ((members & RelatedMetaObjects) != 0) {
|
if ((members & RelatedMetaObjects) != 0) {
|
||||||
Q_ASSERT(priv(prototype->d.data)->revision >= 2);
|
Q_ASSERT(priv(prototype->d.data)->revision >= 2);
|
||||||
const QMetaObject * const *objects = prototype->d.relatedMetaObjects;
|
const auto *objects = prototype->d.relatedMetaObjects;
|
||||||
if (objects) {
|
if (objects) {
|
||||||
while (*objects != 0) {
|
while (*objects != 0) {
|
||||||
addRelatedMetaObject(*objects);
|
addRelatedMetaObject(*objects);
|
||||||
@ -1464,16 +1464,16 @@ static int buildMetaObject(QMetaObjectBuilderPrivate *d, char *buf,
|
|||||||
|
|
||||||
// Create the relatedMetaObjects block if we need one.
|
// Create the relatedMetaObjects block if we need one.
|
||||||
if (d->relatedMetaObjects.size() > 0) {
|
if (d->relatedMetaObjects.size() > 0) {
|
||||||
ALIGN(size, QMetaObject *);
|
using SuperData = QMetaObject::SuperData;
|
||||||
const QMetaObject **objects =
|
ALIGN(size, SuperData);
|
||||||
reinterpret_cast<const QMetaObject **>(buf + size);
|
auto objects = reinterpret_cast<SuperData *>(buf + size);
|
||||||
if (buf) {
|
if (buf) {
|
||||||
meta->d.relatedMetaObjects = objects;
|
meta->d.relatedMetaObjects = objects;
|
||||||
for (index = 0; index < d->relatedMetaObjects.size(); ++index)
|
for (index = 0; index < d->relatedMetaObjects.size(); ++index)
|
||||||
objects[index] = d->relatedMetaObjects[index];
|
objects[index] = d->relatedMetaObjects[index];
|
||||||
objects[index] = 0;
|
objects[index] = nullptr;
|
||||||
}
|
}
|
||||||
size += sizeof(QMetaObject *) * (d->relatedMetaObjects.size() + 1);
|
size += sizeof(SuperData) * (d->relatedMetaObjects.size() + 1);
|
||||||
}
|
}
|
||||||
|
|
||||||
// Align the final size and return it.
|
// Align the final size and return it.
|
||||||
|
@ -216,7 +216,7 @@ inline Q_DECL_CONSTEXPR int qMetaTypeId();
|
|||||||
F(QQueue) \
|
F(QQueue) \
|
||||||
F(QStack) \
|
F(QStack) \
|
||||||
F(QSet) \
|
F(QSet) \
|
||||||
F(QLinkedList)
|
/*end*/
|
||||||
|
|
||||||
#define QT_FOR_EACH_AUTOMATIC_TEMPLATE_2ARG(F) \
|
#define QT_FOR_EACH_AUTOMATIC_TEMPLATE_2ARG(F) \
|
||||||
F(QHash, class) \
|
F(QHash, class) \
|
||||||
|
@ -93,12 +93,6 @@ QAbstractDynamicMetaObject::~QAbstractDynamicMetaObject()
|
|||||||
{
|
{
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
struct QSlotObjectBaseDeleter { // for use with QScopedPointer<QSlotObjectBase,...>
|
|
||||||
static void cleanup(QtPrivate::QSlotObjectBase *slot) {
|
|
||||||
if (slot) slot->destroyIfLastRef();
|
|
||||||
}
|
|
||||||
};
|
|
||||||
static int *queuedConnectionTypes(const QList<QByteArray> &typeNames)
|
static int *queuedConnectionTypes(const QList<QByteArray> &typeNames)
|
||||||
{
|
{
|
||||||
int *types = new int [typeNames.count() + 1];
|
int *types = new int [typeNames.count() + 1];
|
||||||
@ -3380,7 +3374,7 @@ QObjectPrivate::Connection *QMetaObjectPrivate::connect(const QObject *sender,
|
|||||||
type &= Qt::UniqueConnection - 1;
|
type &= Qt::UniqueConnection - 1;
|
||||||
}
|
}
|
||||||
|
|
||||||
QScopedPointer<QObjectPrivate::Connection> c(new QObjectPrivate::Connection);
|
std::unique_ptr<QObjectPrivate::Connection> c{new QObjectPrivate::Connection};
|
||||||
c->sender = s;
|
c->sender = s;
|
||||||
c->signal_index = signal_index;
|
c->signal_index = signal_index;
|
||||||
c->receiver.storeRelaxed(r);
|
c->receiver.storeRelaxed(r);
|
||||||
@ -3394,14 +3388,14 @@ QObjectPrivate::Connection *QMetaObjectPrivate::connect(const QObject *sender,
|
|||||||
c->argumentTypes.storeRelaxed(types);
|
c->argumentTypes.storeRelaxed(types);
|
||||||
c->callFunction = callFunction;
|
c->callFunction = callFunction;
|
||||||
|
|
||||||
QObjectPrivate::get(s)->addConnection(signal_index, c.data());
|
QObjectPrivate::get(s)->addConnection(signal_index, c.get());
|
||||||
|
|
||||||
locker.unlock();
|
locker.unlock();
|
||||||
QMetaMethod smethod = QMetaObjectPrivate::signal(smeta, signal_index);
|
QMetaMethod smethod = QMetaObjectPrivate::signal(smeta, signal_index);
|
||||||
if (smethod.isValid())
|
if (smethod.isValid())
|
||||||
s->connectNotify(smethod);
|
s->connectNotify(smethod);
|
||||||
|
|
||||||
return c.take();
|
return c.release();
|
||||||
}
|
}
|
||||||
|
|
||||||
/*!
|
/*!
|
||||||
@ -3791,10 +3785,16 @@ void doActivate(QObject *sender, int signal_index, void **argv)
|
|||||||
|
|
||||||
if (c->isSlotObject) {
|
if (c->isSlotObject) {
|
||||||
c->slotObj->ref();
|
c->slotObj->ref();
|
||||||
QScopedPointer<QtPrivate::QSlotObjectBase, QSlotObjectBaseDeleter> obj(c->slotObj);
|
|
||||||
|
struct Deleter {
|
||||||
|
void operator()(QtPrivate::QSlotObjectBase *slot) const {
|
||||||
|
if (slot) slot->destroyIfLastRef();
|
||||||
|
}
|
||||||
|
};
|
||||||
|
const std::unique_ptr<QtPrivate::QSlotObjectBase, Deleter> obj{c->slotObj};
|
||||||
|
|
||||||
{
|
{
|
||||||
Q_TRACE_SCOPE(QMetaObject_activate_slot_functor, obj.data());
|
Q_TRACE_SCOPE(QMetaObject_activate_slot_functor, obj.get());
|
||||||
obj->call(receiver, argv);
|
obj->call(receiver, argv);
|
||||||
}
|
}
|
||||||
} else if (c->callFunction && c->method_offset <= receiver->metaObject()->methodOffset()) {
|
} else if (c->callFunction && c->method_offset <= receiver->metaObject()->methodOffset()) {
|
||||||
@ -4947,7 +4947,7 @@ QMetaObject::Connection QObjectPrivate::connectImpl(const QObject *sender, int s
|
|||||||
type = static_cast<Qt::ConnectionType>(type ^ Qt::UniqueConnection);
|
type = static_cast<Qt::ConnectionType>(type ^ Qt::UniqueConnection);
|
||||||
}
|
}
|
||||||
|
|
||||||
QScopedPointer<QObjectPrivate::Connection> c(new QObjectPrivate::Connection);
|
std::unique_ptr<QObjectPrivate::Connection> c{new QObjectPrivate::Connection};
|
||||||
c->sender = s;
|
c->sender = s;
|
||||||
c->signal_index = signal_index;
|
c->signal_index = signal_index;
|
||||||
QThreadData *td = r->d_func()->threadData;
|
QThreadData *td = r->d_func()->threadData;
|
||||||
@ -4962,8 +4962,8 @@ QMetaObject::Connection QObjectPrivate::connectImpl(const QObject *sender, int s
|
|||||||
c->ownArgumentTypes = false;
|
c->ownArgumentTypes = false;
|
||||||
}
|
}
|
||||||
|
|
||||||
QObjectPrivate::get(s)->addConnection(signal_index, c.data());
|
QObjectPrivate::get(s)->addConnection(signal_index, c.get());
|
||||||
QMetaObject::Connection ret(c.take());
|
QMetaObject::Connection ret(c.release());
|
||||||
locker.unlock();
|
locker.unlock();
|
||||||
|
|
||||||
QMetaMethod method = QMetaObjectPrivate::signal(senderMetaObject, signal_index);
|
QMetaMethod method = QMetaObjectPrivate::signal(senderMetaObject, signal_index);
|
||||||
|
@ -486,8 +486,11 @@ class Q_CORE_EXPORT QAbstractMetaCallEvent : public QEvent
|
|||||||
{
|
{
|
||||||
public:
|
public:
|
||||||
QAbstractMetaCallEvent(const QObject *sender, int signalId, QSemaphore *semaphore = nullptr)
|
QAbstractMetaCallEvent(const QObject *sender, int signalId, QSemaphore *semaphore = nullptr)
|
||||||
: QEvent(MetaCall), signalId_(signalId), sender_(sender), semaphore_(semaphore)
|
: QEvent(MetaCall), signalId_(signalId), sender_(sender)
|
||||||
{}
|
#if QT_CONFIG(thread)
|
||||||
|
, semaphore_(semaphore)
|
||||||
|
#endif
|
||||||
|
{ Q_UNUSED(semaphore); }
|
||||||
~QAbstractMetaCallEvent();
|
~QAbstractMetaCallEvent();
|
||||||
|
|
||||||
virtual void placeMetaCall(QObject *object) = 0;
|
virtual void placeMetaCall(QObject *object) = 0;
|
||||||
@ -498,7 +501,9 @@ public:
|
|||||||
private:
|
private:
|
||||||
int signalId_;
|
int signalId_;
|
||||||
const QObject *sender_;
|
const QObject *sender_;
|
||||||
|
#if QT_CONFIG(thread)
|
||||||
QSemaphore *semaphore_;
|
QSemaphore *semaphore_;
|
||||||
|
#endif
|
||||||
};
|
};
|
||||||
|
|
||||||
class Q_CORE_EXPORT QMetaCallEvent : public QAbstractMetaCallEvent
|
class Q_CORE_EXPORT QMetaCallEvent : public QAbstractMetaCallEvent
|
||||||
|
@ -1,7 +1,7 @@
|
|||||||
/****************************************************************************
|
/****************************************************************************
|
||||||
**
|
**
|
||||||
** Copyright (C) 2016 The Qt Company Ltd.
|
** Copyright (C) 2019 The Qt Company Ltd.
|
||||||
** Copyright (C) 2016 Intel Corporation.
|
** Copyright (C) 2019 Intel Corporation.
|
||||||
** Contact: https://www.qt.io/licensing/
|
** Contact: https://www.qt.io/licensing/
|
||||||
**
|
**
|
||||||
** This file is part of the QtCore module of the Qt Toolkit.
|
** This file is part of the QtCore module of the Qt Toolkit.
|
||||||
@ -572,13 +572,42 @@ struct Q_CORE_EXPORT QMetaObject
|
|||||||
int static_metacall(Call, int, void **) const;
|
int static_metacall(Call, int, void **) const;
|
||||||
static int metacall(QObject *, Call, int, void **);
|
static int metacall(QObject *, Call, int, void **);
|
||||||
|
|
||||||
|
template <const QMetaObject &MO> static constexpr const QMetaObject *staticMetaObject()
|
||||||
|
{
|
||||||
|
return &MO;
|
||||||
|
}
|
||||||
|
|
||||||
|
struct SuperData {
|
||||||
|
const QMetaObject *direct;
|
||||||
|
SuperData() = default;
|
||||||
|
constexpr SuperData(std::nullptr_t) : direct(nullptr) {}
|
||||||
|
constexpr SuperData(const QMetaObject *mo) : direct(mo) {}
|
||||||
|
|
||||||
|
constexpr const QMetaObject *operator->() const { return operator const QMetaObject *(); }
|
||||||
|
|
||||||
|
#ifdef QT_NO_DATA_RELOCATION
|
||||||
|
using Getter = const QMetaObject *(*)();
|
||||||
|
Getter indirect = nullptr;
|
||||||
|
constexpr SuperData(Getter g) : direct(nullptr), indirect(g) {}
|
||||||
|
constexpr operator const QMetaObject *() const
|
||||||
|
{ return indirect ? indirect() : direct; }
|
||||||
|
template <const QMetaObject &MO> static constexpr SuperData link()
|
||||||
|
{ return SuperData(QMetaObject::staticMetaObject<MO>); }
|
||||||
|
#else
|
||||||
|
constexpr operator const QMetaObject *() const
|
||||||
|
{ return direct; }
|
||||||
|
template <const QMetaObject &MO> static constexpr SuperData link()
|
||||||
|
{ return SuperData(QMetaObject::staticMetaObject<MO>()); }
|
||||||
|
#endif
|
||||||
|
};
|
||||||
|
|
||||||
struct { // private data
|
struct { // private data
|
||||||
const QMetaObject *superdata;
|
SuperData superdata;
|
||||||
const QByteArrayData *stringdata;
|
const QByteArrayData *stringdata;
|
||||||
const uint *data;
|
const uint *data;
|
||||||
typedef void (*StaticMetacallFunction)(QObject *, QMetaObject::Call, int, void **);
|
typedef void (*StaticMetacallFunction)(QObject *, QMetaObject::Call, int, void **);
|
||||||
StaticMetacallFunction static_metacall;
|
StaticMetacallFunction static_metacall;
|
||||||
const QMetaObject * const *relatedMetaObjects;
|
const SuperData *relatedMetaObjects;
|
||||||
void *extradata; //reserved for future use
|
void *extradata; //reserved for future use
|
||||||
} d;
|
} d;
|
||||||
|
|
||||||
|
@ -38,7 +38,6 @@
|
|||||||
****************************************************************************/
|
****************************************************************************/
|
||||||
|
|
||||||
#include "qglobal.h"
|
#include "qglobal.h"
|
||||||
#if QT_DEPRECATED_SINCE(5, 10)
|
|
||||||
|
|
||||||
#include "qsignalmapper.h"
|
#include "qsignalmapper.h"
|
||||||
#include "qhash.h"
|
#include "qhash.h"
|
||||||
@ -64,7 +63,6 @@ public:
|
|||||||
/*!
|
/*!
|
||||||
\class QSignalMapper
|
\class QSignalMapper
|
||||||
\inmodule QtCore
|
\inmodule QtCore
|
||||||
\obsolete The recommended solution is connecting the signal to a lambda.
|
|
||||||
\brief The QSignalMapper class bundles signals from identifiable senders.
|
\brief The QSignalMapper class bundles signals from identifiable senders.
|
||||||
|
|
||||||
\ingroup objectmodel
|
\ingroup objectmodel
|
||||||
@ -72,7 +70,9 @@ public:
|
|||||||
|
|
||||||
This class collects a set of parameterless signals, and re-emits
|
This class collects a set of parameterless signals, and re-emits
|
||||||
them with integer, string or widget parameters corresponding to
|
them with integer, string or widget parameters corresponding to
|
||||||
the object that sent the signal.
|
the object that sent the signal. Note that in most cases you can
|
||||||
|
use lambdas for passing custom parameters to slots. This is less
|
||||||
|
costly and will simplify the code.
|
||||||
|
|
||||||
The class supports the mapping of particular strings or integers
|
The class supports the mapping of particular strings or integers
|
||||||
with particular objects using setMapping(). The objects' signals
|
with particular objects using setMapping(). The objects' signals
|
||||||
@ -314,5 +314,3 @@ void QSignalMapper::map(QObject *sender)
|
|||||||
QT_END_NAMESPACE
|
QT_END_NAMESPACE
|
||||||
|
|
||||||
#include "moc_qsignalmapper.cpp"
|
#include "moc_qsignalmapper.cpp"
|
||||||
|
|
||||||
#endif
|
|
||||||
|
@ -42,8 +42,6 @@
|
|||||||
|
|
||||||
#include <QtCore/qobject.h>
|
#include <QtCore/qobject.h>
|
||||||
|
|
||||||
#if QT_DEPRECATED_SINCE(5, 10)
|
|
||||||
|
|
||||||
QT_BEGIN_NAMESPACE
|
QT_BEGIN_NAMESPACE
|
||||||
|
|
||||||
class QSignalMapperPrivate;
|
class QSignalMapperPrivate;
|
||||||
@ -53,7 +51,7 @@ class Q_CORE_EXPORT QSignalMapper : public QObject
|
|||||||
Q_OBJECT
|
Q_OBJECT
|
||||||
Q_DECLARE_PRIVATE(QSignalMapper)
|
Q_DECLARE_PRIVATE(QSignalMapper)
|
||||||
public:
|
public:
|
||||||
QT_DEPRECATED explicit QSignalMapper(QObject *parent = nullptr);
|
explicit QSignalMapper(QObject *parent = nullptr);
|
||||||
~QSignalMapper();
|
~QSignalMapper();
|
||||||
|
|
||||||
void setMapping(QObject *sender, int id);
|
void setMapping(QObject *sender, int id);
|
||||||
@ -84,6 +82,4 @@ private:
|
|||||||
|
|
||||||
QT_END_NAMESPACE
|
QT_END_NAMESPACE
|
||||||
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#endif // QSIGNALMAPPER_H
|
#endif // QSIGNALMAPPER_H
|
||||||
|
@ -528,7 +528,8 @@ bool QTranslatorPrivate::do_load(const QString &realname, const QString &directo
|
|||||||
// memory, so no need to use QFile to copy it again.
|
// memory, so no need to use QFile to copy it again.
|
||||||
Q_ASSERT(!d->resource);
|
Q_ASSERT(!d->resource);
|
||||||
d->resource = new QResource(realname);
|
d->resource = new QResource(realname);
|
||||||
if (resource->isValid() && !resource->isCompressed() && resource->size() >= MagicLength
|
if (resource->isValid() && resource->compressionAlgorithm() == QResource::NoCompression
|
||||||
|
&& resource->size() >= MagicLength
|
||||||
&& !memcmp(resource->data(), magic, MagicLength)) {
|
&& !memcmp(resource->data(), magic, MagicLength)) {
|
||||||
d->unmapLength = resource->size();
|
d->unmapLength = resource->size();
|
||||||
d->unmapPointer = reinterpret_cast<char *>(const_cast<uchar *>(resource->data()));
|
d->unmapPointer = reinterpret_cast<char *>(const_cast<uchar *>(resource->data()));
|
||||||
|
@ -362,7 +362,7 @@ class Q_CORE_EXPORT QVariant
|
|||||||
static inline QVariant fromValue(const T &value)
|
static inline QVariant fromValue(const T &value)
|
||||||
{ return QVariant(qMetaTypeId<T>(), &value, QTypeInfo<T>::isPointer); }
|
{ return QVariant(qMetaTypeId<T>(), &value, QTypeInfo<T>::isPointer); }
|
||||||
|
|
||||||
#if QT_HAS_INCLUDE(<variant>) && __cplusplus >= 201703L
|
#if (QT_HAS_INCLUDE(<variant>) && __cplusplus >= 201703L) || defined(Q_CLANG_QDOC)
|
||||||
template<typename... Types>
|
template<typename... Types>
|
||||||
static inline QVariant fromStdVariant(const std::variant<Types...> &value)
|
static inline QVariant fromStdVariant(const std::variant<Types...> &value)
|
||||||
{
|
{
|
||||||
|
@ -92,7 +92,7 @@ QT_BEGIN_NAMESPACE
|
|||||||
but if other instances of QPluginLoader are using the same
|
but if other instances of QPluginLoader are using the same
|
||||||
library, the call will fail, and unloading will only happen when
|
library, the call will fail, and unloading will only happen when
|
||||||
every instance has called unload(). Right before the unloading
|
every instance has called unload(). Right before the unloading
|
||||||
happen, the root component will also be deleted.
|
happens, the root component will also be deleted.
|
||||||
|
|
||||||
See \l{How to Create Qt Plugins} for more information about
|
See \l{How to Create Qt Plugins} for more information about
|
||||||
how to make your application extensible through plugins.
|
how to make your application extensible through plugins.
|
||||||
|
@ -273,7 +273,7 @@ QCborValue QCborArray::at(qsizetype i) const
|
|||||||
not be empty.
|
not be empty.
|
||||||
|
|
||||||
QCborValueRef has the exact same API as \l QCborValue, with one important
|
QCborValueRef has the exact same API as \l QCborValue, with one important
|
||||||
difference: if you assign new values to it, this map will be updated with
|
difference: if you assign new values to it, this array will be updated with
|
||||||
that new value.
|
that new value.
|
||||||
|
|
||||||
\sa operator[](), at(), last(), insert(), prepend(), append(),
|
\sa operator[](), at(), last(), insert(), prepend(), append(),
|
||||||
@ -287,7 +287,7 @@ QCborValue QCborArray::at(qsizetype i) const
|
|||||||
not be empty.
|
not be empty.
|
||||||
|
|
||||||
QCborValueRef has the exact same API as \l QCborValue, with one important
|
QCborValueRef has the exact same API as \l QCborValue, with one important
|
||||||
difference: if you assign new values to it, this map will be updated with
|
difference: if you assign new values to it, this array will be updated with
|
||||||
that new value.
|
that new value.
|
||||||
|
|
||||||
\sa operator[](), at(), first(), insert(), prepend(), append(),
|
\sa operator[](), at(), first(), insert(), prepend(), append(),
|
||||||
@ -302,7 +302,7 @@ QCborValue QCborArray::at(qsizetype i) const
|
|||||||
with undefined entries, until it has an entry at the specified index.
|
with undefined entries, until it has an entry at the specified index.
|
||||||
|
|
||||||
QCborValueRef has the exact same API as \l QCborValue, with one important
|
QCborValueRef has the exact same API as \l QCborValue, with one important
|
||||||
difference: if you assign new values to it, this map will be updated with
|
difference: if you assign new values to it, this array will be updated with
|
||||||
that new value.
|
that new value.
|
||||||
|
|
||||||
\sa at(), first(), last(), insert(), prepend(), append(),
|
\sa at(), first(), last(), insert(), prepend(), append(),
|
||||||
|
@ -1972,7 +1972,15 @@ inline void QCborStreamReader::preparse()
|
|||||||
if (lastError() == QCborError::NoError) {
|
if (lastError() == QCborError::NoError) {
|
||||||
type_ = cbor_value_get_type(&d->currentElement);
|
type_ = cbor_value_get_type(&d->currentElement);
|
||||||
|
|
||||||
if (type_ != CborInvalidType) {
|
if (type_ == CborInvalidType) {
|
||||||
|
// We may have reached the end.
|
||||||
|
if (d->device && d->containerStack.isEmpty()) {
|
||||||
|
d->buffer.clear();
|
||||||
|
if (d->bufferStart)
|
||||||
|
d->device->skip(d->bufferStart);
|
||||||
|
d->bufferStart = 0;
|
||||||
|
}
|
||||||
|
} else {
|
||||||
d->lastError = {};
|
d->lastError = {};
|
||||||
// Undo the type mapping that TinyCBOR does (we have an explicit type
|
// Undo the type mapping that TinyCBOR does (we have an explicit type
|
||||||
// for negative integer and we don't have separate types for Boolean,
|
// for negative integer and we don't have separate types for Boolean,
|
||||||
|
@ -175,7 +175,7 @@ void Base::removeItems(int pos, int numItems)
|
|||||||
length -= numItems;
|
length -= numItems;
|
||||||
}
|
}
|
||||||
|
|
||||||
int Object::indexOf(const QString &key, bool *exists) const
|
int Object::indexOf(QStringView key, bool *exists) const
|
||||||
{
|
{
|
||||||
int min = 0;
|
int min = 0;
|
||||||
int n = length;
|
int n = length;
|
||||||
@ -257,7 +257,7 @@ bool Array::isValid(int maxSize) const
|
|||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
bool Entry::operator ==(const QString &key) const
|
bool Entry::operator ==(QStringView key) const
|
||||||
{
|
{
|
||||||
if (value.latinKey)
|
if (value.latinKey)
|
||||||
return (shallowLatin1Key() == key);
|
return (shallowLatin1Key() == key);
|
||||||
@ -270,7 +270,7 @@ bool Entry::operator==(QLatin1String key) const
|
|||||||
if (value.latinKey)
|
if (value.latinKey)
|
||||||
return shallowLatin1Key() == key;
|
return shallowLatin1Key() == key;
|
||||||
else
|
else
|
||||||
return shallowKey() == key;
|
return shallowKey() == QString(key); // ### conversion to QString
|
||||||
}
|
}
|
||||||
|
|
||||||
bool Entry::operator ==(const Entry &other) const
|
bool Entry::operator ==(const Entry &other) const
|
||||||
|
@ -66,11 +66,13 @@
|
|||||||
|
|
||||||
#include <limits.h>
|
#include <limits.h>
|
||||||
#include <limits>
|
#include <limits>
|
||||||
|
#include <type_traits>
|
||||||
|
|
||||||
QT_BEGIN_NAMESPACE
|
QT_BEGIN_NAMESPACE
|
||||||
|
|
||||||
// in qstring.cpp
|
// in qstring.cpp
|
||||||
void qt_to_latin1_unchecked(uchar *dst, const ushort *uc, qsizetype len);
|
void qt_to_latin1_unchecked(uchar *dst, const ushort *uc, qsizetype len);
|
||||||
|
void qt_from_latin1(ushort *dst, const char *str, size_t size) noexcept;
|
||||||
|
|
||||||
/*
|
/*
|
||||||
This defines a binary data structure for Json data. The data structure is optimised for fast reading
|
This defines a binary data structure for Json data. The data structure is optimised for fast reading
|
||||||
@ -153,16 +155,24 @@ typedef qle_uint offset;
|
|||||||
// round the size up to the next 4 byte boundary
|
// round the size up to the next 4 byte boundary
|
||||||
inline int alignedSize(int size) { return (size + 3) & ~3; }
|
inline int alignedSize(int size) { return (size + 3) & ~3; }
|
||||||
|
|
||||||
static inline bool useCompressed(const QString &s)
|
const int MaxLatin1Length = 0x7fff;
|
||||||
|
|
||||||
|
static inline bool useCompressed(QStringView s)
|
||||||
{
|
{
|
||||||
if (s.length() >= 0x8000)
|
if (s.length() > MaxLatin1Length)
|
||||||
return false;
|
return false;
|
||||||
return QtPrivate::isLatin1(s);
|
return QtPrivate::isLatin1(s);
|
||||||
}
|
}
|
||||||
|
|
||||||
static inline int qStringSize(const QString &string, bool compress)
|
static inline bool useCompressed(QLatin1String s)
|
||||||
{
|
{
|
||||||
int l = 2 + string.length();
|
return s.size() <= MaxLatin1Length;
|
||||||
|
}
|
||||||
|
|
||||||
|
template <typename T>
|
||||||
|
static inline int qStringSize(T string, bool compress)
|
||||||
|
{
|
||||||
|
int l = 2 + string.size();
|
||||||
if (!compress)
|
if (!compress)
|
||||||
l *= 2;
|
l *= 2;
|
||||||
return alignedSize(l);
|
return alignedSize(l);
|
||||||
@ -214,37 +224,49 @@ public:
|
|||||||
return maxSize >= 0 && uint(d->length) <= maxSize / sizeof(ushort);
|
return maxSize >= 0 && uint(d->length) <= maxSize / sizeof(ushort);
|
||||||
}
|
}
|
||||||
|
|
||||||
inline String &operator=(const QString &str)
|
inline String &operator=(QStringView str)
|
||||||
{
|
{
|
||||||
d->length = str.length();
|
d->length = str.length();
|
||||||
#if Q_BYTE_ORDER == Q_BIG_ENDIAN
|
qToLittleEndian<quint16>(str.utf16(), str.length(), d->utf16);
|
||||||
const ushort *uc = (const ushort *)str.unicode();
|
fillTrailingZeros();
|
||||||
for (int i = 0; i < str.length(); ++i)
|
|
||||||
d->utf16[i] = uc[i];
|
|
||||||
#else
|
|
||||||
memcpy(d->utf16, str.unicode(), str.length()*sizeof(ushort));
|
|
||||||
#endif
|
|
||||||
if (str.length() & 1)
|
|
||||||
d->utf16[str.length()] = 0;
|
|
||||||
return *this;
|
return *this;
|
||||||
}
|
}
|
||||||
|
|
||||||
inline bool operator ==(const QString &str) const {
|
inline String &operator=(QLatin1String str)
|
||||||
|
{
|
||||||
|
d->length = str.size();
|
||||||
|
#if Q_BYTE_ORDER == Q_BIG_ENDIAN
|
||||||
|
for (int i = 0; i < str.size(); ++i)
|
||||||
|
d->utf16[i] = str[i].unicode();
|
||||||
|
#else
|
||||||
|
qt_from_latin1((ushort *)d->utf16, str.data(), str.size());
|
||||||
|
#endif
|
||||||
|
fillTrailingZeros();
|
||||||
|
return *this;
|
||||||
|
}
|
||||||
|
|
||||||
|
void fillTrailingZeros()
|
||||||
|
{
|
||||||
|
if (d->length & 1)
|
||||||
|
d->utf16[d->length] = 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
inline bool operator ==(QStringView str) const {
|
||||||
int slen = str.length();
|
int slen = str.length();
|
||||||
int l = d->length;
|
int l = d->length;
|
||||||
if (slen != l)
|
if (slen != l)
|
||||||
return false;
|
return false;
|
||||||
const ushort *s = (const ushort *)str.constData();
|
const ushort *s = (const ushort *)str.utf16();
|
||||||
const qle_ushort *a = d->utf16;
|
const qle_ushort *a = d->utf16;
|
||||||
const ushort *b = s;
|
const ushort *b = s;
|
||||||
while (l-- && *a == *b)
|
while (l-- && *a == *b)
|
||||||
a++,b++;
|
a++,b++;
|
||||||
return (l == -1);
|
return (l == -1);
|
||||||
}
|
}
|
||||||
inline bool operator !=(const QString &str) const {
|
inline bool operator !=(QStringView str) const {
|
||||||
return !operator ==(str);
|
return !operator ==(str);
|
||||||
}
|
}
|
||||||
inline bool operator >=(const QString &str) const {
|
inline bool operator >=(QStringView str) const {
|
||||||
// ###
|
// ###
|
||||||
return toString() >= str;
|
return toString() >= str;
|
||||||
}
|
}
|
||||||
@ -292,18 +314,34 @@ public:
|
|||||||
return byteSize() <= maxSize;
|
return byteSize() <= maxSize;
|
||||||
}
|
}
|
||||||
|
|
||||||
inline Latin1String &operator=(const QString &str)
|
inline Latin1String &operator=(QStringView str)
|
||||||
{
|
{
|
||||||
int len = d->length = str.length();
|
int len = d->length = str.length();
|
||||||
uchar *l = (uchar *)d->latin1;
|
uchar *l = (uchar *)d->latin1;
|
||||||
const ushort *uc = (const ushort *)str.unicode();
|
const ushort *uc = (const ushort *)str.utf16();
|
||||||
qt_to_latin1_unchecked(l, uc, len);
|
qt_to_latin1_unchecked(l, uc, len);
|
||||||
|
|
||||||
for ( ; (quintptr)(l+len) & 0x3; ++len)
|
fillTrailingZeros();
|
||||||
l[len] = 0;
|
|
||||||
return *this;
|
return *this;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
inline Latin1String &operator=(QLatin1String str)
|
||||||
|
{
|
||||||
|
int len = d->length = str.size();
|
||||||
|
uchar *l = (uchar *)d->latin1;
|
||||||
|
memcpy(l, str.data(), len);
|
||||||
|
|
||||||
|
fillTrailingZeros();
|
||||||
|
return *this;
|
||||||
|
}
|
||||||
|
|
||||||
|
void fillTrailingZeros()
|
||||||
|
{
|
||||||
|
uchar *l = (uchar *)d->latin1;
|
||||||
|
for (int len = d->length; (quintptr)(l + len) & 0x3; ++len)
|
||||||
|
l[len] = 0;
|
||||||
|
}
|
||||||
|
|
||||||
QLatin1String toQLatin1String() const noexcept {
|
QLatin1String toQLatin1String() const noexcept {
|
||||||
return QLatin1String(d->latin1, d->length);
|
return QLatin1String(d->latin1, d->length);
|
||||||
}
|
}
|
||||||
@ -351,11 +389,11 @@ public:
|
|||||||
{ \
|
{ \
|
||||||
return lhs.toQLatin1String() op rhs; \
|
return lhs.toQLatin1String() op rhs; \
|
||||||
} \
|
} \
|
||||||
inline bool operator op(const QString &lhs, Latin1String rhs) noexcept \
|
inline bool operator op(QStringView lhs, Latin1String rhs) noexcept \
|
||||||
{ \
|
{ \
|
||||||
return lhs op rhs.toQLatin1String(); \
|
return lhs op rhs.toQLatin1String(); \
|
||||||
} \
|
} \
|
||||||
inline bool operator op(Latin1String lhs, const QString &rhs) noexcept \
|
inline bool operator op(Latin1String lhs, QStringView rhs) noexcept \
|
||||||
{ \
|
{ \
|
||||||
return lhs.toQLatin1String() op rhs; \
|
return lhs.toQLatin1String() op rhs; \
|
||||||
} \
|
} \
|
||||||
@ -419,7 +457,8 @@ inline bool String::operator<(const Latin1String &str) const
|
|||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
static inline void copyString(char *dest, const QString &str, bool compress)
|
template <typename T>
|
||||||
|
static inline void copyString(char *dest, T str, bool compress)
|
||||||
{
|
{
|
||||||
if (compress) {
|
if (compress) {
|
||||||
Latin1String string(dest);
|
Latin1String string(dest);
|
||||||
@ -469,7 +508,7 @@ public:
|
|||||||
Entry *entryAt(int i) const {
|
Entry *entryAt(int i) const {
|
||||||
return reinterpret_cast<Entry *>(((char *)this) + table()[i]);
|
return reinterpret_cast<Entry *>(((char *)this) + table()[i]);
|
||||||
}
|
}
|
||||||
int indexOf(const QString &key, bool *exists) const;
|
int indexOf(QStringView key, bool *exists) const;
|
||||||
int indexOf(QLatin1String key, bool *exists) const;
|
int indexOf(QLatin1String key, bool *exists) const;
|
||||||
|
|
||||||
bool isValid(int maxSize) const;
|
bool isValid(int maxSize) const;
|
||||||
@ -577,9 +616,9 @@ public:
|
|||||||
return shallowKey().isValid(maxSize);
|
return shallowKey().isValid(maxSize);
|
||||||
}
|
}
|
||||||
|
|
||||||
bool operator ==(const QString &key) const;
|
bool operator ==(QStringView key) const;
|
||||||
inline bool operator !=(const QString &key) const { return !operator ==(key); }
|
inline bool operator !=(QStringView key) const { return !operator ==(key); }
|
||||||
inline bool operator >=(const QString &key) const;
|
inline bool operator >=(QStringView key) const;
|
||||||
|
|
||||||
bool operator==(QLatin1String key) const;
|
bool operator==(QLatin1String key) const;
|
||||||
inline bool operator!=(QLatin1String key) const { return !operator ==(key); }
|
inline bool operator!=(QLatin1String key) const { return !operator ==(key); }
|
||||||
@ -589,7 +628,7 @@ public:
|
|||||||
bool operator >=(const Entry &other) const;
|
bool operator >=(const Entry &other) const;
|
||||||
};
|
};
|
||||||
|
|
||||||
inline bool Entry::operator >=(const QString &key) const
|
inline bool Entry::operator >=(QStringView key) const
|
||||||
{
|
{
|
||||||
if (value.latinKey)
|
if (value.latinKey)
|
||||||
return (shallowLatin1Key() >= key);
|
return (shallowLatin1Key() >= key);
|
||||||
@ -602,10 +641,10 @@ inline bool Entry::operator >=(QLatin1String key) const
|
|||||||
if (value.latinKey)
|
if (value.latinKey)
|
||||||
return shallowLatin1Key() >= key;
|
return shallowLatin1Key() >= key;
|
||||||
else
|
else
|
||||||
return shallowKey() >= key;
|
return shallowKey() >= QString(key); // ### conversion to QString
|
||||||
}
|
}
|
||||||
|
|
||||||
inline bool operator <(const QString &key, const Entry &e)
|
inline bool operator <(QStringView key, const Entry &e)
|
||||||
{ return e >= key; }
|
{ return e >= key; }
|
||||||
|
|
||||||
inline bool operator<(QLatin1String key, const Entry &e)
|
inline bool operator<(QLatin1String key, const Entry &e)
|
||||||
|
@ -845,7 +845,7 @@ bool QJsonArray::operator!=(const QJsonArray &other) const
|
|||||||
The return value is of type QJsonValueRef, a helper class for QJsonArray
|
The return value is of type QJsonValueRef, a helper class for QJsonArray
|
||||||
and QJsonObject. When you get an object of type QJsonValueRef, you can
|
and QJsonObject. When you get an object of type QJsonValueRef, you can
|
||||||
use it as if it were a reference to a QJsonValue. If you assign to it,
|
use it as if it were a reference to a QJsonValue. If you assign to it,
|
||||||
the assignment will apply to the character in the QJsonArray of QJsonObject
|
the assignment will apply to the element in the QJsonArray or QJsonObject
|
||||||
from which you got the reference.
|
from which you got the reference.
|
||||||
|
|
||||||
\sa operator+()
|
\sa operator+()
|
||||||
|
@ -421,7 +421,7 @@ QJsonArray QCborArray::toJsonArray() const
|
|||||||
}
|
}
|
||||||
|
|
||||||
/*!
|
/*!
|
||||||
Recursively converts every \l QCborValue value in this array to JSON using
|
Recursively converts every \l QCborValue value in this map to JSON using
|
||||||
QCborValue::toJsonValue() and creates a string key for all keys that aren't
|
QCborValue::toJsonValue() and creates a string key for all keys that aren't
|
||||||
strings, then returns the corresponding QJsonObject composed of those
|
strings, then returns the corresponding QJsonObject composed of those
|
||||||
associations.
|
associations.
|
||||||
|
Some files were not shown because too many files have changed in this diff Show More
Loading…
Reference in New Issue
Block a user