aboutsummaryrefslogtreecommitdiffstats
path: root/src/plugins/designer
diff options
context:
space:
mode:
authorThe Qt Project <gerrit-noreply@qt-project.org>2019-10-04 10:24:07 +0000
committerThe Qt Project <gerrit-noreply@qt-project.org>2019-10-04 10:24:07 +0000
commit77cf25751e043572dc40d9a2be0ba3a0aceb83c1 (patch)
tree1168754be6f6e727211e06bd8b6c88b814253cd5 /src/plugins/designer
parent7651ba50fce0634b203d252ee024017f655aed1b (diff)
parent4f0ffcecbe9e64741fb8528ecb07c923a0cfa0cc (diff)
Merge "Merge remote-tracking branch 'origin/4.10' into 4.11" into 4.11
Diffstat (limited to 'src/plugins/designer')
-rw-r--r--src/plugins/designer/resourcehandler.cpp33
1 files changed, 11 insertions, 22 deletions
diff --git a/src/plugins/designer/resourcehandler.cpp b/src/plugins/designer/resourcehandler.cpp
index 392b632a8f8..a86bf217927 100644
--- a/src/plugins/designer/resourcehandler.cpp
+++ b/src/plugins/designer/resourcehandler.cpp
@@ -103,37 +103,26 @@ void ResourceHandler::updateResourcesHelper(bool updateProjectResources)
// Find the (sub-)project the file belongs to. We don't want to find resources
// from other parts of the project tree, e.g. via a qmake subdirs project.
- Node * const fileNode = project->rootProjectNode()->findNode([&fileName](const Node *n) {
+ ProjectNode *projectNode = project->rootProjectNode();
+ Node * const fileNode = projectNode->findNode([&fileName](const Node *n) {
return n->filePath().toString() == fileName;
});
- ProjectNode *projectNodeForUiFile = nullptr;
if (fileNode) {
// We do not want qbs groups or qmake .pri files here, as they contain only a subset
// of the relevant files.
- projectNodeForUiFile = fileNode->parentProjectNode();
- while (projectNodeForUiFile && !projectNodeForUiFile->isProduct())
- projectNodeForUiFile = projectNodeForUiFile->parentProjectNode();
+ projectNode = fileNode->parentProjectNode();
+ while (projectNode && !projectNode->isProduct())
+ projectNode = projectNode->parentProjectNode();
}
- if (!projectNodeForUiFile)
- projectNodeForUiFile = project->rootProjectNode();
-
- const auto useQrcFile = [projectNodeForUiFile, project](const Node *qrcNode) {
- if (projectNodeForUiFile == project->rootProjectNode())
- return true;
- ProjectNode *projectNodeForQrcFile = qrcNode->parentProjectNode();
- while (projectNodeForQrcFile && !projectNodeForQrcFile->isProduct())
- projectNodeForQrcFile = projectNodeForQrcFile->parentProjectNode();
- return !projectNodeForQrcFile
- || projectNodeForQrcFile == projectNodeForUiFile
- || projectNodeForQrcFile->productType() != ProductType::App;
- };
+ if (!projectNode)
+ projectNode = project->rootProjectNode();
QStringList projectQrcFiles;
- project->rootProjectNode()->forEachNode([&](FileNode *node) {
- if (node->fileType() == FileType::Resource && useQrcFile(node))
+ projectNode->forEachNode([&](FileNode *node) {
+ if (node->fileType() == FileType::Resource)
projectQrcFiles.append(node->filePath().toString());
}, [&](FolderNode *node) {
- if (dynamic_cast<ResourceEditor::ResourceTopLevelNode *>(node) && useQrcFile(node))
+ if (dynamic_cast<ResourceEditor::ResourceTopLevelNode *>(node))
projectQrcFiles.append(node->filePath().toString());
});
// Check if the user has chosen to update the lacking resource inside designer
@@ -145,7 +134,7 @@ void ResourceHandler::updateResourcesHelper(bool updateProjectResources)
}
if (!qrcPathsToBeAdded.isEmpty()) {
m_handlingResources = true;
- projectNodeForUiFile->addFiles(qrcPathsToBeAdded);
+ projectNode->addFiles(qrcPathsToBeAdded);
m_handlingResources = false;
projectQrcFiles += qrcPathsToBeAdded;
}