summaryrefslogtreecommitdiffstats
path: root/clang/lib/Format
diff options
context:
space:
mode:
authorKrasimir Georgiev <krasimir@google.com>2017-11-24 18:00:01 +0000
committerKrasimir Georgiev <krasimir@google.com>2017-11-24 18:00:01 +0000
commitf09c42857f99bb38505a227a73fbc04c09d3e4f7 (patch)
treed71a51f1bdc2aa113a7fad58f3ea8fea27d33836 /clang/lib/Format
parentce2bd4dfd8d56512acd9f4c79f2894703e5977f1 (diff)
downloadbcm5719-llvm-f09c42857f99bb38505a227a73fbc04c09d3e4f7.tar.gz
bcm5719-llvm-f09c42857f99bb38505a227a73fbc04c09d3e4f7.zip
[clang-format] Deduplicate using declarations
Summary: This deduplicated equivalent using declarations within a block. Reviewers: bkramer Reviewed By: bkramer Subscribers: cfe-commits, klimek Differential Revision: https://reviews.llvm.org/D40435 llvm-svn: 318960
Diffstat (limited to 'clang/lib/Format')
-rw-r--r--clang/lib/Format/UsingDeclarationsSorter.cpp20
1 files changed, 20 insertions, 0 deletions
diff --git a/clang/lib/Format/UsingDeclarationsSorter.cpp b/clang/lib/Format/UsingDeclarationsSorter.cpp
index 2c124ec78b1..ef0c7a7d5a4 100644
--- a/clang/lib/Format/UsingDeclarationsSorter.cpp
+++ b/clang/lib/Format/UsingDeclarationsSorter.cpp
@@ -130,7 +130,27 @@ void endUsingDeclarationBlock(
UsingDeclarations->begin(), UsingDeclarations->end());
std::stable_sort(SortedUsingDeclarations.begin(),
SortedUsingDeclarations.end());
+ SortedUsingDeclarations.erase(
+ std::unique(SortedUsingDeclarations.begin(),
+ SortedUsingDeclarations.end(),
+ [](const UsingDeclaration &a, const UsingDeclaration &b) {
+ return a.Label == b.Label;
+ }),
+ SortedUsingDeclarations.end());
for (size_t I = 0, E = UsingDeclarations->size(); I < E; ++I) {
+ if (I >= SortedUsingDeclarations.size()) {
+ // This using declaration has been deduplicated, delete it.
+ auto Begin =
+ (*UsingDeclarations)[I].Line->First->WhitespaceRange.getBegin();
+ auto End = (*UsingDeclarations)[I].Line->Last->Tok.getEndLoc();
+ auto Range = CharSourceRange::getCharRange(Begin, End);
+ auto Err = Fixes->add(tooling::Replacement(SourceMgr, Range, ""));
+ if (Err) {
+ llvm::errs() << "Error while sorting using declarations: "
+ << llvm::toString(std::move(Err)) << "\n";
+ }
+ continue;
+ }
if ((*UsingDeclarations)[I].Line == SortedUsingDeclarations[I].Line)
continue;
auto Begin = (*UsingDeclarations)[I].Line->First->Tok.getLocation();
OpenPOWER on IntegriCloud