summaryrefslogtreecommitdiff
path: root/src/tools/clangrefactoringbackend/source
diff options
context:
space:
mode:
Diffstat (limited to 'src/tools/clangrefactoringbackend/source')
-rw-r--r--src/tools/clangrefactoringbackend/source/clangrefactoringbackend-source.pri6
-rw-r--r--src/tools/clangrefactoringbackend/source/projectpartqueue.cpp147
-rw-r--r--src/tools/clangrefactoringbackend/source/projectpartqueue.h46
3 files changed, 197 insertions, 2 deletions
diff --git a/src/tools/clangrefactoringbackend/source/clangrefactoringbackend-source.pri b/src/tools/clangrefactoringbackend/source/clangrefactoringbackend-source.pri
index 2a78fc0e11..c0d8efe87a 100644
--- a/src/tools/clangrefactoringbackend/source/clangrefactoringbackend-source.pri
+++ b/src/tools/clangrefactoringbackend/source/clangrefactoringbackend-source.pri
@@ -21,7 +21,8 @@ HEADERS += \
$$PWD/projectpartartefactexception.h \
$$PWD/projectpartartefact.h \
$$PWD/filestatuscache.h \
- $$PWD/indexdataconsumer.h
+ $$PWD/indexdataconsumer.h \
+ $$PWD/projectpartqueue.h
!isEmpty(LIBTOOLING_LIBS) {
SOURCES += \
@@ -66,4 +67,5 @@ SOURCES += \
$$PWD/sourcerangefilter.cpp \
$$PWD/symbolindexer.cpp \
$$PWD/projectpartartefact.cpp \
- $$PWD/filestatuscache.cpp
+ $$PWD/filestatuscache.cpp \
+ $$PWD/projectpartqueue.cpp
diff --git a/src/tools/clangrefactoringbackend/source/projectpartqueue.cpp b/src/tools/clangrefactoringbackend/source/projectpartqueue.cpp
new file mode 100644
index 0000000000..d1fdc5a83d
--- /dev/null
+++ b/src/tools/clangrefactoringbackend/source/projectpartqueue.cpp
@@ -0,0 +1,147 @@
+/****************************************************************************
+**
+** Copyright (C) 2018 The Qt Company Ltd.
+** Contact: https://www.qt.io/licensing/
+**
+** This file is part of Qt Creator.
+**
+** Commercial License Usage
+** Licensees holding valid commercial Qt licenses may use this file in
+** accordance with the commercial license agreement provided with the
+** Software or, alternatively, in accordance with the terms contained in
+** a written agreement between you and The Qt Company. For licensing terms
+** and conditions see https://www.qt.io/terms-conditions. For further
+** information use the contact form at https://www.qt.io/contact-us.
+**
+** GNU General Public License Usage
+** Alternatively, this file may be used under the terms of the GNU
+** General Public License version 3 as published by the Free Software
+** Foundation with exceptions as appearing in the file LICENSE.GPL3-EXCEPT
+** included in the packaging of this file. Please review the following
+** information to ensure the GNU General Public License requirements will
+** be met: https://www.gnu.org/licenses/gpl-3.0.html.
+**
+****************************************************************************/
+
+#include "projectpartqueue.h"
+
+namespace ClangBackEnd {
+
+ProjectPartQueue::ProjectPartQueue()
+{
+
+}
+
+namespace {
+
+template<class InputIt1,
+ class InputIt2,
+ class OutputIt,
+ class Compare,
+ class Merge>
+OutputIt set_union_merge(InputIt1 first1,
+ InputIt1 last1,
+ InputIt2 first2,
+ InputIt2 last2,
+ OutputIt d_first,
+ Compare comp,
+ Merge merge)
+{
+ for (; first1 != last1; ++d_first) {
+ if (first2 == last2)
+ return std::copy(first1, last1, d_first);
+ if (comp(*first2, *first1)) {
+ *d_first = *first2++;
+ } else {
+ if (comp(*first1, *first2)) {
+ *d_first = *first1;
+ } else {
+ *d_first = merge(*first1, *first2);
+ ++first2;
+ }
+ ++first1;
+ }
+ }
+ return std::copy(first2, last2, d_first);
+}
+
+}
+
+void ProjectPartQueue::addProjectParts(V2::ProjectPartContainers &&projectParts)
+{
+ auto compare = [](const V2::ProjectPartContainer &first, const V2::ProjectPartContainer &second) {
+ return first.projectPartId < second.projectPartId;
+ };
+
+ auto merge = [](V2::ProjectPartContainer &&first,
+ V2::ProjectPartContainer &&second) {
+ first.arguments = std::move(second.arguments);
+ first.compilerMacros = std::move(second.compilerMacros);
+ first.includeSearchPaths = std::move(second.includeSearchPaths);
+ FilePathIds headerPathIds;
+ headerPathIds.reserve(first.headerPathIds.size() + second.headerPathIds.size());
+ std::set_union(first.headerPathIds.begin(),
+ first.headerPathIds.end(),
+ second.headerPathIds.begin(),
+ second.headerPathIds.end(),
+ std::back_inserter(headerPathIds));
+ first.headerPathIds = std::move(headerPathIds);
+ FilePathIds sourcePathIds;
+ headerPathIds.reserve(first.sourcePathIds.size() + second.sourcePathIds.size());
+ std::set_union(first.sourcePathIds.begin(),
+ first.sourcePathIds.end(),
+ second.sourcePathIds.begin(),
+ second.sourcePathIds.end(),
+ std::back_inserter(sourcePathIds));
+ first.sourcePathIds = std::move(sourcePathIds);
+
+ return first;
+ };
+
+ V2::ProjectPartContainers mergedProjectParts;
+ mergedProjectParts.reserve(m_projectParts.size() + projectParts.size());
+ set_union_merge(std::make_move_iterator(m_projectParts.begin()),
+ std::make_move_iterator(m_projectParts.end()),
+ std::make_move_iterator(projectParts.begin()),
+ std::make_move_iterator(projectParts.end()),
+ std::back_inserter(mergedProjectParts),
+ compare,
+ merge);
+
+ m_projectParts = std::move(mergedProjectParts);
+}
+
+class CompareDifference
+{
+public:
+ bool operator()(const V2::ProjectPartContainer &first, const Utils::SmallString &second)
+ {
+ return first.projectPartId < second;
+ }
+
+ bool operator()(const Utils::SmallString &first, const V2::ProjectPartContainer &second)
+ {
+ return first < second.projectPartId;
+ }
+};
+
+void ProjectPartQueue::removeProjectParts(const Utils::SmallStringVector &projectsPartIds)
+{
+ V2::ProjectPartContainers notToBeRemovedProjectParts;
+ notToBeRemovedProjectParts.reserve(m_projectParts.size());
+ std::set_difference(std::make_move_iterator(m_projectParts.begin()),
+ std::make_move_iterator(m_projectParts.end()),
+ projectsPartIds.begin(),
+ projectsPartIds.end(),
+ std::back_inserter(notToBeRemovedProjectParts),
+ CompareDifference{});
+
+ m_projectParts = std::move(notToBeRemovedProjectParts);
+}
+
+const V2::ProjectPartContainers &ProjectPartQueue::projectParts() const
+{
+ return m_projectParts;
+}
+
+} // namespace ClangBackEnd
diff --git a/src/tools/clangrefactoringbackend/source/projectpartqueue.h b/src/tools/clangrefactoringbackend/source/projectpartqueue.h
new file mode 100644
index 0000000000..b885a1ccb2
--- /dev/null
+++ b/src/tools/clangrefactoringbackend/source/projectpartqueue.h
@@ -0,0 +1,46 @@
+/****************************************************************************
+**
+** Copyright (C) 2018 The Qt Company Ltd.
+** Contact: https://www.qt.io/licensing/
+**
+** This file is part of Qt Creator.
+**
+** Commercial License Usage
+** Licensees holding valid commercial Qt licenses may use this file in
+** accordance with the commercial license agreement provided with the
+** Software or, alternatively, in accordance with the terms contained in
+** a written agreement between you and The Qt Company. For licensing terms
+** and conditions see https://www.qt.io/terms-conditions. For further
+** information use the contact form at https://www.qt.io/contact-us.
+**
+** GNU General Public License Usage
+** Alternatively, this file may be used under the terms of the GNU
+** General Public License version 3 as published by the Free Software
+** Foundation with exceptions as appearing in the file LICENSE.GPL3-EXCEPT
+** included in the packaging of this file. Please review the following
+** information to ensure the GNU General Public License requirements will
+** be met: https://www.gnu.org/licenses/gpl-3.0.html.
+**
+****************************************************************************/
+
+#pragma once
+
+#include <projectpartcontainerv2.h>
+
+namespace ClangBackEnd {
+
+class ProjectPartQueue
+{
+public:
+ ProjectPartQueue();
+
+ void addProjectParts(V2::ProjectPartContainers &&projectParts);
+ void removeProjectParts(const Utils::SmallStringVector &projectsPartIds);
+
+ const V2::ProjectPartContainers &projectParts() const;
+
+private:
+ V2::ProjectPartContainers m_projectParts;
+};
+
+} // namespace ClangBackEnd