summaryrefslogtreecommitdiff
path: root/src/plugins/cpptools/cppmodelmanager.cpp
diff options
context:
space:
mode:
Diffstat (limited to 'src/plugins/cpptools/cppmodelmanager.cpp')
-rw-r--r--src/plugins/cpptools/cppmodelmanager.cpp24
1 files changed, 12 insertions, 12 deletions
diff --git a/src/plugins/cpptools/cppmodelmanager.cpp b/src/plugins/cpptools/cppmodelmanager.cpp
index b27e86fe0a..71703246bc 100644
--- a/src/plugins/cpptools/cppmodelmanager.cpp
+++ b/src/plugins/cpptools/cppmodelmanager.cpp
@@ -996,34 +996,34 @@ void CppModelManager::delayedGC()
d->m_delayedGcTimer.start(500);
}
-static QStringList idsOfAllProjectParts(const ProjectInfo &projectInfo)
+static QStringList removedProjectParts(const QStringList &before, const QStringList &after)
{
- QStringList projectPaths;
- foreach (const ProjectPart::Ptr &part, projectInfo.projectParts())
- projectPaths << part->id();
- return projectPaths;
+ QSet<QString> b = before.toSet();
+ b.subtract(after.toSet());
+
+ return b.toList();
}
void CppModelManager::onAboutToRemoveProject(ProjectExplorer::Project *project)
{
- QStringList projectPartIds;
+ QStringList idsOfRemovedProjectParts;
d->m_projectToIndexerCanceled.remove(project);
{
QMutexLocker locker(&d->m_projectMutex);
d->m_dirty = true;
-
- // Save paths
- const ProjectInfo projectInfo = d->m_projectToProjectsInfo.value(project, ProjectInfo());
- projectPartIds = idsOfAllProjectParts(projectInfo);
+ const QStringList projectPartsIdsBefore = d->m_projectPartIdToProjectProjectPart.keys();
d->m_projectToProjectsInfo.remove(project);
recalculateProjectPartMappings();
+
+ const QStringList projectPartsIdsAfter = d->m_projectPartIdToProjectProjectPart.keys();
+ idsOfRemovedProjectParts = removedProjectParts(projectPartsIdsBefore, projectPartsIdsAfter);
}
- if (!projectPartIds.isEmpty())
- emit projectPartsRemoved(projectPartIds);
+ if (!idsOfRemovedProjectParts.isEmpty())
+ emit projectPartsRemoved(idsOfRemovedProjectParts);
delayedGC();
}